当前位置:萝卜系统下载站 > 技术开发教程 > 详细页面

第5章 Delphi图形图像编程(二)

第5章 Delphi图形图像编程(二)

更新时间:2022-07-13 文章作者:未知 信息来源:网络 阅读次数:

画直线时,用户只有在松开鼠标才能看见直线,对直线的变化不能进行实时观测。这是因为鼠标移动时程序没有进行某种应。Delphi定义了onMouseMove事件来响应鼠标移动。以下代码可使用户随时观测直线的变化: 
   procedure TForm1.FormMouseMove(Sender:Tobject)

  begin

  Drowto(X,Y);

  Moveto(origin);

  end. 

  origin是起始点。

  5.2.3 绘图功能的实现

  绘图软件常根据用户的要求改变绘图工具。Graphex.dpr例程中,当用户按下某个按钮时,可选择绘图工具中的画笔或画刷,在程序类型说明部分定义了五种绘图工具。

   type

  TDrawingTool = (dtLine,dtRectangle,dtEllips,dtRoundRect,dtPolygon); 

  当选中某种按钮,则选中了相应的绘图工具,如: 

  procedure TForm1.LineButtonClick(Sender: TObject);

  begin

  DrawingTool := dtLine;

  end; 

  procedure TForm1.RectangleButtonClick(Sender: TObject);

  begin

  DrawingTool := dtRectangle;

  end; 

  procedure TForm1.EllipseButtonClick(Sender: TObject);

  begin

  DrawingTool := dtEllipse;

  end; 

  procedure TForm1.RoundRectButtonClick(Sender: TObject);

  begin

  DrawingTool := dtRoundRect;

  end; 

  procedure TForm1.PolygonButtonClick(Sender: TObject);

  begin

  DrawingTool :=dtPolygon;

  end;  

  DrawShape过程定义了每种绘图工具的动作: 

  procedure TForm1.DrawShape(TopLeft, BottomRight: TPoint; AMode: TPenMode);

  begin

  with Image.Canvas do

  begin

  Pen.Mode := AMode;

  case DrawingTool of

  dtLine: begin

  MoveTo(TopLeft.X, TopLeft.Y);

  LineTo(BottomRight.X, BottomRight.Y);

  end;

  dtRectangle: Rectangle(TopLeft.X, TopLeft.Y, BottomRight.X, BottomRight.Y);

  dtEllipse: Ellipse(TopLeft.X, TopLeft.Y, BottomRight.X, BottomRight.Y);

  dtRoundRect: RoundRect(TopLeft.X, TopLeft.Y, BottomRight.X, BottomRight.Y,

  (TopLeft.X - BottomRight.X) div 2, (TopLeft.Y - BottomRight.Y) div 2);

  dtPolygon:Polygon([Point(0,0),TopLeft,BottomRight]); end;

  end;

  end; 

  程序刚运行时,只有一个工具栏。当用户单击画笔和画刷时,则出现相应的工具栏,如图5.4。其代码如下: 

  procedure TForm1.PenButtonClick(Sender: TObject);

  begin

  PenBar.Visible := PenButton.Down;

  end; 

  procedure TForm1.BrushButtonClick(Sender: TObject);

  begin

  BrushBar.Visible := BrushButton.Down;

  end;

   在设计绘图程序时,还要解决一些问题。如为了在鼠标移动时能观测图形的变化,我们定义了onMouseMove事件。但会出现这样的现象,当鼠标进入绘图区时,用户未按下鼠标键,画布上却出现绘制的图形,这是我们不希望看到的。其原因是没有对鼠标按钮是否按下进行判断。因此在窗体对象中定义了drawing的域,当鼠标按钮按下时,drawing 设置成真值。只有drawing为真,鼠标移动才执行绘图功能;当鼠标键松开时,drawing设置成假,鼠标移动将不执行绘图动作。

   另外一个问题是, 我们希望得到的是鼠标按钮按下和松开这两点所形成的图形,但onMouseMove却把鼠标轨迹上各点与起始点所形成的所有图形画在屏幕上,这同样是我们不希望看到的,为了解决这些问题,程序定义了鼠标的三个事件: 

  procedure TForm1.FormMouseDown(Sender: TObject; Button: TMouseButton;

  Shift: TShiftState; X, Y: Integer);

  begin

  Drawing := True;

  Image.Canvas.MoveTo(X, Y);

  Origin := Point(X, Y);

  MovePt := Origin;

  OriginPanel.Caption := Format('Origin: (%d, %d)', [X, Y]);

  end; 

  procedure TForm1.FormMouseUp(Sender: TObject; Button: TMouseButton;

  Shift: TShiftState; X, Y: Integer);

  begin

  if Drawing then

  DrawShape(Origin, Point(X, Y), pmCopy);

  Drawing := False;

  end; 

  procedure TForm1.FormMouseMove(Sender: TObject; Shift: TShiftState; X,

  Y: Integer);

  begin

  if Drawing then

  begin

  DrawShape(Origin, MovePt, pmNotXor);

  MovePt := Point(X, Y);

  DrawShape(Origin, MovePt, pmNotXor);

  end;  

  MovePt用来记录鼠标当前位置。当下次鼠标移动时, 就能在上次鼠标绘制的图形上画一个形状、大小一样的图形,并把画笔颜色设置成PmNotXor,使上次绘制的图形颜色变成了屏幕颜色,从而达到“橡皮擦”的效果。

[1] [2]  下一页

温馨提示:喜欢本站的话,请收藏一下本站!

本类教程下载

系统下载排行

网站地图xml | 网站地图html