本文整理汇总了C#中TileType.GetLength方法的典型用法代码示例。如果您正苦于以下问题:C# TileType.GetLength方法的具体用法?C# TileType.GetLength怎么用?C# TileType.GetLength使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TileType
的用法示例。
在下文中一共展示了TileType.GetLength方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GrowAll
/// <summary>
/// Grows the minerals on the map.
/// </summary>
/// <param name="map">The map where the minerals spawn</param>
/// <param name="biomeMap">The biome map attached to the previous map.</param>
public void GrowAll (TileType[, ] map, BiomeType[, ] biomeMap) {
NoiseGenerator gen = new NoiseGenerator ();
while (availableMinerals.Count > 0) {
MineralInfo mineral = availableMinerals.Dequeue();
gen.Reset();
for (int x = 0; x < map.GetLength(0); x ++) {
int y = (mineral.minHeight > 0 ? mineral.minHeight : 0);
int maxY = (mineral.maxHeight < map.GetLength(1) ? mineral.maxHeight : map.GetLength(1));
for (; y < maxY; y ++) {
if (IsTileCompatible(biomeMap, x, y, mineral.compatibleBiomes) && (mineral.rarity < (int) gen.PerlinNoise(x, y, 10, 100, 1)))
PlaceMinerals(map, x, y, mineral.minerals);
}
}
}
}
示例2: TileMapBuilder
/// <summary>
/// Initializes a new instance of the TileMapBuilder class
/// </summary>
/// <param name="map">matrix of symbols</param>
/// <param name="dictionary">dictionary with keys for the symbols</param>
/// <param name="tileSize">Tile size</param>
public TileMapBuilder(TileType[,] map, Dictionary<TileType, Bitmap> dictionary, int tileSize)
{
int mapRows = map.GetLength(0);
int mapCols = map.GetLength(1);
this.MapImage = new Bitmap(mapCols * tileSize, mapRows * tileSize);
Graphics mapGraphics = Graphics.FromImage(this.MapImage);
Bitmap tile;
for (int row = 0; row < mapRows; row++)
{
for (int col = 0; col < mapCols; col++)
{
tile = dictionary[map[row, col]];
int x = col * tileSize;
int y = row * tileSize;
mapGraphics.DrawImage(tile, x, y, tileSize, tileSize);
}
}
}
示例3: DetectSimilarBorderTiles
//Detect if there is a similar tile next to the bordering tile
private int DetectSimilarBorderTiles(TileType[,] area, TileType replaceTarget, int x_coord, int y_coord)
{
int count = 0;
//Check if we are at the edge of the map, since taht would break the program
if (x_coord > 0 && x_coord < area.GetLength (0) - 1 && y_coord > 0 && y_coord < area.GetLength (1) - 1) {
//Directly touching the point
if (area [x_coord - 1, y_coord + 0] == replaceTarget)
count++;
if (area [x_coord + 0, y_coord - 1] == replaceTarget)
count++;
if (area [x_coord + 1, y_coord + 0] == replaceTarget)
count++;
if (area [x_coord + 0, y_coord + 1] == replaceTarget)
count++;
}
return count;
}
示例4: Largest_Space
public int Largest_Space(TileType[,] area, TileType scanTarget, List<Coord> topLeftCoords)
{
int[,] scanArea = new int[area.GetLength (0),area.GetLength (1)];
int largestCount = 0;
int currentCount = 0;
Queue<Coord> coordQ = new Queue<Coord> ();
Coord current;
//This coord will be removed at the end of this function
Coord largestCoord;
largestCoord.x_coord = 0;
largestCoord.y_coord = 0;
//Set scanArea to area so that we can easily scan the map
for (int y = 0; y < scanArea.GetLength(1); y++) {
for (int x = 0; x < scanArea.GetLength(0); x++) {
scanArea[x, y] = (int)area[x, y];
}
}
//Scan the map for the 'scanTarget', when one is found, inspect its area and then compare sizes
//-1 signifies that the tile has been scaned
for (int y = 0; y < scanArea.GetLength(1); y++) {
for (int x = 0; x < scanArea.GetLength(0); x++){
if(scanArea[x, y] == (int)scanTarget){
currentCount = 0;
current.x_coord = x;
current.y_coord = y;
scanArea[x, y] = -1;
coordQ.Enqueue (current);
topLeftCoords.Add (current);
currentCount++;
//Keep scan until queue is empty
while(coordQ.Count != 0){
ScanMap (scanArea, coordQ, scanTarget, ref currentCount);
}
//Compare if this area is the largest
if(currentCount > largestCount){
largestCoord.x_coord = x;
largestCoord.y_coord = y;
largestCount = currentCount;
}
}
}
}
//Remove the coord responsible for the largest from the list
topLeftCoords.Remove (largestCoord);
return largestCount;
}
示例5: GenerateSquares
/// <summary>
/// Generates the gameobjects.
/// </summary>
/// <param name="map">Map.</param>
public void GenerateSquares(TileType[,] map) {
GameObject tile;
for (int i = 0; i < map.GetLength(0); i++) {
for (int j = 0; j < map.GetLength(1); j++) {
tile = (GameObject)Instantiate(getTile(map[i, j]), new Vector3(i, j, 0), Quaternion.identity);
tile.name = "Tile[" + i + "][" + j + "]";
tile.transform.parent = tileCollection.transform;
tileMap.Add (new Coord(i, j), tile);
Diffusion d = tile.GetComponent<Diffusion> ();
if (d)
AIMap.Add(new Coord(i, j), d);
MouseOver m = tile.GetComponent<MouseOver> ();
if (m && m.isLinkable) {
linkables.Enqueue (m);
}
}
}
foreach (KeyValuePair<Coord, Diffusion> kvp in AIMap) {
AttachNeighbours(kvp.Key.x, kvp.Key.y);
}
LinkLinkables ();
}
示例6: GenerateElevators
/// <summary>
/// Creates an instantites the tiles.
/// </summary>
/// <param name="map"></param>
/// <param name="dividerLevel"></param>
/// <param name="availiableTile"></param>
protected virtual void GenerateElevators(TileType[,] map, int dividerLevel, Dictionary<TileSetType, TileLevel> availiableTile)
{
List<Vector2> leftEnds = new List<Vector2>();
List<Vector2> rightEnds = new List<Vector2>();
for (int xdx = 0; xdx < map.GetLength(0); xdx++)
{
for (int ydx = 0; ydx < map.GetLength(1); ydx++)
{
TileType type = map[xdx, ydx];
if (type == TileType.LeftEnd)
{
leftEnds.Add(new Vector2(xdx, ydx));
}
else if (type == TileType.RightEnd)
{
rightEnds.Add(new Vector2(xdx, ydx));
}
}
}
DualStore<Vector2, Vector2> veritcal = new DualStore<Vector2, Vector2>();
foreach (Vector2 vec in rightEnds)
{
int xdx = (int)vec.x + 1;
//int ydx = (int)vec.y;
for (int ydx = (int)vec.y - 1; ydx > 0; ydx--)
{
if (map[xdx, ydx] != TileType.None)
{
veritcal.Add(new Vector2(xdx, vec.y), new Vector2(xdx, ydx + 1));
ydx = -1;
}
else if (map[xdx - 1, ydx] == TileType.RightEnd)
{
veritcal.Add(new Vector2(xdx, vec.y), new Vector2(xdx, ydx));
ydx = - 1;
}
else if (map[xdx + 1, ydx] == TileType.LeftEnd)
{
veritcal.Add(new Vector2(xdx, vec.y), new Vector2(xdx, ydx));
ydx = -1;
}
}
}
foreach (Vector2 vec in leftEnds)
{
int xdx = (int)vec.x - 1;
//int ydx = (int)vec.y;
for (int ydx = (int)vec.y - 1; ydx > 0; ydx--)
{
if (map[xdx, ydx] != TileType.None)
{
veritcal.Add(new Vector2(xdx, vec.y), new Vector2(xdx, ydx + 1));
ydx = -1;
}
else if (map[xdx - 1, ydx] == TileType.RightEnd)
{
veritcal.Add(new Vector2(xdx, vec.y), new Vector2(xdx, ydx));
ydx = -1;
}
else if (map[xdx + 1, ydx] == TileType.LeftEnd)
{
veritcal.Add(new Vector2(xdx, vec.y), new Vector2(xdx, ydx));
ydx = -1;
}
}
}
foreach (KeyValuePair<Vector2, Vector2> kv in veritcal.KeyValuePairs)
{
TileSetType level = kv.Value.y > dividerLevel ? TileSetType.upperLevels : TileSetType.lowerLevels;
GameObject obj = availiableTile[level].GetTileType(TileType.Platform);
var tile = (GameObject)Instantiate(obj, new Vector3(kv.Key.x * Tilesize, kv.Key.y * Tilesize), new Quaternion());
ElevatorMovement move = tile.GetComponent(typeof(ElevatorMovement)) as ElevatorMovement;
move.EndPos = new Vector2(kv.Value.x * Tilesize, kv.Value.y * Tilesize);
move.StartPos = new Vector2(kv.Key.x * Tilesize, kv.Key.y * Tilesize);
move.moveDir = MovementDirection.updown;
//ElevatorMovement move = tile.GetComponent<ElevatorMovement>();
Debug.Log(tile);
NetworkServer.Spawn(tile);
}
DualStore<Vector2, Vector2> horizontal = new DualStore<Vector2, Vector2>();
//.........这里部分代码省略.........
示例7: SpiralGeneration
/*Clear*/
//General in a clockwise (square)spiral from the outside base on neighbouring tiles
private void SpiralGeneration(TileType[,] area, TileType replaceTarget, int kFactor, int cFactor)
{
int increment = 1;
bool reachedCenter = false;
//Expand from there by density and build it spirally
do
{
//Top
for (int x = increment; x < area.GetLength(0) - 1 - increment; x++)
GenerateTileByRelation(area, replaceTarget,
x, //x-coord
increment, //y-coord
kFactor, cFactor);
//Right
for (int y = increment; y < area.GetLength(1) - 1 - increment; y++)
GenerateTileByRelation(area, replaceTarget,
area.GetLength(0) - 1 - increment, //x-coord
y, //y-coord
kFactor, cFactor);
//Bottom
for (int x = area.GetLength(0) - 1 - increment; x >= increment; x--)
GenerateTileByRelation(area, replaceTarget,
x, //x-coord
area.GetLength(1) - 1 - increment, //y-coord
kFactor, cFactor);
//Left
for (int y = area.GetLength(1) - 1 - increment - 1; y >= increment + 1; y--)
GenerateTileByRelation(area, replaceTarget,
increment, //x-coord
y, //y-coord
kFactor, cFactor);
//Increment or stop?
if (2 * increment > area.GetLength(0) || 2 * increment > area.GetLength(1))
reachedCenter = true;
else
increment++;
} while (!reachedCenter);
}
示例8: SafeCoord
private bool SafeCoord(TileType[,] area, int x_coord, int y_coord)
{
return(x_coord >= 0 && x_coord < area.GetLength(0) && y_coord >= 0 && y_coord < area.GetLength(1));
}
示例9: GenerateTileByRelation
/*Clear*/
//Replaces tile if the neighbouring tiles are alike
private void GenerateTileByRelation( TileType[,] area, TileType replaceTarget, int x_coord, int y_coord, int kFactor, int cFactor)
{
//(Modifier x Neighbouring Trees) / 100
if (((kFactor * DetectSimilarBorderTiles(area, replaceTarget, x_coord, y_coord)) + cFactor) > (int)Random.Range(0,100) &&
x_coord > 0 && x_coord < area.GetLength (0) - 1 && y_coord > 0 && y_coord < area.GetLength (1) - 1)
area[x_coord, y_coord] = replaceTarget;
}
示例10: PlaceMinerals
void PlaceMinerals (TileType[, ] map, int x, int y, List<TileType> minerals)
{
if (map [x, y] != TileType.NONE && (y + 1) < map.GetLength(1) && map[x, y + 1] != TileType.NONE) {
int i = Random.Range(0, minerals.Count);
map[x, y] = minerals[i];
}
}
示例11: EasyMap
// building an easy map - only up and right turns. EasyMap gets a two dimensional array
// and builds an easy map in it. the number 0 represents a wall (or solid matter)
// and the number 1 represents a room (the path, a hallway, air, what ever you want)
static MapDescriptor EasyMap(int sizeX, int sizeY)
{
System.Random rng = new System.Random();
var tiles = new TileType[sizeX, sizeY];
//finding the greatest common divisor of the lengths of the rectangle.
// this gives a better way of randomizing tiles, instead in a ratio of 1:1
// the ratio depends on the size of the rectangle (for a 10 by 20 rectangle
// the randomizing ratio for up and right will be 1:2)
int gcd = FindGCD(tiles.GetLength(1), tiles.GetLength(0));
int ChanceNum = (tiles.GetLength(1) / gcd) + (tiles.GetLength(0) / gcd);
// setting the whole tiles to 0, everything is a wall
for (int i = 0; i < tiles.GetLength(0); i++) {
for (int j = 0; j < tiles.GetLength(1); j++) {
tiles[i,j] = TileType.Wall;
}
}
//[0,0] is the starting point and so it always equals to 1. [0,0] represents the
// right bottom point of the map
tiles[0, 0] = TileType.Floor;
//indexes to the last tile that was changed
int CurrentRow = 0;
int CurrentCol = 0;
int num;
// the pathway can be as long as the sum of the number of columns
// and rows in the array minus 1
for (int i = 0; i < (tiles.GetLength(0) + tiles.GetLength(1)); i++)
{
if (CurrentCol < tiles.GetLength(1) - 1 && CurrentRow < tiles.GetLength(0) - 1)
{
//getting a random number between 0 and the chance num, so the odds
//of getting an up or right turn will be adjusted by the size of the rectangle
num = rng.Next(0, ChanceNum);
if (num < Math.Min((tiles.GetLength(1) / gcd), (tiles.GetLength(0) / gcd)))
{
if(tiles.GetLength(1)>tiles.GetLength(0)){
CurrentRow++;
tiles[CurrentRow, CurrentCol] = TileType.Floor;
}
else
{
CurrentCol++;
tiles[CurrentRow, CurrentCol] = TileType.Floor;
}
}
else{
if(tiles.GetLength(1)>tiles.GetLength(0))
{
CurrentCol++;
tiles[CurrentRow, CurrentCol] = TileType.Floor;
}else
{
CurrentRow++;
tiles[CurrentRow, CurrentCol] = TileType.Floor;
}
}
}
}
while (CurrentRow != tiles.GetLength(0) - 1)
{
num = rng.Next(0, tiles.GetLength(1));
MoveUp(num, tiles);
CurrentRow++;
}
while (CurrentCol != tiles.GetLength(1) - 1)
{
num = rng.Next(0, tiles.GetLength(0));
MoveRight(num, tiles);
CurrentCol++;
}
var result = new MapDescriptor();
result.tiles = tiles;
// Simple paths always start at the bottom left, end at the top right
result.startX = 0;
result.startY = 0;
result.endX = sizeX;
result.endY = sizeY;
return result;
}
示例12: MoveUp
static void MoveUp(int col, TileType[,] map)
{
int row = map.GetLength(0)-1;
while (map[row-1, col] != TileType.Floor)
{
row--;
}
map[row, col] = TileType.Floor;
for (int i = col+1; i < map.GetLength(1); i++)
{
for (int j = map.GetLength(0)-1; j > 0; j--)
{
if (map[j-1, i] == TileType.Floor)
{
map[j, i] = TileType.Floor;
map[j - 1, i] = TileType.Wall;
}
}
}
}
示例13: MoveRight
static void MoveRight(int row, TileType[,] map)
{
int col = map.GetLength(1) - 1;
while (map[row, col - 1]!=TileType.Floor)
{
col--;
}
map[row,col]=TileType.Floor;
for (int i = row+1; i < map.GetLength(0); i++)
{
for (int j = map.GetLength(1)-1; j > 0; j--)
{
if (map[i, j - 1] == TileType.Floor)
{
map[i, j] = TileType.Floor;
map[i,j - 1] = TileType.Wall;
}
}
}
}
示例14: InstantiateTiles
/// <summary>
/// Instantiates all the tiles.
/// </summary>
/// <param name="map"></param>
/// <param name="dividerLevel"></param>
/// <param name="availiableTile"></param>
protected virtual void InstantiateTiles(TileType[,] map, int dividerLevel, Dictionary<TileSetType, TileLevel> availiableTile, List<Vector2> spawnPoints)
{
for (int xdx = 0; xdx < map.GetLength(0); xdx++)
{
for (int ydx = 0; ydx < map.GetLength(1); ydx++)
{
TileType type = map[xdx, ydx];
if (type != TileType.None && type != TileType.Lava)
{
TileSetType level = ydx > dividerLevel ? TileSetType.upperLevels : TileSetType.lowerLevels;
GameObject obj = availiableTile[level].GetTileType(type);
var tile = (GameObject) Instantiate(obj, new Vector3(xdx * Tilesize, ydx * Tilesize), new Quaternion());
Debug.Log(tile);
NetworkServer.Spawn(tile);
}
else if (type == TileType.Lava)
{
GameObject obj = availiableTile[TileSetType.lava].GetTileType(TileType.Top);
var tile = (GameObject)Instantiate(obj, new Vector3(xdx * Tilesize, ydx * Tilesize), new Quaternion());
tile.name = "Lava";
Debug.Log(tile);
NetworkServer.Spawn(tile);
}
//GameObject bck = availiableTile[TileSetType.background].GetTileType(TileType.Filler);
//var backt = (GameObject)Instantiate(bck, new Vector3(xdx * Tilesize, ydx * Tilesize), new Quaternion());
//backt.name = "background";
//Debug.Log(backt);
//NetworkServer.Spawn(backt);
}
}
foreach(Vector2 point in spawnPoints)
{
var spawn = (GameObject)Instantiate(SpawnPrefab, new Vector3(point.x * Tilesize, point.y * Tilesize), new Quaternion());
spawn.name = "spawnPoint";
Debug.Log(spawn);
NetworkServer.Spawn(spawn);
}
//GameObject back = backgroundPrefab;
var backobj = (GameObject)Instantiate(backgroundPrefab, new Vector3(0, 0, -1.5f), new Quaternion());
BackgroundScript move = backobj.GetComponent(typeof(BackgroundScript)) as BackgroundScript;
move.MapSize = new Vector2(WidthSize * Tilesize, HeightSize * Tilesize);
move.DividerLevel = dividerLevel;
Debug.Log(backobj);
NetworkServer.Spawn(backobj);
}
示例15: FillIsolated
//Similar to ScanMap(), but interacts with the actual map so that changes can be made. replace scanTargets
//to replaceTargets
private void FillIsolated(TileType[,] area, Queue<Coord> topLeftCoords, TileType scanTarget, TileType replaceTarget)
{
Coord current = topLeftCoords.Dequeue ();
Coord nextPoint;
//Scan left
if (current.x_coord > 0) {
if (area[current.x_coord - 1, current.y_coord] == scanTarget){
nextPoint.x_coord = current.x_coord - 1;
nextPoint.y_coord = current.y_coord;
area[nextPoint.x_coord, nextPoint.y_coord] = replaceTarget;
topLeftCoords.Enqueue (nextPoint);
}
}
//Scan right
if (current.x_coord < area.GetLength(0) - 1) {
if (area[current.x_coord + 1, current.y_coord] == scanTarget){
nextPoint.x_coord = current.x_coord + 1;
nextPoint.y_coord = current.y_coord;
area[nextPoint.x_coord, nextPoint.y_coord] = replaceTarget;
topLeftCoords.Enqueue (nextPoint);
}
}
//Scan up
if (current.y_coord > 0) {
if (area[current.x_coord, current.y_coord - 1] == scanTarget){
nextPoint.x_coord = current.x_coord;
nextPoint.y_coord = current.y_coord - 1;
area[nextPoint.x_coord, nextPoint.y_coord] = replaceTarget;
topLeftCoords.Enqueue (nextPoint);
}
}
//Scan down
if (current.y_coord < area.GetLength(1) - 1) {
if (area[current.x_coord, current.y_coord + 1] == scanTarget){
nextPoint.x_coord = current.x_coord;
nextPoint.y_coord = current.y_coord + 1;
area[nextPoint.x_coord, nextPoint.y_coord] = replaceTarget;
topLeftCoords.Enqueue (nextPoint);
}
}
}