您的位置:首页 > 其它

将图层属性表的信息显示在DataGridView的控件上

2015-08-25 10:19 337 查看
在做Arcengine开发时常常需要将图层的属性表的信息加载出来,这时就会用到DataGridView这个控件,

首先必须将原有的图层的列名建立起来,这时一张全国的SHP图层(以省级单位)



这个图层有7列,我们先将这7列导出到DataGridView,作为列名
DataTable pTable=new DataTable()//建立一个table
IFields pFields=pFeatureclass.Fields;
for(int i=0;i<pFields.FieldCounts;i++)
{
string FieldName;//建立一个string变量存储Field的名字
FieldName=pFields.Get_Field(i).AliasName;
pTable.Columns.Add(FieldName);
}
现在将图层的列名复制完了,下面将图层里面的每个Feature的字段值进行导入
IFeatureCursor pFeatureCursor;
pFeatureCursor=pFeatureClass.Search(null,false);//全部查询,也可以设置过滤器,IQueryFilter,这里不多介绍了
IFeature pFeature;
pFeature=pFeatureCursor.NextFeature();
while(pFeature!=null)
{
DataRow row=pTable.Newrow();//在pTable下面新建一行,下面是对这一行的每个值赋值
for(int i=0;i<pFields.FieldCounts;i++)
{
string FieldValue=null;//存储pFeature的值
FieldValue=Convert.Tostring(pFeature.get_value(i));//也可以在这里加一些判断,例如值是多少,然后怎样之类的...
row[i]=FieldValue;
}
pTable.rows.Add(row);
pFeature=pFeatureCursor.NextFeature();

}
最后把图层所有的值赋值之后,gridcontrol1.DataSource = pDataTable;
这就是完整的赋值过程了,里面的代码全是手写不是复制,可能有的大小写在编辑器里面是不对的...
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: