C# 搜索MapObject2控件上的地物

王朝c#·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

项目原因,客户需要张地图,并显示各图层,最后一个图层上是所有分公司的地物,希望通过选择地物进行查询数据,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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航