从零开始搭建一个GIS开发小框架(二)——扩展功能:绘制多边形

1.绘制多边形功能实现

1.1功能描述

在GMap.Net控件上创建一个图层,在图层上绘制多边形,生成一个多边形对象,给图形对象赋结构化数据属性(以Json形式封装和解析)。

1.2实现效果演示

功能菜单:
在这里插入图片描述

多边形对象绘制、给图形对象增加右键菜单:
在这里插入图片描述

多边形对象的右键菜单打开弹窗,实现最基本的窗体传值:
在这里插入图片描述

多边形对象的Tag属性和Name属性可以存放用户自定义属性描述,我在Tag里存放完整的Json数据:
在这里插入图片描述

2.绘制功能的核心方法代码

在绘制多边形方法里同时实现了:坐标点缓存处理。当开启该功能时,点击左键的时候新增一个界址点,获取该点的坐标(OpenCycleMap地图是WGS84坐标),并将坐标点加到PolygonPointList中,从点击第二个点A2开始,每点击创建一个点AN,绘制两点AN和AN-1之间的直线,作为多边形的边线;点击右键时,绘制结束,创建直线连接最后一个点和第一个点,形成封闭多边形,完成样式设置,例如颜色填充等,最后将所有的数据赋值给多边形对象p,由p生成格式化后的Json数据集。

/// <summary>
/// 多边形左键加点
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void MapControl_PolygonMouseClick(object sender, MouseEventArgs e)
{
    if (e.Button == MouseButtons.Left)    //新建一个端点
    {
        PointLatLng point = MainMap.FromLocalToLatLng(e.X, e.Y);
        double pLat = point.Lat;
        double pLong = point.Lng;
        PolygonPointList.Add(new PointLatLng(pLat, pLong));

        #region 多边形辅助线

        int listCount = PolygonPointList.Count;

        if (listCount > 1)
        {
            List<PointLatLng> latlngs = new List<PointLatLng>();
            latlngs.Add(PolygonPointList[listCount - 1]);
            latlngs.Add(PolygonPointList[listCount - 2]);
            GMapRoute _routeOnPolygon = new GMapRoute(latlngs, "routeOnPolygon");
            _routeOnPolygon.Stroke = new Pen(Color.Red, 1);
            _routeOnPolygon.Stroke.DashStyle = System.Drawing.Drawing2D.DashStyle.Solid;   //虚线
            polygonAuxiliaryLinelay.Routes.Add(_routeOnPolygon);
            //更新显示route
            this.MainMap.UpdateRouteLocalPosition(_routeOnPolygon);
        }

        #endregion

    }
    else if (e.Button == MouseButtons.Right)    //结束多边形绘制
    {
        IList<string> cachePoints = new List<string>();
        foreach (PointLatLng x in PolygonPointList)
        {
            string po = x.Lat.ToString() + "," + x.Lng.ToString();
            cachePoints.Add(po);
        }

        PolygonProp p = new PolygonProp();
        p.PointsWGS84 = cachePoints;

        string pointsJson = JsonConvert.SerializeObject(p, Formatting.Indented);

        GMapPolygon polygon = new GMapPolygon(PolygonPointList, "mypolygon");
        polygon.Fill = new SolidBrush(Color.FromArgb(150, Color.Yellow));
        polygon.Stroke = new Pen(Color.Red, 1);
        polygon.Name = "土地位置";  //土地位置
        polygon.Tag = pointsJson;
        polygon.IsHitTestVisible = true;
        polygon.Status = RouteStatusCode.OK;
        overlay.Polygons.Add(polygon);

        PolygonPointList.Clear();
        polygonAuxiliaryLinelay.Routes.Clear();
    }
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiangcns

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值