我对Graphics对象有疑问。我想绘制一个像MS paint一样的连续线。我不知道如何实现这样的事情。我知道如何从鼠标位置开始一行。这是我在一个图片框上添加新点(e.X,e.Y)。另一条线不能相同,否则就没有线可见。我无法制作另一个Point(10,10)或类似的东西。因为它会始终从同一点创建一条线。
有谁知道如何绘制连续的线条(带曲线)
是否与mouse_down和mouse_up事件有关?我很长时间都坚持这个问题。如果你们中的任何一个人都有时间向我解释可行的方法,那就太棒了!
提前致谢!
答案 0 :(得分:3)
我刚为您实施了简单的涂料。只需创建一个新项目并将下面的代码复制到Form1.cs文件中。代码中的注释应该解释它是如何工作的。
public partial class Form1 : Form
{
private Bitmap bmp; // Place to store our drawings
private List<Point> points; // Points of currently drawing line
private Pen pen; // Pen we will use to draw
public Form1()
{
InitializeComponent();
DoubleBuffered = true; // To avoid flickering effect
bmp = new Bitmap(640, 480); // This is our canvas that will store drawn lines
using (Graphics g = Graphics.FromImage(bmp))
g.Clear(Color.White); // Let's make it white, like paper
points = new List<Point>(); // Here we will remember the whole path
pen = new Pen(Color.Black);
MouseDown += OnMouseDown; // Start drawing
MouseMove += OnMouseMove; // Drawing...
MouseUp += OnMouseUp; // Stop drawing
Paint += OnPaint; // Show the drawing
}
void OnPaint(object sender, PaintEventArgs e)
{
e.Graphics.DrawImage(bmp, 0, 0); // Show what is drawn
if (points.Count > 0)
e.Graphics.DrawLines(pen, points.ToArray()); // Show what is currently being drawn
}
void OnMouseDown(object sender, MouseEventArgs e)
{
if (e.Button != MouseButtons.Left)
return;
points.Clear();
points.Add(e.Location); // Remember the first point
}
void OnMouseMove(object sender, MouseEventArgs e)
{
if (e.Button != MouseButtons.Left)
return;
points.Add(e.Location); // Add points to path
Invalidate(); // Force to repaint
}
void OnMouseUp(object sender, MouseEventArgs e)
{
if (e.Button != MouseButtons.Left)
return;
SaveToBitmap(); // Save the drawn line to bitmap
points.Clear(); // Our drawing is saved, we can clear the list of points
}
private void SaveToBitmap()
{
if (points.Count == 0)
return;
using (Graphics g = Graphics.FromImage(bmp))
g.DrawLines(pen, points.ToArray()); // Just draw current line on bitmap
}
}
结果:
答案 1 :(得分:0)
概括地说:
MouseDown
上,捕获鼠标并存储当前位置。此位置是您的初始Point
值。MouseMove
上,将当前位置添加到您的积分列表中。MouseUp
上,根据需要完成曲线,停止捕捉鼠标。渲染时,将Point
值列表转换为数组并将其传递给Graphics.DrawLines()
方法。作为可能的优化,一旦用户完成绘图,将列表永久转换为数组。或者,使用Bitmap
实例作为渲染缓存。
请注意,您可以配置用于绘制线条的Pen
对象以应用特殊效果,例如端盖和斜接接头。
要绘制曲线,请改用Graphics.DrawBeziers()
方法。请注意,在这种情况下,鼠标事件期间捕获的点应该是传递给方法的数组中的每三个点。每个点之间的两点是每条曲线的控制点。
您应该从DrawLines()
开始,因为它更简单。一旦你有了很好的工作,那么你可以用DrawBeziers()
方法使你的生活复杂化。至少,您必须自动计算默认控制点以与该方法一起使用。优选地,您将为用户提供编辑控制点的方法,以便他们可以自定义曲线。