本文整理汇总了C#中Tile.Equals方法的典型用法代码示例。如果您正苦于以下问题:C# Tile.Equals方法的具体用法?C# Tile.Equals怎么用?C# Tile.Equals使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Tile
的用法示例。
在下文中一共展示了Tile.Equals方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Test
public void Test()
{
Tile tile1 = new Tile
{
TileSetId = 1,
TileId = 2,
};
Tile tile2 = new Tile
{
TileSetId = 1,
TileId = 2,
};
Tile tile3 = new Tile
{
TileSetId = 1,
TileId = 3,
};
Assert.IsTrue(Tile.Equals(tile1, tile2));
Assert.IsFalse(Tile.Equals(tile1, tile3));
Assert.IsFalse(Tile.Equals(tile1, null));
Assert.IsTrue(tile1.Equals(tile2));
Assert.IsFalse(tile1.Equals(tile3));
Assert.IsFalse(tile1.Equals(null));
Assert.IsTrue(tile1 == tile2);
Assert.IsFalse(tile1 != tile2);
Assert.IsFalse(tile1 == tile3);
Assert.IsTrue(tile1 != tile3);
Assert.IsFalse(tile1 == null);
Assert.IsTrue(tile1 != null);
}
示例2: EqualsTest
public void EqualsTest()
{
Tile target = new Tile(); // TODO: Initialize to an appropriate value
object obj = null; // TODO: Initialize to an appropriate value
bool expected = false; // TODO: Initialize to an appropriate value
bool actual;
actual = target.Equals(obj);
Assert.AreEqual(expected, actual);
Assert.Inconclusive("Verify the correctness of this test method.");
}
示例3: FindPath
/*
* Finds the shortest path from the player's position to the goal tile.
* Note that this returns the path as a link list and the front of the list
* is the end of the path.
*
* Arguments
* - Tile goal - The goal of the path
* - bool allowBlockedGoal - Allow us to keep looking if the goal is blocked
* - bool stealth - Stops finding a path if the distance is too far. Used by Stealth objects
* as an performance improvement.
*/
PathTile FindPath(Tile goal, bool allowBlockedGoal, bool stealth)
{
HashSet<Tile> explored = new HashSet<Tile>(); // The explored tiles
Tile neighbour; // The neighbour to a currently looked at tile
PathTile current; // The currently looked at tile
Queue<PathTile> q; // Queue of path tiles
/* Breadth first search */
if (goal != null && (allowBlockedGoal || !blockedTiles.Contains(goal))) {
q = new Queue<PathTile>();
q.Enqueue(new PathTile(playerScript.PlayerPosition()));
while (q.Count != 0) {
current = q.Dequeue();
if (current.Equals(goal)) // Found the goal
return current;
for (int z = 1; z >= -1; z -= 2) {
neighbour = new Tile(current.X + 0, current.Z + z);
if (neighbour.Equals(goal)) // Goal is the neighbour
return new PathTile(current, neighbour);
if (stealth && new PathTile(current, neighbour).Depth > 10)
continue;
if (!blockedTiles.Contains(neighbour) && !explored.Contains(neighbour)) {
explored.Add(neighbour);
q.Enqueue(new PathTile(current, neighbour));
}
}
for (int x = 1; x >= -1; x -= 2) {
neighbour = new Tile(current.X + x, current.Z + 0);
if (neighbour.Equals(goal)) // Neighbour is the goal
return new PathTile(current, neighbour);
if (stealth && new PathTile(current, neighbour).Depth > 10)
continue;
if (!blockedTiles.Contains(neighbour) && !explored.Contains(neighbour)) {
explored.Add(neighbour);
q.Enqueue(new PathTile(current, neighbour));
}
}
}
}
return null;
}
示例4: RequestMovement
/**
* This does one of two things: visualises the player's movement choice, or it confirms
* and moves a player's movement choice. Which one is chosen depends on whether this is the
* first time the player has clicked the goal tile or the second time.
*/
public void RequestMovement(Tile goal)
{
PathTile dest; // The destination tile
if (InteractiveTiles.Count >= 1) {
InteractiveTiles[0].CloseEvent();
}
if (moving == Moving.YES) {
return;
}
if (moving == Moving.POSSIBLY && goal.Equals(clickedTile)) {
if (playerScript.GetStatValue(Stat.AP) < 0f || playerScript.GetStatValue(Stat.AP) > 0f)
moving = Moving.YES;
return;
}
if (moving == Moving.POSSIBLY) { /* Clears all visual elements of selected path */
Destroy(GameObject.FindGameObjectWithTag("Highlighted Tile"));
ClearPath();
}
if (UseInteractable(goal)) // We interacted with an object
return;
dest = FindPath(goal, false, false);
if (dest != null) {
cost = dest.Depth;
SpawnHighlightedTile(goal);
clickedTile = goal;
moving = Moving.POSSIBLY;
path = FlipPath(dest);
dest = dest.Parent;
}
while (dest != null && dest.Parent != null) {
if (dest.Depth > playerScript.GetStatValue(Stat.AP)) // Not enough AP to reach tile
visualPath.AddLast(SpawnPathTile(dest, InvalidPathMarker) as GameObject);
else // Enough AP to reach tile
visualPath.AddLast(SpawnPathTile(dest, ValidPathMarker) as GameObject);
dest = dest.Parent;
}
}
示例5: GetInteractable
/*
* Get Index of Interactable on a certain Tile.
*
* Arguments
* - Tile tile - The tile to find
*/
public int GetInteractable(Tile tile)
{
for (int i = 0; i < InteractiveTiles.Count; i++) {
if (tile.Equals(InteractiveTiles[i].GetTile())) // We found the tile
return i;
}
return -1;
}
示例6: searchForTile
//returns the distance to the tile
public int searchForTile(int x,int y,Tile tile, int mov, TileCosts costs)
{
int max = 20;
//print ("doing " + mov);
//if (mov < gridDistance(x,tile.x,y,tile.y)) return -100; //failure
if (mov >= max) return int.MaxValue; //stop looking after some point
if (tile.Equals(map[x,y])) return mov; //success
int left,right,up,down,final;
final = left = right = up = down = int.MaxValue; //high value so it wont be chosen
if (onMap (x+1,y)) right = gridDistance(x+1,tile.x,y,tile.y) + (int)costs.costs[map[x+1,y].type];
if (onMap (x-1,y)) left = gridDistance(x-1,tile.x,y,tile.y) + (int)costs.costs[map[x-1,y].type];
if (onMap (x,y+1)) up = gridDistance(x,tile.x,y+1,tile.y) + (int)costs.costs[map[x,y+1].type];
if (onMap (x,y-1)) down = gridDistance(x,tile.x,y-1,tile.y) + (int)costs.costs[map[x,y-1].type];
while(up < int.MaxValue || down < int.MaxValue || left < int.MaxValue || right < int.MaxValue){
if(up < down && up < right && up < left){
final = searchForTile(x,y+1,tile,mov + (int)costs.costs[map[x,y+1].type],costs);
if (final >= max) up = int.MaxValue; //this condition is so it will check the other options if it deadends
else return final;
}
if (down < left && down < right){
final = searchForTile(x,y-1,tile,mov + (int) costs.costs[map[x,y-1].type],costs);
if (final >= max) down = int.MaxValue;
else return final;
}
if (left < right){
final = searchForTile(x-1,y,tile,mov + (int) costs.costs[map[x-1,y].type],costs);
if (final >= max) left = int.MaxValue;
else return final;
}
if (right < int.MaxValue){
final = searchForTile(x+1,y,tile,mov + (int) costs.costs[map[x+1,y].type],costs);
if (final >= max) right = int.MaxValue;
else return final;
}
}
return final;
}
示例7: checkPair
/*
* Called once 2 tiles have been selected. Checks if a match has been made
*/
public bool checkPair(Tile other){
return other.Equals (pair);
}