多边形交叉区域计算面积_使用GPC或Clipper计算多边形交叉区域

在Angus的Clipper与其他库的基准测试中,他有一个多边形区域计算方法 . 我用它并修改了他的椭圆方法 . 结果如下:

void Ellipse2Poly(double theta, double A1, double B1, double H1, double K1, Poly& p)

{

const double pi = 3.1415926535898, tolerance = 0.125;

const int n = 30;

double step = pi/(double)n;

double a = A1; // Long semi-axis length

double b = B1; // short semi-axis length

double xc = H1; // current X position

double yc = K1; // current Y position

double sintheta = sin(theta);

double costheta = cos(theta);

double t = 0;

p.resize(2*n+1);

for (int i = 0; i < 2*n+1; i++)

{

p[i].x = xc + a*cos(t)*costheta - b*sin(t)*sintheta;

p[i].y = yc + a*cos(t)*sintheta + b*sin(t)*costheta;

t += step;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值