创建一个弧

通过中心点,半径和角度

/ * *
*功能:objarc
*创建一个弧(与N段线)
*
*参数:
*中心-中心点
半径-圆弧半径
*α-起始角度(Grad
*ω-结束角(Grad
*段-绘制圆弧的段数
*标志-真正的:创建弧功能,从中心开始到端点到中心
*错误:创建弧功能从开始到终点
*
*返回:一个具有四个功能的数组,如果标志
*电弧特征(来自Linestring)
*起点(点)
*端点(从点)
*弦(LineString)
* /
function objArc(center, radius, alpha, omega, segments, flag)
{
    var pointList=[];
    if(flag)
        pointList.push(new OpenLayers.Geometry.Point(center.x, center.y));

    var dAngle= segments+1;
    for(var i=0;i<dAngle;i++)
    {
        var Angle = alpha - (alpha-omega)*i/(dAngle-1);
        var x = center.x + radius*Math.cos(Angle*Math.PI/180);
        var y = center.y + radius*Math.sin(Angle*Math.PI/180);

        var point = new OpenLayers.Geometry.Point(x, y);

        pointList.push(point);
    }
    if(flag)
        pointList.push(new OpenLayers.Geometry.Point(center.x, center.y));

    var ftArc    = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString(pointList));
    if(flag)
    {
        var ftArcPt0 = new OpenLayers.Feature.Vector(pointList[1]);
        var ftArcPt1 = new OpenLayers.Feature.Vector(pointList[pointList.length-2]);
        var ftArcSehne = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString([pointList[1], pointList[pointList.length-2]]));
        var arrArc = [ftArc, ftArcPt0, ftArcPt1, ftArcSehne];
    }
    else
        var arrArc = [ftArc];

    return(arrArc);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值