コード例 #1
0
ファイル: MapPart.cs プロジェクト: wizard1991/HeroGame
        public ILand[,] GetMap()
        {
            if (_innerMap == null)
            {
                _innerMap = new ILand[Height,Width];

                for (int i = 0; i < Height; i++)
                    for (int j = 0; j < Width; j++)
                    {
                        int res = Generator.Generator.GenerateRandomValue(1, 99);

                        switch (res % 3)
                        {
                            case 0:
                                _innerMap[i, j] = new Ground();
                                break;
                            case 1:
                                _innerMap[i, j] = new Water();
                                break;
                            case 2:
                                _innerMap[i, j] = new Mountain();
                                break;
                        }
                    }
            }
            return _innerMap;
        }
コード例 #2
0
ファイル: MapRegion.cs プロジェクト: Dieho/Hero
        private ILand[,] CreateNewLayout(String landType, String baseLandType, int landSquare)
        {
            //int groundSquare = Generator.Generator.GenerateRandomValue(40, _width * _height - 1);
            const int groundC = 10;
            var map = new String [groundC];
            if (_innerMap != null)
            {
                for (int i = 0; i < groundC; i++)
                {
                    int positionX = Generator.Generator.GenerateRandomValue(0, _width);
                    int positionY = Generator.Generator.GenerateRandomValue(0, _height);

                    if(_innerMap[positionX, positionY].ToString() == baseLandType)
                        switch (landType)
                        {
                            case "Ground":
                                _innerMap[positionX, positionY] = new Ground();
                                break;
                            case "Mountain":
                                _innerMap[positionX, positionY] = new Mountain();
                                break;
                            case "Water":
                                _innerMap[positionX, positionY] = new Water();
                                break;
                        }
                    map[i] = positionX.ToString(CultureInfo.InvariantCulture) + ';' + positionY.ToString(CultureInfo.InvariantCulture);
                }
            }
            _innerMap = SmartLayout(_innerMap, map, landType, landSquare);

            return _innerMap;
        }
コード例 #3
0
ファイル: MapRegion.cs プロジェクト: Dieho/Hero
        private ILand[,] SmartLayout(ILand[,] innerMap, String[] map, String landType, int landSquare)
        {
            for (int i = 0; i < landSquare; i++)
            {
                int position = Generator.Generator.GenerateRandomValue(0, map.Length);
                string [] sep = map[position].Split(new Char[] { ';' });
                int positionX = int.Parse(sep[0]);
                int positionY = int.Parse(sep[1]);

                switch (position % 4)
                {
                    case 0:
                        if (positionX != 0)
                            positionX -= 1;
                        break;
                    case 1:
                        if (positionX != (_width - 1))
                            positionX += 1;
                        break;
                    case 2:
                        if (positionY != 0)
                            positionY -= 1;
                        break;
                    case 3:
                        if (positionY != (_height - 1))
                            positionY += 1;
                        break;
                }

                if (innerMap[positionX, positionY].ToString() == landType)
                    continue;
                switch (landType)
                {
                    case "Ground":
                        _innerMap[positionX, positionY] = new Ground();
                        break;
                    case "Mountain":
                        _innerMap[positionX, positionY] = new Mountain();
                        break;
                    case "Water":
                        _innerMap[positionX, positionY] = new Water();
                        break;
                }
                var buffer = map;
                map = new string[map.Length + 1];
                buffer.CopyTo(map, 0);
                map[map.Length - 1] = positionX.ToString(CultureInfo.InvariantCulture) + ';' + positionY.ToString(CultureInfo.InvariantCulture);

            }
            return innerMap;
        }