从网上找到了这个计算方法,但是不会用。
const MaxPointNum = 65535;
type
PXY = ^TXY;
TXY = record // 点的数据结构
x, y: single;
end;
XYArray = array[0..MaxPointNum] of TXY;
PXYArray = ^XYArray; // 线的数据结构
// 多边形坐标在 xys 中,点数在 nn 中
function AreaOfPolygon(xys: PXYArray; nn: integer):single;
var ii:integer;
ss: single;
begin
ss := 0;
for ii := 0 to nn-2 do
ss := ss + (xys^[ii].y+xys^[ii+1].y) * (xys^[ii].x-xys^[ii+1].x) / 2;
result := abs(ss);
end;
////为什么如下这样调用出现错误呢?编译可以通过
procedure TForm1.Button1Click(Sender: TObject);
var
xy: PXYArray;
begin
xy[0].x:=0;
xy[0].y:=0;
xy[1].x:=1;
xy[1].y:=2;
xy[2].x:=3;
xy[2].y:=3;
AreaOfPolygon(xy,3);
end;end.
关键是如何初始化坐标点以及如何调用该函数
请高手帮忙解答,谢谢
暂时给100分,解决后再送100分
----------------------------------------------
const MaxPointNum = 65535;
type
PXY = ^TXY;
TXY = record // 点的数据结构
x, y: single;
end;
XYArray = array[0..MaxPointNum] of TXY;
PXYArray = ^XYArray; // 线的数据结构
// 多边形坐标在 xys 中,点数在 nn 中
function AreaOfPolygon(xys: PXYArray; nn: integer):single;
var ii:integer;
ss: single;
begin
ss := 0;
for ii := 0 to nn-2 do
ss := ss + (xys^[ii].y+xys^[ii+1].y) * (xys^[ii].x-xys^[ii+1].x) / 2;
result := abs(ss);
end;
////为什么如下这样调用出现错误呢?编译可以通过
procedure TForm1.Button1Click(Sender: TObject);
var
xy: PXYArray;
begin
xy[0].x:=0;
xy[0].y:=0;
xy[1].x:=1;
xy[1].y:=2;
xy[2].x:=3;
xy[2].y:=3;
AreaOfPolygon(xy,3);
end;end.
关键是如何初始化坐标点以及如何调用该函数
请高手帮忙解答,谢谢
暂时给100分,解决后再送100分
----------------------------------------------
解决方案 »
- quickreport中对beforeprint,afterprint事件用法
- 关于第三方控件使用,奇怪问题,请教下各位
- 求助:CombogBox下拉框的高度与水平滚动()
- 各位,新年好,如何将richedit中内容带格式保存到access中?
- Tmonthcalendar控件,如何把日期设置成2004-05-01的形式
- 如何在stringGrid里显示图片
- 找程序员工作,精通DELPHI,PB,VC,工作地方:广州
- 如何在一个FORM的FormActivate事件中满足某个条件时将自己关闭?
- 算法求解:任意时间段的天数计算
- nkzgj(和曦) 请进来一下
- 如何分割这条Update语句??
- 点击关闭按钮后,如何取消关闭操作,
function AreaOfPolygon(xys: TPoints):single;
var ii,nn:integer;
ss: single;
begin
nn:=Length(xys);
ss := 0;
for ii := 0 to nn-2 do
ss := ss + (xys[ii].y+xys[ii+1].y) * (xys[ii].x-xys[ii+1].x) ;
result := abs(ss/2);
end;
用这个试试
var
pointsA:Tpoints;
i:integer;
b:double;
begin
setlength(pointsA,3);
for i:= 0 to 2 do
begin
pointsa[i].X:=10*i+10;
pointsa[i].Y:=10*i+90;
end;
b:=areaofpolygon(pointsa);
showmessage(floattostr(b));end;