C# 搜索MapObject2控件上的地物

因项目需求,需在地图上显示各图层并通过选择地物查询数据。作者分享了核心代码,利用C#和DAO对象,通过地图控件的MouseDownEvent事件,实现了在指定图层搜索地物并获取分公司编号,以便后续在数据库中查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目原因,客户需要张地图,并显示各图层,最后一个图层上是所有分公司的地物,希望通过选择地物进行查询数据,TMD,第一次搞这个,核心就两句,图层ADD很方便,搜索地物真繁,没书没资料,去ERSI下了帮助才搞出来!E文看到头痛

CODE如下:

lstDept.Items.Clear();//显示分公司名的ListBox
     lstID.Items.Clear();//分公司ID的ListBox
     MapObjects2.Rectangle pRect = axMapObj.TrackRectangle();//用MOUSE所选择的巨型区域
     MapObjects2.Recordset pDAOrd = null;
     
     MapObjects2.MapLayer layer = (MapObjects2.MapLayer)axMapObj.Layers.Item(0);//最上面的图层,axMapObj是地图控件的名称
     pDAOrd = layer.SearchShape(pRect,MapObjects2.SearchMethodConstants.moContaining,"");//使用DAO对象,主要是SearchShape方法

     if(pDAOrd!=null)pDAOrd.MoveFirst();//现在就是数据库操作了,不用多说了,不明白的看看DAO对象,和ADO差不多
     while(!pDAOrd.EOF)
     {
      string sDeptName = "";
      string sDeptID = "";

       sDeptName = pDAOrd.Fields.Item("UNITNAME").ValueAsString;
       sDeptID   = pDAOrd.Fields.Item("UNITID").ValueAsString;


      if(sDeptName!=string.Empty && sDeptID!=string.Empty)
      {
       lstDept.Items.Add(sDeptName);
       lstID.Items.Add(sDeptID);
      }
      pDAOrd.MoveNext();
     }

这段CODE放在axMapObj是地图控件的MouseDownEvent事件中

好了,找到分公司的编号,就可以使用自己数据库中的查询了!

我的主页:itbaby.jss.cn

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值