本文整理汇总了C#中ISurface.GetSurface方法的典型用法代码示例。如果您正苦于以下问题:C# ISurface.GetSurface方法的具体用法?C# ISurface.GetSurface怎么用?C# ISurface.GetSurface使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ISurface
的用法示例。
在下文中一共展示了ISurface.GetSurface方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ConvertLandSurface
private static unsafe void ConvertLandSurface(ISurface surface, out byte[] rawdata)
{
if (surface.Stride / surface.Width != 2)
throw new NotImplementedException();
var bitmap = surface.GetSurface();// as BitmapSurface;
var imrect = bitmap.GetImageRect();
var imavrx = bitmap.Width / 2;
var imlenx = Math.Min(Math.Max(imavrx - imrect.X1, imrect.X2 + 1 - imavrx), imavrx);
imrect = new Clipper2D((short)(imavrx - imlenx), imrect.Y1, (short)(imavrx + imlenx - 1), (short)(bitmap.Height - 1));
if (imrect.Width != 44 || imrect.Height != 44) {
imrect = new Clipper2D((short)0, (short)0, (ushort)bitmap.Width, (ushort)bitmap.Height);
if (imrect.Width != 44 || imrect.Height != 44)
throw new ClassicFactoryException();
}
rawdata = new byte[0x07E8];
lock (surface) {
uint delta = surface.Stride >> 1;
ushort* line1 = surface.ImageWordPtr + imrect.Y1 * delta + imrect.X1;
ushort* line2 = surface.ImageWordPtr + imrect.Y2 * delta + imrect.X1;
fixed (byte* _data = &rawdata[0]) {
var data = (uint*)_data;
//data[0] = 0x00000000; // header
var i1 = 0;
var i2 = 505;
for (var y = 0; y < 22; ++y, line1 += delta, line2 -= delta) {
var cur1 = (uint*)(line1 + 21 - y);
var cur2 = (uint*)(line2 + 21 + y);
for (var x = 0; x <= y; ++x, ++i1, --i2, ++cur1, --cur2) {
data[i1] = *cur1 ^ 0x80008000;
data[i2] = *cur2 ^ 0x80008000;
}
}
}
}
}
示例2: ConvertItemSurface
private static unsafe void ConvertItemSurface(ISurface surface, out byte[] rawdata)
{
if (surface.Stride / surface.Width != 2)
throw new NotImplementedException();
var bitmap = surface.GetSurface();// as BitmapSurface;
var imrect = bitmap.GetImageRect();
var imavrx = bitmap.Width / 2;
var imlenx = Math.Min(Math.Max(imavrx - imrect.X1, imrect.X2 + 1 - imavrx), imavrx);
imrect = new Clipper2D((short)(imavrx - imlenx), imrect.Y1, (short)(imavrx + imlenx - 1), (short)(bitmap.Height - 1));
var data = new BinaryWriter(new MemoryStream());
data.Write((uint)1234); // header
data.Write((ushort)imrect.Width);
data.Write((ushort)imrect.Height);
var lookup = (int)data.BaseStream.Position;
for (var y = 0; y < imrect.Height; ++y)// fill lookup
data.Write((ushort)0);
lock (surface) {
uint delta = surface.Stride >> 1;
ushort* line = surface.ImageWordPtr + imrect.Y1 * delta;
for (int y = 0; y < imrect.Height; ++y, line += delta) {
data.BaseStream.Seek(lookup + (y << 1), SeekOrigin.Begin);
var lineoffs = ((data.BaseStream.Length - lookup) >> 1) - imrect.Height;
if (lineoffs > 0xFFFF)
throw new ClassicFactoryException();
data.Write( (ushort)lineoffs );
data.BaseStream.Seek(0, SeekOrigin.End);
ushort* cur = line + imrect.X1;
int x = 0, j = 0, i = 0;
while (i < imrect.Width) {
for (i = x; i < imrect.Width; ++i) {
//first pixel set
if (cur[i] != 0)
break;
}
if (i < imrect.Width) {
for (j = (i + 1); j < imrect.Width; ++j) {
//next non set pixel
// if (cur[j] == 0)
if (cur[j] == 0 && (j + 1 == imrect.Width || cur[j + 1] == 0))
break;
}
data.Write((ushort)(i - x)); //xoffset
data.Write((ushort)(j - i)); //run
for (int p = i; p < j; ++p)
//data.Write((ushort)(cur[p] ^ 0x8000);
data.Write((ushort)(cur[p] > 0 ? (cur[p] ^ 0x8000) : cur[p]));
x = j;
}
}
data.Write((ushort)0); //xOffset
data.Write((ushort)0); //Run
}
}
data.Flush();
rawdata = (data.BaseStream as MemoryStream).ToArray();
data.Close();
}
示例3: Render
private void Render(int cmd)
{
if (UOManager == null) {
MessageBox.Show("Enter client path and load client mul files to be able to draw facet.");
return;
}
var flt = cmd < 20;
//if (flt)
// cmd -= 10;
//else
// cmd -= 20;
var _cmdlast = flt ? 10 : 20;
if (cmdlast != _cmdlast ) {
avrg_ticks = avrg_draws = 0;
cmdlast = _cmdlast ;
}
switch (cmd) {
case 17: goto case 28;
case 13: goto case 22;
case 19: goto case 26;
case 11: goto case 24;
case 18: goto case 29;
case 12: goto case 21;
case 14: goto case 27;
case 16: goto case 23;
case 27: nudX.Value -= 1; break;
case 23: nudX.Value += 1; break;
case 29: nudY.Value -= 1; break;
case 21: nudY.Value += 1; break;
case 28: nudX.Value -= 1; nudY.Value -= 1; break;
case 22: nudX.Value += 1; nudY.Value += 1; break;
case 24: nudX.Value -= 1; nudY.Value += 1; break;
case 26: nudX.Value += 1; nudY.Value -= 1; break;
default: break;
}
if (nudX.Value < nudX.Minimum)
nudX.Value = nudX.Minimum;
if (nudY.Value < nudY.Minimum)
nudY.Value = nudY.Minimum;
if (nudX.Value > nudX.Maximum)
nudX.Value = nudX.Maximum;
if (nudY.Value > nudY.Maximum)
nudY.Value = nudY.Maximum;
var surw = (ushort)nudW.Value;
var surh = (ushort)nudH.Value;
var map = (byte)nudM.Value;
var range = (byte)nudR.Value;
var tcx = (ushort)nudX.Value;
var tcy = (ushort)nudY.Value;
var minz = (sbyte)nudMinZ.Value;
var maxz = (sbyte)nudMaxZ.Value;
var alt = (short)nudS.Value;
surf = UOManager.CreateSurface(surw, surh, PixelFormat.Bpp16X1R5G5B5);
var ticks = Environment.TickCount;
if (flt)
UOManager.FacetRender.DrawFlatMap(map, alt, ref surf, range, tcx, tcy, minz, maxz);
else
UOManager.FacetRender.DrawObliqueMap(map, alt, ref surf, range, tcx, tcy, minz, maxz);
var take_ticks = Environment.TickCount - ticks;
avrg_ticks += take_ticks;
++avrg_draws;
lblStatus.Content = String.Format("Draw in: {0:00000} ms / Avrg: {1:00000}ms", take_ticks, avrg_ticks / avrg_draws);
//var bid = UOManager.GetMapFacet(map).GetBlockId((uint)nudX.Value, (uint)nudY.Value);
//UOManager.FacetRender.DrawBlock(ref surf, map, bid);
imgFacet.Source = surf.GetSurface().Image;
}