本文整理汇总了C#中Player.ClearBlockChange方法的典型用法代码示例。如果您正苦于以下问题:C# Player.ClearBlockChange方法的具体用法?C# Player.ClearBlockChange怎么用?C# Player.ClearBlockChange使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Player
的用法示例。
在下文中一共展示了Player.ClearBlockChange方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Use
public override void Use(Player p, params string[] args)
{
p.ClearBlockChange();
p.BlockChangeObject = args.Length > 0 ? byte.Parse(args[0]) : (byte)0;
p.OnBlockChange += Blockchange1;
p.SendMessage("Place/delete a block where you want the tree.");
//p.Blockchange += new Player.BlockchangeEventHandler(Blockchange1);
}
示例2: Blockchange1
void Blockchange1(Player p, int x, int y, int z, short type)
{
p.ClearBlockChange();
p.SendBlockChange(x, (byte)y, z, p.level.GetBlock(x, y, z), p.level.GetMeta(x, y, z));
p.SendMessage("Position: " + x + "," + y + "," + z);
p.SendMessage("Type: " + p.level.GetBlock(x, y, z));
p.SendMessage("Meta: " + p.level.GetMeta(x, y, z));
p.SendMessage("Extra: " + p.level.GetExtra(x, y, z));
}
示例3: Use
public override void Use(Player p, params string[] args)
{
if (args.Length < 1) { Help(p); return; }
byte meta = 0;
try { meta = byte.Parse(args[0]); }
catch { p.SendMessage("Invalid input."); return; }
if (meta < 0)
meta = 0;
else if (meta > 15)
meta = 15;
p.ClearBlockChange();
p.BlockChangeObject = meta;
p.OnBlockChange += Blockchange1;
p.SendMessage("Place/delete a block to change it's meta data.");
}
示例4: Blockchange1
void Blockchange1(Player p, int x, int y, int z, short type)
{
p.ClearBlockChange();
p.level.GrowTree(x, y, z, (byte)p.BlockChangeObject, Entity.randomJava);
}
示例5: Use
public override void Use(Player p, params string[] args)
{
p.ClearBlockChange();
p.OnBlockChange += Blockchange1;
p.SendMessage("Place/delete a block to get info.");
}
示例6: Use
public override void Use(Player p, params string[] args)
{
CuboidData cd; cd.x = 0; cd.y = 0; cd.z = 0;
cd.type = -1; cd.mode = CuboidType.Solid;
if (args.Length >= 2)
{
try { cd.type = Convert.ToInt16(args[0]); }
catch { cd.type = FindBlocks.FindBlock(args[0]); }
if (!FindBlocks.ValidBlock(cd.type)) { p.SendMessage("There is no block \"" + args[0] + "\"."); return; }
switch (args[1].ToLower())
{
case "hollow":
cd.mode = CuboidType.Hollow;
break;
case "walls":
cd.mode = CuboidType.Walls;
break;
case "holes":
cd.mode = CuboidType.Holes;
break;
case "wire":
cd.mode = CuboidType.Wire;
break;
case "random":
cd.mode = CuboidType.Random;
break;
}
}
else if (args.Length >= 1)
{
switch (args[0].ToLower())
{
case "hollow":
cd.mode = CuboidType.Hollow;
break;
case "walls":
cd.mode = CuboidType.Walls;
break;
case "holes":
cd.mode = CuboidType.Holes;
break;
case "wire":
cd.mode = CuboidType.Wire;
break;
case "random":
cd.mode = CuboidType.Random;
break;
}
if (cd.mode == CuboidType.Solid)
{
try { cd.type = Convert.ToInt16(args[0]); }
catch { cd.type = FindBlocks.FindBlock(args[0]); }
if (!FindBlocks.ValidBlock(cd.type)) { p.SendMessage("There is no block \"" + args[0] + "\"."); return; }
}
}
p.ClearBlockChange();
p.BlockChangeObject = cd;
p.OnBlockChange += Blockchange1;
p.SendMessage("Place/delete a block at 2 corners for the cuboid.");
//p.Blockchange += new Player.BlockchangeEventHandler(Blockchange1);
}
示例7: Blockchange2
void Blockchange2(Player p, int x, int y, int z, short type)
{
p.ClearBlockChange();
//p.SendMessage("tile: " + x + " " + y + " " + z + " " + type);
p.SendBlockChange(x, (byte)y, z, p.level.GetBlock(x, y, z), p.level.GetMeta(x, y, z));
CuboidData cd = (CuboidData)p.BlockChangeObject;
byte meta = (byte)p.inventory.current_item.meta;
if (cd.type != -1) type = cd.type;
if (!FindBlocks.ValidBlock(type)) type = 0;
int sx = Math.Min(cd.x, x);
int ex = Math.Max(cd.x, x);
int sy = Math.Min(cd.y, y);
int ey = Math.Max(cd.y, y);
int sz = Math.Min(cd.z, z);
int ez = Math.Max(cd.z, z);
int total = 0;
p.SendMessage("Cuboiding...");
switch (cd.mode)
{
case CuboidType.Solid:
for (int xx = sx; xx <= ex; xx++)
for (int yy = sy; yy <= ey; yy++)
for (int zz = sz; zz <= ez; zz++)
{
p.level.BlockChange(xx, yy, zz, (byte)type, meta, false);
total++;
}
break;
case CuboidType.Hollow:
for (int xx = sx; xx <= ex; xx++)
for (int zz = sz; zz <= ez; zz++)
{
p.level.BlockChange(xx, sy, zz, (byte)type, meta, false);
p.level.BlockChange(xx, ey, zz, (byte)type, meta, false);
total += 2;
}
for (int yy = sy; yy <= ey; yy++)
{
for (int xx = sx; xx <= ex; xx++)
{
p.level.BlockChange(xx, yy, sz, (byte)type, meta, false);
p.level.BlockChange(xx, yy, ez, (byte)type, meta, false);
total += 2;
}
for (int zz = sz; zz <= ez; zz++)
{
p.level.BlockChange(sx, yy, zz, (byte)type, meta, false);
p.level.BlockChange(ex, yy, zz, (byte)type, meta, false);
total += 2;
}
}
break;
case CuboidType.Walls:
for (int yy = sy; yy <= ey; yy++)
{
for (int xx = sx; xx <= ex; xx++)
{
p.level.BlockChange(xx, yy, sz, (byte)type, meta, false);
p.level.BlockChange(xx, yy, ez, (byte)type, meta, false);
total += 2;
}
for (int zz = sz; zz <= ez; zz++)
{
p.level.BlockChange(sx, yy, zz, (byte)type, meta, false);
p.level.BlockChange(ex, yy, zz, (byte)type, meta, false);
total += 2;
}
}
break;
case CuboidType.Holes:
bool Checked = true, startZ, startY;
for (int xx = sx; xx <= ex; xx++)
{
startY = Checked;
for (int yy = sy; yy <= ey; yy++)
{
startZ = Checked;
for (int zz = sz; zz <= ez; zz++)
{
Checked = !Checked;
if (Checked) { p.level.BlockChange(xx, yy, zz, (byte)type, meta, false); total++; }
}
Checked = !startZ;
}
Checked = !startY;
}
break;
case CuboidType.Wire:
for (int xx = sx; xx <= ex; xx++)
{
p.level.BlockChange(xx, sy, sz, (byte)type, meta, false);
p.level.BlockChange(xx, sy, ez, (byte)type, meta, false);
p.level.BlockChange(xx, ey, sz, (byte)type, meta, false);
p.level.BlockChange(xx, ey, ez, (byte)type, meta, false);
total += 4;
}
for (int yy = sy; yy <= ey; yy++)
{
//.........这里部分代码省略.........
示例8: Blockchange1
void Blockchange1(Player p, int x, int y, int z, short type)
{
p.ClearBlockChange();
//p.SendMessage("tile: " + x + " " + y + " " + z + " " + type);
p.SendBlockChange(x, (byte)y, z, p.level.GetBlock(x, y, z), p.level.GetMeta(x, y, z));
CuboidData cd = (CuboidData)p.BlockChangeObject;
cd.x = x; cd.y = y; cd.z = z;
p.BlockChangeObject = cd;
p.OnBlockChange += Blockchange2;
}
示例9: Blockchange1
void Blockchange1(Player p, int x, int y, int z, short type)
{
p.ClearBlockChange();
p.level.BlockChange(x, (byte)y, z, p.level.GetBlock(x, y, z), (byte)p.BlockChangeObject);
p.SendMessage("Metadata set!");
}
示例10: Use
public override void Use(Player p, params string[] args)
{
SpheroidData cd; cd.x = 0; cd.y = 0; cd.z = 0;
cd.type = -1; cd.vertical = false;
if (args.Length >= 2)
{
try { cd.type = Convert.ToInt16(args[0]); }
catch { cd.type = FindBlocks.FindBlock(args[0]); }
if (!FindBlocks.ValidBlock(cd.type)) { p.SendMessage("There is no block \"" + args[0] + "\"."); return; }
cd.vertical = (args[1].ToLower() == "vertical");
}
else if (args.Length >= 1)
{
cd.vertical = (args[0].ToLower() == "vertical");
if (!cd.vertical)
{
try { cd.type = Convert.ToInt16(args[0]); }
catch { cd.type = FindBlocks.FindBlock(args[0]); }
if (!FindBlocks.ValidBlock(cd.type)) { p.SendMessage("There is no block \"" + args[0] + "\"."); return; }
}
}
p.ClearBlockChange();
p.BlockChangeObject = cd;
p.OnBlockChange += Blockchange1;
p.SendMessage("Place/delete a block at 2 corners for the spheroid.");
}
示例11: Blockchange2
void Blockchange2(Player p, int x, int y, int z, short type)
{
p.ClearBlockChange();
//p.SendMessage("tile: " + x + " " + y + " " + z + " " + type);
p.SendBlockChange(x, (byte)y, z, p.level.GetBlock(x, y, z), p.level.GetMeta(x, y, z));
SpheroidData cd = (SpheroidData)p.BlockChangeObject;
byte meta = (byte)p.inventory.current_item.meta;
if (cd.type != -1) type = cd.type;
if (!FindBlocks.ValidBlock(type)) type = 0;
int sx = Math.Min(cd.x, x);
int ex = Math.Max(cd.x, x);
int sy = Math.Min(cd.y, y);
int ey = Math.Max(cd.y, y);
int sz = Math.Min(cd.z, z);
int ez = Math.Max(cd.z, z);
int total = 0;
p.SendMessage("Spheroiding...");
if (!cd.vertical)
{
// find center points
double cx = (ex + sx) / 2 + (((ex + sx) % 2 == 1) ? 0.5 : 0);
double cy = (ey + sy) / 2 + (((ey + sy) % 2 == 1) ? 0.5 : 0);
double cz = (ez + sz) / 2 + (((ez + sz) % 2 == 1) ? 0.5 : 0);
// find axis lengths
double rx = Convert.ToDouble(ex) - cx + 0.25;
double ry = Convert.ToDouble(ey) - cy + 0.25;
double rz = Convert.ToDouble(ez) - cz + 0.25;
double rx2 = 1 / (rx * rx);
double ry2 = 1 / (ry * ry);
double rz2 = 1 / (rz * rz);
//int totalBlocks = (int)(Math.PI * 0.75 * rx * ry * rz);
for (int xx = sx; xx <= ex; xx += 8)
for (int yy = sy; yy <= ey; yy += 8)
for (int zz = sz; zz <= ez; zz += 8)
for (int z3 = 0; z3 < 8 && zz + z3 <= ez; z3++)
for (int y3 = 0; y3 < 8 && yy + y3 <= ey; y3++)
for (int x3 = 0; x3 < 8 && xx + x3 <= ex; x3++)
{
// get relative coordinates
double dx = (xx + x3 - cx);
double dy = (yy + y3 - cy);
double dz = (zz + z3 - cz);
// test if it's inside ellipse
if ((dx * dx) * rx2 + (dy * dy) * ry2 + (dz * dz) * rz2 <= 1)
{
p.level.BlockChange(x3 + xx, yy + y3, zz + z3, (byte)type, meta, false);
total++;
}
}
}
else
{
// find center points
double cx = (ex + sx) / 2 + (((ex + sx) % 2 == 1) ? 0.5 : 0);
double cz = (ez + sz) / 2 + (((ez + sz) % 2 == 1) ? 0.5 : 0);
// find axis lengths
double rx = Convert.ToDouble(ex) - cx + 0.25;
double rz = Convert.ToDouble(ez) - cz + 0.25;
double rx2 = 1 / (rx * rx);
double rz2 = 1 / (rz * rz);
double smallrx2 = 1 / ((rx - 1) * (rx - 1));
double smallrz2 = 1 / ((rz - 1) * (rz - 1));
for (int xx = sx; xx <= ex; xx += 8)
for (int zz = sz; zz <= ez; zz += 8)
for (int z3 = 0; z3 < 8 && zz + z3 <= ez; z3++)
for (int x3 = 0; x3 < 8 && xx + x3 <= ex; x3++)
{
// get relative coordinates
double dx = (xx + x3 - cx);
double dz = (zz + z3 - cz);
// test if it's inside ellipse
if ((dx * dx) * rx2 + (dz * dz) * rz2 <= 1 && (dx * dx) * smallrx2 + (dz * dz) * smallrz2 > 1)
{
p.level.BlockChange(x3 + xx, sy, zz + z3, (byte)type, meta, false);
total++;
}
}
}
p.SendMessage(total + " blocks.");
}