Cle*_*ven 3 c# textures imagebrush winforms
我有一个纹理画笔,它使用某个图像来使纹理显示如下:
Image image = new Bitmap("Untitled.png");
for (int i = 0; i < points.Count; i++)
{
using (TextureBrush tbr = new TextureBrush(image))
{
tbr.RotateTransform(i * 4);
var p = PointToClient(Cursor.Position);
tbr.Transform = new Matrix(
75.0f / 640.0f,
0.0f,
0.0f,
75.0f / 480.0f,
0.0f,
0.0f);
e.Graphics.FillEllipse(tbr, p.X - 50, p.Y - 50, 100, 100);
Pen p3 = new Pen(tbr);
e.Graphics.DrawEllipse(Pens.DeepSkyBlue, p.X - 50, p.Y - 50, 100, 100);
}
}
Run Code Online (Sandbox Code Playgroud)
这是它正在使用的图像:
结果是这样的:
我希望图像填充圆圈,使其看起来像这样(编辑后的图像):
任何帮助,将不胜感激。
您需要使用正确的数字进行缩放。
如果你想要一个尺寸 = 宽度 * 高度像素的图像来填充一个直径的圆,你应该像这样缩放:
int diameter = 100;
Image image = new Bitmap(yourImage);
float scaleX = 1f * diameter / image.Size.Width;
float scaleY = 1f * diameter / image.Size.Height;
Run Code Online (Sandbox Code Playgroud)
但是请注意,您TextureBrush
将始终显示由您的图像制成的平铺。这对于您的原始问题似乎没问题,尤其是在旋转尾部的图像以消除任何伪影时。
但在这里它可能根本不是你想要的。
如果您希望图像跟随鼠标移动,则需要绘制它。
这是一个示例,它使用复选框在平铺和绘图之间切换。动画仅使用一帧:
for (int i = 0; i < points.Count; i++)
{
using (TextureBrush tbr = new TextureBrush(image))
{
tbr.RotateTransform(i * 4); // optional
var p = PointToClient(Cursor.Position);
tbr.Transform = new Matrix(
scaleX,
0.0f,
0.0f,
scaleY,
0.0f,
0.0f);
// any tile mode will work, though not all the same way
tbr.WrapMode = WrapMode.TileFlipXY;
if (cbx_tileFunny.Checked)
e.Graphics.FillEllipse(tbr, p.X - diameter/2,
p.Y - diameter/2, diameter, diameter);
else
{
((Bitmap)image).SetResolution(e.Graphics.DpiX, e.Graphics.DpiY); // (**)
e.Graphics.ScaleTransform(scaleX, scaleY);
e.Graphics.DrawImage( image, (p.X - diameter/2) / scaleX,
(p.Y - diameter/2 ) / scaleY);
e.Graphics.ResetTransform();
}
/// ? Pen p3 = new Pen(tbr);
e.Graphics.DrawEllipse(Pens.DeepSkyBlue, p.X - diameter/2,
p.Y - diameter/2, diameter, diameter);
}
}
Run Code Online (Sandbox Code Playgroud)
如果图像的 dpi 设置与您的屏幕不同,请注意此处所需的额外缩放 (**)。
另外:虽然快速创建和处理钢笔和画笔通常是一个好主意,但当投入大量精力创建画笔和/或图像时,缓存它们或什至是一系列它们似乎更可取,imo。