本文整理汇总了C#中Level.PosToInt方法的典型用法代码示例。如果您正苦于以下问题:C# Level.PosToInt方法的具体用法?C# Level.PosToInt怎么用?C# Level.PosToInt使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Level
的用法示例。
在下文中一共展示了Level.PosToInt方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: DoGeyser
public static void DoGeyser(Level lvl, Check C, Random rand) {
C.time++;
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
byte below = lvl.GetTile(x, (ushort)(y - 1), z);
if (below == Block.air) {
lvl.AddUpdate(lvl.PosToInt(x, (ushort)(y - 1), z), Block.geyser);
} else if (below != Block.geyser) {
byte block = lvl.blocks[C.b];
lvl.PhysWater(lvl.PosToInt((ushort)(x + 1), y, z), block);
lvl.PhysWater(lvl.PosToInt((ushort)(x - 1), y, z), block);
lvl.PhysWater(lvl.PosToInt(x, y, (ushort)(z + 1)), block);
lvl.PhysWater(lvl.PosToInt(x, y, (ushort)(z - 1)), block);
}
if (lvl.physics <= 1 || C.time <= 10) return;
C.time = 0;
bool flowUp = false;
GeyserFlow(lvl, x - 1, y, z, ref flowUp);
GeyserFlow(lvl, x + 1, y, z, ref flowUp);
GeyserFlow(lvl, x, y - 1, z, ref flowUp);
GeyserFlow(lvl, x, y, z - 1, ref flowUp);
GeyserFlow(lvl, x, y, z + 1, ref flowUp);
if (flowUp)
GeyserFlow(lvl, x, y + 1, z, ref flowUp);
}
示例2: DoWaterOrLava
public unsafe static void DoWaterOrLava(Level lvl, Check C, Random rand) {
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
byte tileBelow = lvl.GetTile(x, (ushort)(y - 1), z);
if (tileBelow == Block.air) {
lvl.AddUpdate(lvl.PosToInt(x, (ushort)(y - 1), z), lvl.blocks[C.b], false, C.extraInfo);
lvl.AddUpdate(C.b, Block.air);
C.extraInfo = "";
} else if (tileBelow == Block.waterstill || tileBelow == Block.lavastill) {
lvl.AddUpdate(C.b, Block.air);
C.extraInfo = "";
} else {
const int count = 25;
int* indices = stackalloc int[count];
for (int i = 0; i < count; ++i)
indices[i] = i;
for (int k = count - 1; k > 1; --k) {
int randIndx = rand.Next(k);
int temp = indices[k];
indices[k] = indices[randIndx]; // move random num to end of list.
indices[randIndx] = temp;
}
for (int j = 0; j < count; j++) {
int i = indices[j];
ushort posX = (ushort)(x + (i / 5) - 2);
ushort posZ = (ushort)(z + (i % 5) - 2);
if (lvl.GetTile(posX, (ushort)(y - 1), posZ) == Block.air &&
lvl.GetTile(posX, y, posZ) == Block.air)
{
if (posX < x)
posX = (ushort)(Math.Floor((double)(posX + x) / 2));
else
posX = (ushort)(Math.Ceiling((double)(posX + x) / 2));
if (posZ < z)
posZ = (ushort)(Math.Floor((double)(posZ + z) / 2));
else
posZ = (ushort)(Math.Ceiling((double)(posZ + z) / 2));
int index = lvl.PosToInt(posX, y, posZ);
if (index >= 0 && lvl.blocks[index] == Block.air &&
lvl.AddUpdate(index, lvl.blocks[C.b], false, C.extraInfo))
{
lvl.AddUpdate(C.b, Block.air);
C.extraInfo = "";
return;
}
}
}
}
}
示例3: ExpandDiagonal
static void ExpandDiagonal(Level lvl, ushort x, ushort y, ushort z,
int xOffset, int yOffset, int zOffset) {
if (!Block.FireKill(lvl.GetTile((ushort)(x + xOffset),
(ushort)(y + yOffset), (ushort)(z + zOffset))))
return;
if (xOffset != 0)
lvl.AddUpdate(lvl.PosToInt((ushort)(x + xOffset), y, z), Block.fire);
if (yOffset != 0)
lvl.AddUpdate(lvl.PosToInt(x, (ushort)(y + yOffset), z), Block.fire);
if (zOffset != 0)
lvl.AddUpdate(lvl.PosToInt(x, y, (ushort)(z + zOffset)), Block.fire);
}
示例4: DoFlood
public static void DoFlood(Level lvl, Check C, Random rand, AirFlood mode, byte block) {
if (C.time >= 1) {
lvl.AddUpdate(C.b, 0);
C.time = 255; return;
}
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
FloodAir(lvl, lvl.PosToInt((ushort)(x + 1), y, z), block);
FloodAir(lvl, lvl.PosToInt((ushort)(x - 1), y, z), block);
FloodAir(lvl, lvl.PosToInt(x, y, (ushort)(z + 1)), block);
FloodAir(lvl, lvl.PosToInt(x, y, (ushort)(z - 1)), block);
switch (mode) {
case AirFlood.Full:
FloodAir(lvl, lvl.PosToInt(x, (ushort)(y - 1), z), block);
FloodAir(lvl, lvl.PosToInt(x, (ushort)(y + 1), z), block);
break;
case AirFlood.Layer:
break;
case AirFlood.Down:
FloodAir(lvl, lvl.PosToInt(x, (ushort)(y - 1), z), block);
break;
case AirFlood.Up:
FloodAir(lvl, lvl.PosToInt(x, (ushort)(y + 1), z), block);
break;
}
C.time++;
}
示例5: MagmaFlow
static void MagmaFlow(Level lvl, int x, int y, int z, ref bool flowUp) {
int index = lvl.PosToInt((ushort)x, (ushort)y, (ushort)z);
if (index >= 0 && Block.LavaKill(lvl.blocks[index])) {
lvl.AddUpdate(index, Block.magma);
flowUp = true;
}
}
示例6: Do
public static void Do(Level lvl, Check C, Random rand) {
int dirX = rand.Next(1, 10) <= 5 ? 1 : -1;
int dirY = rand.Next(1, 10) <= 5 ? 1 : -1;
int dirZ = rand.Next(1, 10) <= 5 ? 1 : -1;
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
for (int cx = -dirX; cx != 2 * dirX; cx += dirX)
for (int cy = -dirY; cy != 2 * dirY; cy += dirY)
for (int cz = -dirZ; cz != 2 * dirZ; cz += dirZ)
{
byte tileBelow = lvl.GetTile((ushort)(x + cx),(ushort)(y + cy - 1), (ushort)(z + cz));
byte tile = lvl.GetTile((ushort)(x + cx),(ushort)(y + cy), (ushort)(z + cz));
if ((tileBelow == Block.red || tileBelow == Block.op_air) &&
(tile == Block.air || tile == Block.water)) {
lvl.AddUpdate(lvl.PosToInt((ushort)(x + cx),
(ushort)(y + cy), (ushort)(z + cz)), Block.train);
lvl.AddUpdate(C.b, Block.air);
byte newBlock = tileBelow == Block.red ? Block.obsidian : Block.glass;
lvl.AddUpdate(lvl.IntOffset(C.b, 0, -1, 0), newBlock, true,
"wait 5 revert " + tileBelow.ToString());
return;
}
}
}
示例7: Do
public static void Do(Level lvl, Check C, Random rand) {
int dirX = rand.Next(1, 10) <= 5 ? 1 : -1;
int dirY = rand.Next(1, 10) <= 5 ? 1 : -1;
int dirZ = rand.Next(1, 10) <= 5 ? 1 : -1;
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
for (int cx = -dirX; cx != 2 * dirX; cx += dirX)
for (int cy = -dirY; cy != 2 * dirY; cy += dirY)
for (int cz = -dirZ; cz != 2 * dirZ; cz += dirZ)
{
byte rocketTail = lvl.GetTile((ushort)(x + cx), (ushort)(y + cy), (ushort)(z + cz));
if (rocketTail != Block.fire) continue;
int headIndex = lvl.PosToInt((ushort)(x - cx), (ushort)(y - cy), (ushort)(z - cz));
byte rocketHead = headIndex < 0 ? Block.Zero : lvl.blocks[headIndex];
bool unblocked = !lvl.ListUpdate.Exists(u => u.b == headIndex || u.b == C.b);
if (unblocked && (rocketHead == Block.air || rocketHead == Block.rocketstart)) {
lvl.AddUpdate(headIndex, Block.rockethead);
lvl.AddUpdate(C.b, Block.fire);
} else if (rocketHead == Block.fire) {
} else {
if (lvl.physics > 2)
lvl.MakeExplosion(x, y, z, 2);
else
lvl.AddUpdate(C.b, Block.fire);
}
}
}
示例8: Do
public static void Do(Level lvl, Check C, Random rand) {
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
if (lvl.GetTile(x, (ushort)(y - 1), z) != Block.lavastill)
return;
if (lvl.GetTile(x, (ushort)(y + 1), z) == Block.air) {
bool keepGoing = true;
if ((lvl.Height * 80 / 100) < y)
keepGoing = rand.Next(1, 20) > 1;
if (keepGoing) {
int bAbove = lvl.PosToInt(x, (ushort)(y + 1), z);
bool unblocked = !lvl.ListUpdate.Exists(u => u.b == bAbove);
if (unblocked) {
lvl.AddUpdate(bAbove, Block.firework, false);
lvl.AddUpdate(C.b, Block.lavastill, false, "wait 1 dissipate 100");
C.extraInfo = "wait 1 dissipate 100";
return;
}
}
}
Firework(x, y, z, 4, lvl, rand);
}
示例9: ExpandSimple
static bool ExpandSimple(Level lvl, int x, int y, int z) {
int index = lvl.PosToInt((ushort)x, (ushort)y, (ushort)z);
if (index < 0 || lvl.blocks[index] != Block.air) return false;
lvl.AddUpdate(index, Block.fire);
return true;
}
示例10: Expand
static bool Expand(Level lvl, int x, int y, int z) {
int index = lvl.PosToInt((ushort)x, (ushort)y, (ushort)z);
if (index >= 0 && lvl.blocks[index] == Block.air &&
lvl.AddUpdate(index, Block.finiteWater)) {
return true;
}
return false;
}
示例11: Firework
static void Firework(ushort x, ushort y, ushort z, int size, Level lvl, Random rand) {
if (lvl.physics < 1 || lvl.physics == 5) return;
int rand1 = rand.Next(Block.red, Block.white);
int rand2 = rand.Next(Block.red, Block.white);
int min = Math.Min(rand1, rand2), max = Math.Max(rand1, rand2);
// Not using override, since override = true makes it more likely that a colored block will be
// generated with no extraInfo, because it sets a Check for that position with no extraInfo.
lvl.AddUpdate(lvl.PosToInt(x, y, z), Block.air);
for (ushort yy = (ushort)(y - (size + 1)); yy <= (ushort)(y + (size + 1)); ++yy)
for (ushort zz = (ushort)(z - (size + 1)); zz <= (ushort)(z + (size + 1)); ++zz)
for (ushort xx = (ushort)(x - (size + 1)); xx <= (ushort)(x + (size + 1)); ++xx)
{
if (lvl.GetTile(xx, yy, zz) == Block.air && rand.Next(1, 40) < 2)
lvl.AddUpdate(lvl.PosToInt(xx, yy, zz), (byte)rand.Next(min, max),
false, "drop 100 dissipate 25");
}
}
示例12: ExpandAvanced
static void ExpandAvanced(Level lvl, int x, int y, int z) {
int index = lvl.PosToInt((ushort)x, (ushort)y, (ushort)z);
if (index < 0) return;
byte block = lvl.blocks[index];
if (Block.FireKill(block))
lvl.AddUpdate(index, Block.fire);
else if (block == Block.tnt)
lvl.MakeExplosion((ushort)x, (ushort)y, (ushort)z, -1);
}
示例13: DoKiller
public static void DoKiller(Level lvl, Check C, Random rand, byte target) {
Player closest = AIPhysics.ClosestPlayer(lvl, C);
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
if (closest != null && rand.Next(1, 20) < 19) {
int index = 0, dirsVisited = 0;
switch (rand.Next(1, 10)) {
case 1:
case 2:
case 3:
if ((closest.pos[0] / 32) - x != 0) {
index = lvl.PosToInt((ushort)(x + Math.Sign((closest.pos[0] / 32) - x)), y, z);
if (MoveFish(lvl, C, index, target)) return;
}
dirsVisited++;
if (dirsVisited >= 3) break;
goto case 4;
case 4:
case 5:
case 6:
if ((closest.pos[1] / 32) - y != 0) {
index = lvl.PosToInt(x, (ushort)(y + Math.Sign((closest.pos[1] / 32) - y)), z);
if (MoveFish(lvl, C, index, target)) return;
}
dirsVisited++;
if (dirsVisited >= 3) break;
goto case 7;
case 7:
case 8:
case 9:
if ((closest.pos[2] / 32) - z != 0) {
index = lvl.PosToInt(x, y, (ushort)(z + Math.Sign((closest.pos[2] / 32) - z)));
if (MoveFish(lvl, C, index, target)) return;
}
dirsVisited++;
if (dirsVisited >= 3) break;
goto case 1;
}
}
RandomlyMove(lvl, C, rand, x, y, z, target);
}
示例14: Do
public static void Do(Level lvl, Check C, Random rand) {
ushort x, y, z;
lvl.IntToPos(C.b, out x, out y, out z);
switch (rand.Next(1, 15)) {
case 1:
if (lvl.GetTile(x, (ushort)(y - 1), z) == Block.air)
lvl.AddUpdate(lvl.PosToInt(x, (ushort)(y - 1), z), lvl.blocks[C.b]);
else goto case 3;
break;
case 2:
if (lvl.GetTile(x, (ushort)(y + 1), z) == Block.air)
lvl.AddUpdate(lvl.PosToInt(x, (ushort)(y + 1), z), lvl.blocks[C.b]);
else goto case 6;
break;
case 3:
case 4:
case 5:
FlyTo(lvl, C, x - 1, y, z);
break;
case 6:
case 7:
case 8:
FlyTo(lvl, C, x + 1, y, z);
break;
case 9:
case 10:
case 11:
FlyTo(lvl, C, x, y, z - 1);
break;
default:
FlyTo(lvl, C, x, y, z + 1);
break;
}
lvl.AddUpdate(C.b, Block.air);
C.time = 255;
}
示例15: Load
public Level Load(string levelName, string path)
{
Level finalLevel = new Level(new Vector3S(32, 32, 32));
finalLevel.Name = levelName;
using (FileStream fs = File.OpenRead(path)) {
using (GZipStream gs = new GZipStream(fs, CompressionMode.Decompress)) {
byte[] ver = new byte[2];
gs.Read(ver, 0, ver.Length);
ushort version = BitConverter.ToUInt16(ver, 0);
//if (version != 1874) //Is a old MCForge level!
// throw new Exception(path + " is not a valid MCForge Level");
// Older levels WILL STILL WORK WITH THIS so you don't need this check. .dat files won't load though.
ushort[] vars = new ushort[6];
byte[] rot = new byte[2];
byte[] header = new byte[16];
gs.Read(header, 0, header.Length);
vars[0] = BitConverter.ToUInt16(header, 0); //X
vars[1] = BitConverter.ToUInt16(header, 2); //Z
vars[2] = BitConverter.ToUInt16(header, 4); //Y
vars[3] = BitConverter.ToUInt16(header, 6); //SpawnX
vars[4] = BitConverter.ToUInt16(header, 8); //SpawnZ
vars[5] = BitConverter.ToUInt16(header, 10); //SpawnY
rot[0] = header[12]; //SpawnHeading
rot[1] = header[13]; //SpawnYaw
finalLevel.CWMap.Size = new Vector3S((short)vars[0], (short)vars[1], (short)vars[2]);
finalLevel.CWMap.SpawnPos = new Vector3S((short)vars[3], (short)vars[4], (short)vars[5]);
finalLevel.CWMap.SpawnRotation = new Vector2S(rot[0], rot[1]);
finalLevel.TotalBlocks = finalLevel.CWMap.Size.x * finalLevel.CWMap.Size.z * finalLevel.CWMap.Size.y;
byte[] blocks = new byte[finalLevel.CWMap.Size.x * finalLevel.CWMap.Size.z * finalLevel.CWMap.Size.y];
gs.Read(blocks, 0, blocks.Length);
finalLevel.CWMap.BlockData = new byte[finalLevel.TotalBlocks];
for (int x = 0; x < finalLevel.CWMap.Size.x; x++)
for (int y = 0; y < finalLevel.CWMap.Size.y; y++)
for (int z = 0; z < finalLevel.CWMap.Size.z; z++)
finalLevel.SetBlock(x, z, y, (byte)OldMCForgeToNewMCForge.Convert(blocks[finalLevel.PosToInt((ushort)x, (ushort)z, (ushort)y)])); //Converts all custom blocks to normal blocks.
}
}
finalLevel.HandleMetaData();
Logger.Log("[Level] " + levelName + " was loaded");
return finalLevel;
}