绘图多边形(愿意出300分)(300分)

  • 主题发起人 主题发起人 hikehilter
  • 开始时间 开始时间
H

hikehilter

Unregistered / Unconfirmed
GUEST, unregistred user!
我想在一个image上绘制多个多边形,然后把每个多边形绘制的点存入数据库,
能够在下次调入的时候,自动生成多边形,并且能在鼠标移到多边形上的时候
能像DreamWare上的热区一样.最好能提供完整源码.(包括用鼠标绘制多边形操作的过程
其中的mousedown,mouseup,mousemove等事件.)
如果网友回答我的问题,希望能给出完整的.
 
用矢量图好了,没有必要用数据库的如果一定要用的话,
那么你可以买一本关于多媒体编程的书,都介绍了,关于热点区域的问题,参看hikihilter
的提问中的回答,其实好多的书上都有介绍了,
 
是处理地图信息吗?
 
这个可以这样去做。将所存入的点保存到一个动态数组中。再去创建这个多边形区域。
用到的API有
创建多边形区域
SelectObject
判断光标是否在区域中
 
数组里比较好,可以用createpoly
 
TPolyline可以满足您的要求。
http://www.codeidea.com
 
用API函数CreatePolyRgn就可以搞定

下边给个例子, 该窗体中有一个image4, 和三个按钮。其它没有
unit PolygonRgn;
interface

uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
StdCtrls, ExtCtrls;

type
TFormPolygon = class(TForm)
Button1: TButton;
Button2: TButton;
Button3: TButton;
Image4: TImage;
procedure Button1Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure FormMouseMove(Sender: TObject; Shift: TShiftState; X,
Y: Integer);
procedure Image4MouseMove(Sender: TObject; Shift: TShiftState; X,
Y: Integer);
private
{ Private declarations }
public
{ Public declarations }
myPolygonRgn:hrgn;
end;

var
FormPolygon: TFormPolygon;

implementation

{$R *.DFM}

procedure TFormPolygon.Button1Click(Sender: TObject);
var
i:integer;
type
PPoints = ^TPoints;
TPoints = array[0..0] of TPoint;
TP = array of TPoint;

var
P: PPoints;
pary: TP;

function CreatePolyRgn(var Points: TP): HRgn;
type
PPoints = ^TPoints;
TPoints = array[0..0] of TPoint;
begin
Result := CreatePolygonRgn(PPoints(Points)^, High(Points) + 1, WINDING);
end;

begin
Image4.canvas.brush.color:=clred;
setlength(pary,100);
pary[0]:=point(20,10);
pary[1]:=point(180,30);
pary[2]:=point(180,180);
pary[3]:=point(0,180);
pary[4]:=point(120,180);
pary[5]:=point(55,130);
try
myPolygonRgn:=CreatePolyRgn(Pary);
if myPolygonRgn<>0 then
fillrgn(Image4.canvas.handle,myPolygonRgn,Image4.canvas.brush.handle)
else
showmessage('invalid region');
finally
// deleteobject(myPolygonRgn);
end;
end;



procedure TFormPolygon.Button2Click(Sender: TObject);
var pary:array of tpoint;
i:integer;
myPolygonRgn:hrgn;
type
PPoints = ^TPoints;
TPoints = array[0..0] of TPoint;

var
P: PPoints;

// Copy From RXHints.pas
function CreatePolyRgn(const Points: array of TPoint): HRgn;
type
PPoints = ^TPoints;
TPoints = array[0..0] of TPoint;
begin
Result := CreatePolygonRgn(PPoints(@Points)^, High(Points) + 1, WINDING);
end;

begin
Image4.canvas.brush.color:=clBlue;
setlength(pary,4);
pary[0]:=point(0,0);
pary[1]:=point(180,0);
pary[2]:=point(180,180);
pary[3]:=point(0,180);
try
myPolygonRgn:=CreatePolyRgn(Pary);
if myPolygonRgn<>0 then
fillrgn(Image4.canvas.handle,myPolygonRgn,Image4.canvas.brush.handle)
else
showmessage('invalid region');
finally
deleteobject(myPolygonRgn);
end;
end;

procedure TFormPolygon.FormMouseMove(Sender: TObject; Shift: TShiftState; X,
Y: Integer);
begin
if ptInRegion(myPolygonRgn,X,Y)=false then
caption:='不在多边形内'
else
caption:='在多边形内!!!!!!1';



end;

procedure TFormPolygon.Image4MouseMove(Sender: TObject; Shift: TShiftState;
X, Y: Integer);
begin
if ptInRegion(myPolygonRgn,X,Y)=false then
caption:='不在多边形内'
else
caption:='在多边形内!!!!!!1';

end;

end.


 
接受答案了.
 
后退
顶部