本文整理汇总了C#中ImageData.ToBitmap方法的典型用法代码示例。如果您正苦于以下问题:C# ImageData.ToBitmap方法的具体用法?C# ImageData.ToBitmap怎么用?C# ImageData.ToBitmap使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ImageData
的用法示例。
在下文中一共展示了ImageData.ToBitmap方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: getTransformedBitmap
private Bitmap getTransformedBitmap()
{
if (srcH == 0 || srcW == 0) return null;
if (rect.Width < 800 && rect.Height < 600)
{
ImageData destCB = new ImageData();
destCB.A = new byte[rect.Width, rect.Height];
destCB.B = new byte[rect.Width, rect.Height];
destCB.G = new byte[rect.Width, rect.Height];
destCB.R = new byte[rect.Width, rect.Height];
PointF ptInPlane = new PointF();
int x1, x2, y1, y2;
double dab, dbc, dcd, dda;
float dx1, dx2, dy1, dy2, dx1y1, dx1y2, dx2y1, dx2y2, nbyte;
for (int y = 0; y < rect.Height; y++)
{
for (int x = 0; x < rect.Width; x++)
{
Point srcPt = new Point(x, y);
srcPt.Offset(this.rect.Location);
if (isOnPlaneABCD(srcPt))
{
dab = Math.Abs((new YLScsDrawing.Geometry.Vector(vertex[0], srcPt)).CrossProduct(AB));
dbc = Math.Abs((new YLScsDrawing.Geometry.Vector(vertex[1], srcPt)).CrossProduct(BC));
dcd = Math.Abs((new YLScsDrawing.Geometry.Vector(vertex[2], srcPt)).CrossProduct(CD));
dda = Math.Abs((new YLScsDrawing.Geometry.Vector(vertex[3], srcPt)).CrossProduct(DA));
ptInPlane.X = (float)(srcW * (dda / (dda + dbc)));
ptInPlane.Y = (float)(srcH * (dab / (dab + dcd)));
x1 = (int)ptInPlane.X;
y1 = (int)ptInPlane.Y;
if (x1 >= 0 && x1 < srcW && y1 >= 0 && y1 < srcH)
{
if (isBilinear)
{
x2 = (x1 == srcW - 1) ? x1 : x1 + 1;
y2 = (y1 == srcH - 1) ? y1 : y1 + 1;
dx1 = ptInPlane.X - (float)x1;
if (dx1 < 0) dx1 = 0;
dx1 = 1f - dx1;
dx2 = 1f - dx1;
dy1 = ptInPlane.Y - (float)y1;
if (dy1 < 0) dy1 = 0;
dy1 = 1f - dy1;
dy2 = 1f - dy1;
dx1y1 = dx1 * dy1;
dx1y2 = dx1 * dy2;
dx2y1 = dx2 * dy1;
dx2y2 = dx2 * dy2;
nbyte = srcCB.A[x1, y1] * dx1y1 + srcCB.A[x2, y1] * dx2y1 + srcCB.A[x1, y2] * dx1y2 + srcCB.A[x2, y2] * dx2y2;
destCB.A[x, y] = (byte)nbyte;
nbyte = srcCB.B[x1, y1] * dx1y1 + srcCB.B[x2, y1] * dx2y1 + srcCB.B[x1, y2] * dx1y2 + srcCB.B[x2, y2] * dx2y2;
destCB.B[x, y] = (byte)nbyte;
nbyte = srcCB.G[x1, y1] * dx1y1 + srcCB.G[x2, y1] * dx2y1 + srcCB.G[x1, y2] * dx1y2 + srcCB.G[x2, y2] * dx2y2;
destCB.G[x, y] = (byte)nbyte;
nbyte = srcCB.R[x1, y1] * dx1y1 + srcCB.R[x2, y1] * dx2y1 + srcCB.R[x1, y2] * dx1y2 + srcCB.R[x2, y2] * dx2y2;
destCB.R[x, y] = (byte)nbyte;
}
else
{
destCB.A[x, y] = srcCB.A[x1, y1];
destCB.B[x, y] = srcCB.B[x1, y1];
destCB.G[x, y] = srcCB.G[x1, y1];
destCB.R[x, y] = srcCB.R[x1, y1];
}
}
}
}
}
return destCB.ToBitmap();
}
else
{
return error;
}
}