本文整理汇总了C#中Map.GetSize方法的典型用法代码示例。如果您正苦于以下问题:C# Map.GetSize方法的具体用法?C# Map.GetSize怎么用?C# Map.GetSize使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Map
的用法示例。
在下文中一共展示了Map.GetSize方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Launch
public void Launch(Map map)
{
// Implementierung der Abschusssequenz
for (int i = 0; i < Map.allowedShots; i++)
{
int randX = RandomNumber(i, 0, map.GetSize());
int randY = RandomNumber(i*2, 0, map.GetSize());
map.fireShot(randX, randY);
}
}
示例2: Launch
public void Launch(Map map)
{
// Implementierung der Abschusssequenz
int randX = RandomNumber(1, 1, map.GetSize()-1);
int randY = RandomNumber(1*2, 1, map.GetSize()-1);
for (int i = 0; i < Map.allowedShots; i++)
{
map.fireShot(randX, randY);
map.fireShot(randX-1, randY);
map.fireShot(randX, randY-1);
map.fireShot(randX, randY+1);
map.fireShot(randX+1, randY);
}
}
示例3: PhysicsUnit
public PhysicsUnit(Item item, Dictionary<int, PhysicsUnit> items)
{
this.item = item;
this.items = items;
moving = item.GetProperty<WalkingProperty>();
collidable = item.GetProperty<CollidableProperty>();
carrier = item.GetProperty<CarrierProperty>();
portable = item.GetProperty<PortableProperty>();
map = item.Engine.Map;
mapSize = map.GetSize();
// Attach Item Stuff
item.CellChanged += item_CellChanged;
// Attach Moving Stuff
if (moving != null)
{
moving.OnMaximumMoveSpeedChanged += moving_OnMaximumMoveSpeedChanged;
moving.OnMoveDirectionChanged += moving_OnMoveDirectionChanged;
moving.OnMoveSpeedChanged += moving_OnMoveSpeedChanged;
moving.MoveMalus = 1;
}
// Attach Collision Stuff
if (collidable != null)
{
collidable.OnCollisionMassChanged += collidable_OnCollisionMassChanged;
collidable.OnCollisionFixedChanged += collidable_OnCollisionFixedChanged;
}
// Attach Carrier Stuff
if (carrier != null)
{
carrier.OnCarrierLoadChanged += carrier_OnCarrierLoadChanged;
carrier.OnCarrierStrengthChanged += carrier_OnCarrierStrengthChanged;
}
// Attach Portable Stuff
if (portable != null)
{
portable.OnPortableWeightChanged += portable_OnPortableMassChanged;
portable.OnNewCarrierItem += portable_OnNewCarrierItem;
portable.OnLostCarrierItem += portable_OnLostCarrierItem;
clusterUnits = new HashSet<PhysicsUnit>();
}
Recalc();
}
示例4: GenerateMap
private void GenerateMap(Map map)
{
var mapSize = map.GetSize();
int width = (int)mapSize.Width - 1;
int height = (int)mapSize.Height - 1;
int count = (int)(width*height*0.35);
var mapWithRiver = GenerateRiver(map);
for (int i = 0; i < mapWithRiver.GetLength(0); i++)
{
for (int j = 0; j < mapWithRiver.GetLength(1); j++)
{
if (mapWithRiver[i, j] > 0)
map.SetObjectFromCell(new Point(i, j), new FixedObject(new Size(1, 1), (uint)(mapWithRiver[i, j] > 1 ? 0x00002000 : 0x00002100)));
}
}
int tmpX, tmpY;
Random rand = new Random();
while( count > 0 )
{
tmpX = rand.Next(width);
tmpY = rand.Next(height);
if( map.GetObjectFromCell(new Point(tmpX, tmpY)) != null )
continue;
switch (count % 11)
{
case 0:
case 1:
map.SetObjectFromCell(new Point(tmpX, tmpY), new AppleTree());
break;
case 2:
case 3:
map.SetObjectFromCell(new Point(tmpX, tmpY), new Plant());
break;
case 4:
case 5:
map.SetObjectFromCell(new Point(tmpX, tmpY), new Rock());
break;
case 6:
case 7:
map.SetObjectFromCell(new Point(tmpX, tmpY), new Bush());
break;
case 8:
case 9:
map.SetObjectFromCell(new Point(tmpX, tmpY), new SpruceTree());
break;
case 10:
map.SetObjectFromCell(new Point(tmpX, tmpY), new Mushroom());
break;
}
count--;
}
while (true)
{
tmpX = rand.Next(width);
tmpY = rand.Next(height);
if (map.GetObjectFromCell(new Point(tmpX, tmpY)) != null)
continue;
map.AddMobileObject(new Dikabryozik(new Point(tmpX, tmpY)));
break;
}
}
示例5: GenerateRiver
private int[,] GenerateRiver(Map map)
{
var mapSize = map.GetSize();
int width = (int)mapSize.Width - 1;
int height = (int)mapSize.Height - 1;
var mapTmp = new int[mapSize.Width, mapSize.Height];
int river_length = 40;
int deep = 2;
var pointList = new List<Point>();
int tmpX, tmpY;
Random rand = new Random();
tmpX = rand.Next(width);
tmpY = rand.Next(height);
tmpX = tmpX <= 1 ? tmpX + 10 : tmpX >= width - 1 ? tmpX - 10 : tmpX;
tmpY = tmpY <= 1 ? tmpY + 10 : tmpY >= height - 1 ? tmpY - 10 : tmpY;
mapTmp[tmpX, tmpY] = deep;
pointList.Add(new Point(tmpX, tmpY));
var posibility = rand.Next(4);
tmpX = posibility == 0 ? tmpX - 1 : posibility == 1 ? tmpX + 1 : tmpX;
tmpY = posibility == 2 ? tmpY - 1 : posibility == 3 ? tmpY + 1 : tmpY;
mapTmp[tmpX, tmpY] = deep;
pointList.Add(new Point(tmpX, tmpY));
while (pointList.Count < river_length)
{
var currentListLength = pointList.Count;
var curPoint = pointList.First();
var firstPoint = AddDeepPointToRiver(curPoint, width, height, mapTmp, deep, rand);
if(!object.ReferenceEquals(firstPoint, null))
pointList.Insert(0, firstPoint);
curPoint = pointList.Last();
var lastPoint = AddDeepPointToRiver(curPoint, width, height, mapTmp, deep, rand);
if (!object.ReferenceEquals(lastPoint, null))
pointList.Add(lastPoint);
if(currentListLength == pointList.Count)
break;
}
while (pointList.Count > 0)
{
var curPoint = pointList.First();
pointList.RemoveAt(0);
var curDeepness = mapTmp[curPoint.X, curPoint.Y];
if(curDeepness <= 0)
continue;
for (int i = curPoint.X - 1; i <= curPoint.X + 1; i++)
{
for (int j = curPoint.Y - 1; j <= curPoint.Y + 1; j++)
{
if ((i == curPoint.X && j == curPoint.Y) || i < 0 || i > width || j < 0 || j > height
|| mapTmp[i, j] > 0)
continue;
var posibilityForDeepness = rand.Next(9);
var nextDeepness = posibilityForDeepness < 8 ? curDeepness - 1 : curDeepness;
if(nextDeepness <= 0)
continue;
mapTmp[i, j] = nextDeepness;
pointList.Add(new Point(i, j));
}
}
}
return mapTmp;
}