.net教程:mapx从数据库读取数据形成新图层
[size=3]在c#中实现mapx从数据库读取数据形成新图层分为两个问题:1. mapx从数据库读取数据形成新图层;
2. 将datatable转换为ado的recordset。
这里的第二个问题是由第一个问题引起的,因为mapx是一个com控件,而且它只支持ado的数据访问方式,而c#编程时一般会使用ado.net方式,为此需要在两种方式之间做一下转换。(当然也可以在c#中使用ado方式,但这毕竟是落后的方法。该解决办法可参考文章《visual basic.net中使用ado访问数据库》)。
对第二个问题的解决办法,参见作者的另一篇文章《将datatable对象转换为recordset对象》(http://blog.csdn.net/allentao/archive/2005/05/11/373634.aspx),本文章只讲述在得到了recordset对象后,如何解决第一个问题。
步骤如下:
1. 创建cmapxfields对象,并对应数据库中字段添加字段;
2. 创建cmapxbindlayer对象,指定其坐标值字段的序号;
3. 向map.datasets中添加数据集,从而生成新的图层;
4. 指定新图层中要素的显示风格,本文采用显示位图的方式,为此需要将要显示的位图放入mapx安装目录的custsymb文件夹下。
代码如下:
private void creatnewlayerfromdb(string layername, adodb.recordset rsnopass)
{
this.deletelayerbyname(layername); //将原有层删除
cmapxfields flds=new fieldsclass();
// describe the structure of the unbound dataset
flds.add("stationid", "theid", aggregationfunctionconstants.miaggregationindividual,
fieldtypeconstants.mitypestring);
flds.add("address", "address", aggregationfunctionconstants.miaggregationindividual,
fieldtypeconstants.mitypestring);
flds.add("longitude", "longitude", aggregationfunctionconstants.miaggregationsum,
fieldtypeconstants.mitypenumeric); //经度
flds.add("latitude", "latitude", aggregationfunctionconstants.miaggregationsum,
fieldtypeconstants.mitypenumeric); //纬度
cmapxbindlayer bindlayerobject=new bindlayerclass();
bindlayerobject.layername=layername;
bindlayerobject.refcolumn1=3;
bindlayerobject.refcolumn2=4;
bindlayerobject.layertype=bindlayertypeconstants.mibindlayertypexy;
cmapxdataset dataset=map.datasets.add(datasettypeconstants.midatasetado,
rsnopass, layername, "stationid", "address", bindlayerobject, flds, false );
cmapxlayer layer=map.layers._item(layername);
layer.overridestyle= true;
string picname="icon.bmp";
if(layer.style.supportsbitmapsymbols == true)
{
layer.style.symboltype = symboltypeconstants.misymboltypebitmap;
layer.style.symbolbitmapsize = 60;
layer.style.symbolbitmaptransparent = true;
layer.style.symbolbitmapname = picname;
}
}
private void deletelayerbyname(string layername)
{
int count=map.layers.count;
for(int i=1; i<count; i++)
{
if(map.layers._item(i).name==layername)
map.layers.remove(i);
}
}
说明:
mapx控件中的序号是从1开始的,这一点可从上面的代码中layers集合与fields集合的序号使用上可以看出。
[/size]
页:
[1]