本文整理汇总了C#中Unit.move方法的典型用法代码示例。如果您正苦于以下问题:C# Unit.move方法的具体用法?C# Unit.move怎么用?C# Unit.move使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Unit
的用法示例。
在下文中一共展示了Unit.move方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: MoveAndDig
public static bool MoveAndDig(Unit digger, IEnumerable<Point> targets)
{
Bb.ReadBoard();
var passable = Solver.GetPassable();
var moveTargets = targets.SelectMany(t => Pather.GetNeighbors(t, passable)).ToBitArray();
moveTargets.And(targets.ToBitArray().Not());
if (digger.MovementLeft == 0)
{
if (Dig(digger, targets, GetDiggableAndUnDug()))
{
return true;
}
return false;
}
var steps = Solver.GetWalkingSteps(digger.ToPoint(), moveTargets);
if (steps == null)
{
return false;
}
foreach (var step in steps)
{
if (digger.MovementLeft > 0)
{
digger.move(step.x, step.y);
}
}
Dig(digger, targets, GetDiggableAndUnDug());
return true;
}
示例2: go
//Returns false if there's no pieces left to move.
public bool go()
{
//If it's the move phase, move the strongest unit that hasn't moved yet towards
//the enemy with the highest attack to HP ratio.
if (phase == Phase.MOVE) {
unit = getNextUnit();
if (unit == null) {
return true;
}
target = getPreferredEnemy();
if (target == null) {
return true;
}
HexPosition[] path = getPath(unit, target);
//You can freeze the enemy AI by hiding the desired enemy out of reach. I should fix this eventually,
//and make it go on to the next target or something. Or try to clear a path to that unit.
if(path == null) {
unit.skipMove();
} else {
unit.move(path);
}
phase = Phase.ATTACK;
//If it's the attack phase, attack the target, or if you haven't gotten close enough,
//find the best enemy in range to attack. If nobody is in range, do nothing.
} else {
if (unit.Coordinates.dist(target.Coordinates) <= unit.RANGE) {
unit.attack(target);
phase = Phase.MOVE;
} else {
target = null;
double score = 0;
foreach (Unit other_unit in units) {
if (other_unit.PLAYER == player || unit.Coordinates.dist(other_unit.Coordinates) > unit.RANGE) {
continue;
}
double new_score = other_unit.STRENGTH / other_unit.HP;
if (new_score > score) {
score = new_score;
target = other_unit;
}
}
if (target != null) {
unit.attack (target);
}
phase = Phase.MOVE;
}
}
return false;
}
示例3: moveTo
public void moveTo(Unit u, Position to)
{
if (!canMove(to.x, to.y, u.race) || !accessible(to, u) || u.aBouge) { }
else
{
Console.WriteLine("L'unite " + u.name + " bouge de (" + u.pos.x + "," + u.pos.y + ") en (" + to.x + "," + to.y + ")");
Position from = u.pos;
//Récupération de l'ancienne liste
//supression de l'unité
List<Unit> uList;
units.TryGetValue(from, out uList);
uList.Remove(u);
units.Remove(from);
units.Add(from, uList);
//Récupération de la nouvelle liste
//et ajout de l'unité
units.TryGetValue(to, out uList);
uList.Add(u);
units.Remove(to);
units.Add(to, uList);
u.move(to);
}
}
示例4: MoveAndAttack
public static void MoveAndAttack(Unit attacker, IEnumerable<Unit> targets, bool ifInRange = false)
{
var alive = targets.Where(t => t.HealthLeft > 0);
if (!alive.Any())
{
return;
}
if (Attack(attacker, alive))
{
return;
}
if (attacker.MovementLeft == 0)
{
return;
}
var steps = GetWalkingSteps(attacker.ToPoint(), alive.Select(t => t.ToPoint()).ToBitArray(), nearbyOk: true);
if (steps == null)
{
return;
}
if (ifInRange)
{
int simulationMoves = attacker.MovementLeft;
foreach (var step in steps)
{
simulationMoves--;
if (simulationMoves < 0)
{
return;
}
if (alive.Any(t => Manhattan(t.ToPoint(), step) < attacker.Range))
{
break;
}
}
}
foreach (var step in steps)
{
attacker.move(step.x, step.y);
if (Attack(attacker, alive) || attacker.MovementLeft == 0)
{
return;
}
}
}
示例5: Move
public static void Move(Unit unit, BitArray goals, bool walkInWater = false)
{
var stepCount = unit.MovementLeft;
if (stepCount == 0)
{
return;
}
var steps = GetWalkingSteps(unit.ToPoint(), goals, walkInWater);
if (steps == null)
{
return;
}
foreach (Point p in steps)
{
if (stepCount == 0)
{
return;
}
unit.move(p.x, p.y);
stepCount--;
}
}
示例6: missionTrenchAroundTarget
private static void missionTrenchAroundTarget(Unit u, BitArray target)
{
BitArray adj = BitBoard.GetAdjacency(target);
if (!u.HasDug)
{
Tile minTile = null;
List<Node> path = null;
foreach (Tile tile in AI.tiles)
{
if (BitBoard.GetBit(adj, tile.X, tile.Y) && 3 >= Misc.ManhattanDistance(u, tile))
{
BitArray pos = BitBoard.position[tile.X][tile.Y];
BitArray dest = new BitArray(BitBoard.length, false).Or(pos).Or(BitBoard.GetNonDiagonalAdjacency(pos));
List<Node> p = AStar.route(u.X, u.Y, dest);
if (p.Count == 0 && !BitBoard.GetBit(dest, u.X, u.Y)) continue;
if (minTile == null)
{
minTile = tile;
path = p;
}
if (tile.Depth < minTile.Depth)
{
minTile = tile;
path = p;
}
}
}
if (minTile != null)
{
// BitArray pos = BitBoard.position[minTile.X][minTile.Y];
// BitArray dest = new BitArray(BitBoard.length, false).Or(pos).Or(BitBoard.GetNonDiagonalAdjacency(pos));
// List<Node> path = AStar.route(u.X, u.Y, dest);
//int x = u.X;
//int y = u.Y;
foreach (Node n in path)
{
if (u.MovementLeft == 0) break;
u.move(n.x, n.y);
}
if (1 >= Misc.ManhattanDistance(u, minTile))
{
u.dig(minTile);
}
}
}
BitBoard.UpdateAll(); // May cause water to change
}
示例7: missionGoToAttack
private static void missionGoToAttack(Unit u, BitArray b, bool walkThroughWater)
{
if (u.MovementLeft == 0 || BitBoard.Equal(b, BitBoard.empty))
{
return;
}
List<Node> path = AStar.route(u.X, u.Y, b, !walkThroughWater);
if (path.Count == 0)
{
if (BitBoard.GetBit(b, u.X, u.Y))
{
BitArray dest = BitBoard.GetPumpStation(b, u.X, u.Y);
dest.And(BitBoard.GetNonDiagonalAdjacency(BitBoard.oppOccupiedTiles));
if (!BitBoard.Equal(dest, BitBoard.empty))
{
path = AStar.route(u.X, u.Y, dest, !walkThroughWater);
foreach (Node n in path)
{
if (u.MovementLeft == 0) break;
u.move(n.x, n.y);
}
}
}
}
foreach (Node n in path)
{
bool stop = false;
if (u.MovementLeft == 0) break;
//Try to stop once we are close enough to attack
foreach (Unit unit in AI.units)
{
if (unit.Owner != u.Owner)
{
if (u.Range >= Misc.ManhattanDistance(u, unit) && unit.Type == (int)AI.Types.Tank)
{
stop = true;
break;
}
}
}
if (stop) break;
// Try to move
// if you fail to move,
// curl up in a ball and cry
if (!u.move(n.x, n.y))
{
break;
}
}
BitBoard.UpdateUnits();
}
示例8: missionGoTo
//goto should go to the nearest non-occupied square
//from the target bit board
private static void missionGoTo(Unit u, BitArray b, bool walkThroughWater)
{
if (u.MovementLeft == 0 || BitBoard.Equal(b, BitBoard.empty))
{
return;
}
List<Node> path = AStar.route(u.X, u.Y, b, !walkThroughWater);
foreach (Node n in path)
{
if (u.MovementLeft == 0) break;
// Try to move
// if you fail to move,
// curl up in a ball and cry
if (!u.move(n.x, n.y))
{
break;
}
}
BitBoard.UpdateUnits();
}