本文整理汇总了C#中Location.Equals方法的典型用法代码示例。如果您正苦于以下问题:C# Location.Equals方法的具体用法?C# Location.Equals怎么用?C# Location.Equals使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Location
的用法示例。
在下文中一共展示了Location.Equals方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: testEquals
public void testEquals()
{
// Same UN locode - equal
Assert.True(
new Location(new UnLocode("ATEST"), "test-name", CET, CustomsZone.None).Equals(
new Location(new UnLocode("ATEST"), "test-name", CET, CustomsZone.None)));
// Different UN locodes - not equal
Assert.False(
new Location(new UnLocode("ATEST"), "test-name", CET, CustomsZone.None).Equals(
new Location(new UnLocode("TESTB"), "test-name", CET, CustomsZone.None)));
// Always equal to itself
Location location = new Location(new UnLocode("ATEST"), "test-name", CET, CustomsZone.None);
Assert.True(location.Equals(location));
// Never equal to null
Assert.False(location.Equals(null));
// Special NONE location is equal to itself
Assert.True(Location.None.Equals(Location.None));
try
{
new Location(null, null, null, null);
Assert.Fail("Should not allow any null constructor arguments");
}
catch(ArgumentException)
{
}
}
示例2: check_that_the_Equals_method_works
public void check_that_the_Equals_method_works()
{
Location loc1 = new Location(5, 6);
Location loc2 = new Location(5, 6);
Location loc3 = new Location(5, 5);
Location loc4 = new Location(6, 5);
Specify.That(loc1.Equals(loc2)).ShouldBeTrue();
Specify.That(loc1.Equals(loc3)).ShouldBeFalse();
Specify.That(loc1.Equals(loc4)).ShouldBeFalse();
Specify.That(loc3.Equals(loc4)).ShouldBeFalse();
}
示例3: locationXYRegionHandle
public void locationXYRegionHandle()
{
Location TestLocation1 = new Location(256000,256000);
Location TestLocation2 = new Location(1099511628032000);
Assert.That(TestLocation1 == TestLocation2);
Assert.That(TestLocation2.X == 256000 && TestLocation2.Y == 256000, "Test xy location doesn't match regionhandle provided");
Assert.That(TestLocation2.RegionHandle == 1099511628032000,
"Location RegionHandle Property didn't match regionhandle provided in constructor");
TestLocation1 = new Location(256001, 256001);
TestLocation2 = new Location(1099511628032000);
Assert.That(TestLocation1 != TestLocation2);
Assert.That(TestLocation1.Equals(256001, 256001), "Equals(x,y) failed to match the position in the constructor");
Assert.That(TestLocation2.GetHashCode() == (TestLocation2.X.GetHashCode() ^ TestLocation2.Y.GetHashCode()), "GetHashCode failed to produce the expected hashcode");
Location TestLocation3;
object cln = TestLocation2.Clone();
TestLocation3 = (Location) cln;
Assert.That(TestLocation3.X == TestLocation2.X && TestLocation3.Y == TestLocation2.Y,
"Cloned Location values do not match");
Assert.That(TestLocation2.Equals(cln), "Cloned object failed .Equals(obj) Test");
}
示例4: CanCompareForEquality
public void CanCompareForEquality()
{
Location loc1 = new Location(85.6789, 92.4517);
Location loc2 = new Location(85.6789, 92.4517);
Assert.True(loc1.Equals(loc2));
Assert.Equal(loc1.GetHashCode(), loc2.GetHashCode());
}
示例5: LocationEquals_CompareToNull_ReturnsFalse
public void LocationEquals_CompareToNull_ReturnsFalse()
{
int x = 300;
int y = 300;
Location location1 = new Location(x, y);
Assert.AreEqual(false, location1.Equals(null)); ;
}
示例6: LocationEquals_TwoObjectsDifferentCoordinates_ReturnsFalse
public void LocationEquals_TwoObjectsDifferentCoordinates_ReturnsFalse()
{
int x = 300;
int y = 300;
Location location1 = new Location(x, y);
Location location2 = new Location(x + 1, y);
Assert.AreEqual(false, location1.Equals(location2)); ;
}
示例7: RouteSpecification
public RouteSpecification(Location.Location origin, Location.Location destination, DateTime arrivalDeadline)
{
if (origin == null) throw new ArgumentNullException("origin");
if (destination == null) throw new ArgumentNullException("destination");
if (arrivalDeadline < DateTime.Now.AddDays(2)) throw new ArgumentException("arrivalDeadline should be greater than actual date by two days");
if (origin.Equals(destination)) throw new ArgumentException("Origin and destination can't be the same: " + origin.Name);
_origin = origin;
_destination = destination;
_arrivalDeadline = arrivalDeadline;
}
示例8: FindNextLocation
public static Location FindNextLocation(Location start, Location dest, IGameState state)
{
if (start.Equals(dest) || !state.GetIsPassable(dest))
return null;
List<Location> list = FindPath(start, dest, state);
if (list != null)
return list[0];
else
return null;
}
示例9: FindNextLocation
public static Location FindNextLocation(Location start, Location dest, IGameState state, List<Location> avoid, LayeredInfluenceMap heat)
{
if (start.Equals(dest) || !state.GetIsPassable(dest) || avoid.Contains(dest))
return null;
List<Location> list = FindPath(start, dest, state, avoid, heat);
if (list != null)
return list[0];
else
return null;
}
示例10: TestEquals
public void TestEquals()
{
// Same UN locode - equal
Assert.IsTrue(new Location(new UnLocode("ATEST"), "test-name").
Equals(new Location(new UnLocode("ATEST"), "test-name")));
// Different UN locodes - not equal
Assert.IsFalse(new Location(new UnLocode("ATEST"), "test-name").
Equals(new Location(new UnLocode("TESTB"), "test-name")));
// Always equal to itself
var location = new Location(new UnLocode("ATEST"), "test-name");
Assert.IsTrue(location.Equals(location));
// Never equal to null
Assert.IsFalse(location.Equals(null));
// Special UNKNOWN location is equal to itself
Assert.IsTrue(Location.UNKNOWN.Equals(Location.UNKNOWN));
new Location(null, null);
}
示例11: Program
public Program()
{
State state = new State("map.txt"); // State
Location start = new Location(1, 1);
Location dest = new Location(3, 13);
List<Location> avoid = new List<Location>();
List<Location> closed, open;
List<Location> path = Pathfinding.FindPath(start, dest, state, avoid, out closed, out open);
//List<Location> path = Pathfinding.GetNeighbours(dest, state);
if (path == null)
path = new List<Location>();
for (int y = 0; y < state.Height; y++)
{
for (int x = 0; x < state.Width; x++)
{
if (start.Equals(new Location(y, x)))
Console.Write("S");
else if (dest.Equals(new Location(y, x)))
Console.Write("E");
else if (path.Contains(new Location(y, x)))
Console.Write("*");
else if (state.Map[y, x])
Console.Write("=");
else if (closed.Contains(new Location(y, x)))
Console.Write(" ");
else if (open.Contains(new Location(y, x)))
Console.Write("+");
else
Console.Write(".");
}
Console.WriteLine();
}
Console.WriteLine();
Console.Write("Length = " + path.Count.ToString());
Console.ReadLine();
}
示例12: checkPossibleWays
private void checkPossibleWays(int movesLeft, Location position, Location previousPosition, List<Location> path)
{
path.Add(position);
if (movesLeft == 0) {
List<Location> onePath = createPath(path);
endPositions.Add(onePath);
} else {
//To the right
if (position.column + 1 != state.gridSize.Width && (
(state.types[position.row][position.column + 1] == (int)SquareType.Properties && state.values[position.row][position.column + 1] > 0) ||
(state.types[position.row][position.column + 1] != (int)SquareType.Properties)
)) {
Location p = new Location(position.column + 1, position.row);
//Makes sure to not add the square where it came from
if (previousPosition.Equals(p) == false) {
//In case it's a line.
if (state.types[position.row][position.column + 1] == (int)SquareType.Lines)
checkPossibleWays(movesLeft, p, position, path);
else
checkPossibleWays(movesLeft - 1, p, position, path);
}
}
//To the left
if (position.column - 1 != -1 && (
(state.types[position.row][position.column - 1] == (int)SquareType.Properties && state.values[position.row][position.column - 1] > 0) ||
(state.types[position.row][position.column - 1] != (int)SquareType.Properties)
)) {
Location p = new Location(position.column - 1, position.row);
//Makes sure to not add the square where it came from
if (previousPosition.Equals(p) == false) {
//In case it's a line.
if (state.types[position.row][position.column - 1] == (int)SquareType.Lines)
checkPossibleWays(movesLeft, p, position, path);
else
checkPossibleWays(movesLeft - 1, p, position, path);
}
}
//Up
if (position.row - 1 != -1 && (
(state.types[position.row - 1][position.column] == (int)SquareType.Properties && state.values[position.row - 1][position.column] > 0) ||
(state.types[position.row - 1][position.column] != (int)SquareType.Properties)
)) {
Location p = new Location(position.column, position.row - 1);
//Makes sure to not add the square where it came from
if (previousPosition.Equals(p) == false) {
//In case it's a line.
if (state.types[position.row - 1][position.column] == (int)SquareType.Lines)
checkPossibleWays(movesLeft, p, position, path);
else
checkPossibleWays(movesLeft - 1, p, position, path);
}
}
//Down
if (position.row + 1 != state.gridSize.Height && (
(state.types[position.row + 1][position.column] == (int)SquareType.Properties && state.values[position.row + 1][position.column] > 0) ||
(state.types[position.row + 1][position.column] != (int)SquareType.Properties)
)) {
Location p = new Location(position.column, position.row + 1);
//Makes sure to not add the square where it came from
if (previousPosition.Equals(p) == false) {
//In case it's a line.
if (state.types[position.row + 1][position.column] == (int)SquareType.Lines)
checkPossibleWays(movesLeft, p, position, path);
else
checkPossibleWays(movesLeft - 1, p, position, path);
}
}
}
path.RemoveAt(path.Count - 1);
}
示例13: FindPath
// Returns a list of tiles that form the shortest path between start and dest
public static List<Location> FindPath(Location start, Location dest, IGameState state, List<Location> avoid, LayeredInfluenceMap heat = null, int maxDepth = int.MaxValue)
{
if (start.Equals(dest) || !state.GetIsPassable(dest) || avoid.Contains(dest))
return null;
HashSet<string> closed = new HashSet<string>();
Dictionary<string, PathfindNode> locToNode = new Dictionary<string, PathfindNode>();
List<PathfindNode> open = new List<PathfindNode>();
List<Location> reachable;
PathfindNode first = new PathfindNode(start, null, dest, state, heat[start]);
open.Add(first);
locToNode.Add(MyBot.LocationToKey(first.Position), first);
// Repeat until the destination node is reached
PathfindNode last = null;
while (open.Count > 0)
{
if (state.TimeRemaining < 10)
{
MyBot.LogShit("timeout.txt", "stop B - " + state.TimeRemaining);
return null;
}
// Search the best available tile (lowest cost to reach from start, closest to dest)
PathfindNode best = null;
foreach (PathfindNode next in open)
{
if (best == null)
best = next;
if (next.F < best.F)
best = next;
}
if (best.G > maxDepth)
return null;
//PathfindNode best = open.Min;
// Move to closed list
open.Remove(best);
locToNode.Remove(MyBot.LocationToKey(best.Position));
closed.Add(MyBot.LocationToKey(best.Position));
if (best.Position.Equals(dest)) // Destination added to closed list - almost done!
{
last = best;
break;
}
// Find tiles adjacent to this tile
reachable = GetNeighbours(best.Position, state);
string lid;
PathfindNode pfn;
foreach (Location next in reachable)
{
if (!state.GetIsPassable(next) || avoid.Contains(next)) // Check if tile is blocked
continue;
lid = MyBot.LocationToKey(next);
if (closed.Contains(lid))
continue;
if(locToNode.ContainsKey(lid))
{
pfn = locToNode[lid];
if (best.G + 1 < pfn.G)
pfn.Parent = best;
}
else{
pfn = new PathfindNode(next, best, dest, state, heat[next]);
open.Add(pfn);
locToNode.Add(lid, pfn);
}
}
}
if (last == null)
return null;
// Trace the route from destination to start (using each node's parent property)
List<PathfindNode> route = new List<PathfindNode>();
while (last != first && last != null)
{
route.Add(last);
last = last.Parent;
}
// Reverse route and convert to Points
List<Location> path = new List<Location>();
for (int i = route.Count - 1; i >= 0; i--)
{
path.Add(route[i].Position);
}
//.........这里部分代码省略.........
示例14: OnViewportChanged
protected override void OnViewportChanged()
{
var bounds = ParentMap.ViewportTransform.Inverse.TransformBounds(new Rect(new Point(), ParentMap.RenderSize));
var start = ParentMap.MapTransform.Transform(new Point(bounds.X, bounds.Y));
var end = ParentMap.MapTransform.Transform(new Point(bounds.X + bounds.Width, bounds.Y + bounds.Height));
var minSpacing = MinLineSpacing * 360d / (Math.Pow(2d, ParentMap.ZoomLevel) * 256d);
var spacing = LineSpacings[LineSpacings.Length - 1];
if (spacing >= minSpacing)
{
spacing = LineSpacings.FirstOrDefault(s => s >= minSpacing);
}
var labelStart = new Location(
Math.Ceiling(start.Latitude / spacing) * spacing,
Math.Ceiling(start.Longitude / spacing) * spacing);
var labelEnd = new Location(
Math.Floor(end.Latitude / spacing) * spacing,
Math.Floor(end.Longitude / spacing) * spacing);
var lineStart = new Location(
Math.Min(Math.Max(labelStart.Latitude - spacing, -ParentMap.MapTransform.MaxLatitude), ParentMap.MapTransform.MaxLatitude),
labelStart.Longitude - spacing);
var lineEnd = new Location(
Math.Min(Math.Max(labelEnd.Latitude + spacing, -ParentMap.MapTransform.MaxLatitude), ParentMap.MapTransform.MaxLatitude),
labelEnd.Longitude + spacing);
if (!lineStart.Equals(graticuleStart) || !lineEnd.Equals(graticuleEnd))
{
graticuleStart = lineStart;
graticuleEnd = lineEnd;
var geometry = (PathGeometry)path.Data;
geometry.Figures.Clear();
geometry.Transform = ParentMap.ViewportTransform;
for (var lat = labelStart.Latitude; lat <= end.Latitude; lat += spacing)
{
var figure = new PathFigure
{
StartPoint = ParentMap.MapTransform.Transform(new Location(lat, lineStart.Longitude)),
IsClosed = false,
IsFilled = false
};
figure.Segments.Add(new LineSegment
{
Point = ParentMap.MapTransform.Transform(new Location(lat, lineEnd.Longitude)),
});
geometry.Figures.Add(figure);
}
for (var lon = labelStart.Longitude; lon <= end.Longitude; lon += spacing)
{
var figure = new PathFigure
{
StartPoint = ParentMap.MapTransform.Transform(new Location(lineStart.Latitude, lon)),
IsClosed = false,
IsFilled = false
};
figure.Segments.Add(new LineSegment
{
Point = ParentMap.MapTransform.Transform(new Location(lineEnd.Latitude, lon)),
});
geometry.Figures.Add(figure);
}
var childIndex = 1; // 0 for Path
var format = spacing < 1d ? "{0} {1}°{2:00}'" : "{0} {1}°";
for (var lat = labelStart.Latitude; lat <= end.Latitude; lat += spacing)
{
for (var lon = labelStart.Longitude; lon <= end.Longitude; lon += spacing)
{
TextBlock label;
if (childIndex < Children.Count)
{
label = (TextBlock)Children[childIndex];
}
else
{
var renderTransform = new TransformGroup();
renderTransform.Children.Add(new TranslateTransform());
renderTransform.Children.Add(ParentMap.RotateTransform);
renderTransform.Children.Add(new TranslateTransform());
label = new TextBlock
{
RenderTransform = renderTransform
};
label.SetBinding(TextBlock.ForegroundProperty, new Binding
{
Source = this,
//.........这里部分代码省略.........
示例15: IsAdjacentLocation
/// <summary>
/// Determines whether the specified location is adjacent to this instance.
/// That is, whether it is located one point to the left, right, above, or below.
/// </summary>
/// <param name="location">The location.</param>
/// <returns>
/// <c>true</c> if the specified location is adjacent; otherwise, <c>false</c>.
/// </returns>
public bool IsAdjacentLocation(Location location)
{
return !location.Equals(this)
&& ((ColumnNumber == location.ColumnNumber
&& RowNumber <= location.RowNumber + 1
&& RowNumber >= location.RowNumber - 1)
||
(RowNumber == location.RowNumber
&& ColumnNumber <= location.ColumnNumber + 1
&& ColumnNumber >= location.ColumnNumber - 1)
);
}