C#+arcengine获得栅格数据的属性表
2015-02-03 19:15
363 查看
此文为或的栅格数据的属性表的功能,在此,我的属性表中有count和value字段,其中value是栅格数据的高程值,count是value在影像中出现的次数,此程序的功能为得到count最大的数,以此来获得对应的value即此栅格影像的高程值的众数,如下:
/// <summary>
/// 获得属性表
/// </summary>
/// <param name="maskTifPath">raster的路径</param>
private int GetAttributeTable(string maskPath)
{
int elevation=0;//高程
//得到raster(见另外的博文获得栅格数据)
IRaster raster=GetRaster(maskPath);
if (raster != null)
{
try
{
//得到一段光栅带
IRasterBandCollection rasterBandCollection = (IRasterBandCollection)raster;
int bandCount = rasterBandCollection.Count;//bandCount=1
for (int j = 0; j < bandCount; j++)
{
IRasterBand rasterBand = rasterBandCollection.Item(j);
//得到此光栅带的属性表,并保存到table
ITable table = rasterBand.AttributeTable;
//创建一个查询(SQL语句)
IQueryFilter queryFilter = new QueryFilterClass();
queryFilter.WhereClause = "";
//用queryFilter查询表,并把结果保存到游标指针中去
ICursor cursorCount = table.Search(queryFilter, false);
IRow rowCount = cursorCount.NextRow();
// count字段集合
List<int> countCol = new List<int>();
int MaxValue = 0;
for (int i = 0; i < table.Fields.FieldCount; i++)//field.count=4
{
//判断字段名称是否为count
if (table.Fields.get_Field(i).Name == "Count")
{
while (rowCount != null)
{
//以下显示Count字段的值,并得到count值的集合
countCol.Add(Convert.ToInt32(rowCount.get_Value(table.FindField("Count"))));
rowCount = cursorCount.NextRow();
}
int count = countCol.Count;
//得到字段Count的最大值
MaxValue = countCol[0];
for (int w = 1; w < count; w++)
{
if (countCol[w] > MaxValue)
{
MaxValue = countCol[w];
}
}
//得到Count最大时value的值,即为高程的众数
ICursor cursorBinvalues = table.Search(queryFilter, false);
IRow rowBinvalues = cursorBinvalues.NextRow();
while (rowBinvalues != null)
{
int value = Convert.ToInt32(rowBinvalues.get_Value(table.FindField("Count")));
if (value == MaxValue)
{
elevation = Convert.ToInt32(rowBinvalues.get_Value(table.FindField("Value")));
}
rowBinvalues = cursorBinvalues.NextRow();
}
}
else
{
//字段名称不是count,无用,往下判断
}
}
}
return elevation;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
return 0;
}
}
else
{
MessageBox.Show("提取栅格数据失败!");
return 0;
}
}
本文参照了http://blog.csdn.net/gisoracle/article/details/4297650博文,博主很强大,在次拜谢
/// <summary>
/// 获得属性表
/// </summary>
/// <param name="maskTifPath">raster的路径</param>
private int GetAttributeTable(string maskPath)
{
int elevation=0;//高程
//得到raster(见另外的博文获得栅格数据)
IRaster raster=GetRaster(maskPath);
if (raster != null)
{
try
{
//得到一段光栅带
IRasterBandCollection rasterBandCollection = (IRasterBandCollection)raster;
int bandCount = rasterBandCollection.Count;//bandCount=1
for (int j = 0; j < bandCount; j++)
{
IRasterBand rasterBand = rasterBandCollection.Item(j);
//得到此光栅带的属性表,并保存到table
ITable table = rasterBand.AttributeTable;
//创建一个查询(SQL语句)
IQueryFilter queryFilter = new QueryFilterClass();
queryFilter.WhereClause = "";
//用queryFilter查询表,并把结果保存到游标指针中去
ICursor cursorCount = table.Search(queryFilter, false);
IRow rowCount = cursorCount.NextRow();
// count字段集合
List<int> countCol = new List<int>();
int MaxValue = 0;
for (int i = 0; i < table.Fields.FieldCount; i++)//field.count=4
{
//判断字段名称是否为count
if (table.Fields.get_Field(i).Name == "Count")
{
while (rowCount != null)
{
//以下显示Count字段的值,并得到count值的集合
countCol.Add(Convert.ToInt32(rowCount.get_Value(table.FindField("Count"))));
rowCount = cursorCount.NextRow();
}
int count = countCol.Count;
//得到字段Count的最大值
MaxValue = countCol[0];
for (int w = 1; w < count; w++)
{
if (countCol[w] > MaxValue)
{
MaxValue = countCol[w];
}
}
//得到Count最大时value的值,即为高程的众数
ICursor cursorBinvalues = table.Search(queryFilter, false);
IRow rowBinvalues = cursorBinvalues.NextRow();
while (rowBinvalues != null)
{
int value = Convert.ToInt32(rowBinvalues.get_Value(table.FindField("Count")));
if (value == MaxValue)
{
elevation = Convert.ToInt32(rowBinvalues.get_Value(table.FindField("Value")));
}
rowBinvalues = cursorBinvalues.NextRow();
}
}
else
{
//字段名称不是count,无用,往下判断
}
}
}
return elevation;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
return 0;
}
}
else
{
MessageBox.Show("提取栅格数据失败!");
return 0;
}
}
本文参照了http://blog.csdn.net/gisoracle/article/details/4297650博文,博主很强大,在次拜谢
相关文章推荐
- C#+arcengine获得栅格数据
- C#+Arcengine实现GP工具中的extract by mask(提取掩膜),可以实现提取shp范围的栅格数据,可用来获得shp范围的高程
- C#+arcengine获得栅格数据的像素值(高程)
- C#+arcengine修改栅格数据的像元值
- C#+ArcEngine加载影像Raster栅格数据,并与ArcGIS一样判断是否创建金字塔。
- C#+arcengine实现栅格计算器的减功能(可以用来修改栅格数据的高程)
- C#+ArcEngine:加载打开Shp矢量数据和栅格数据(VS2010窗体+代码)
- C#+Arcengine实现GP工具中Data Management Tool》raster》raster processing中的clip功能(矢量数据对栅格数据的裁剪)
- C#+arcengine实现输出水深图的功能(通过淹没区域和dem高程数据)(包含栅格计算器(减)、feature to line、产生随机点、获得高程、extract values to poin)
- C#后台获得前台JS数据值
- 【转】ArcGIS栅格数据的属性表受65536限制的问题
- C#+ArcEngine 不同格式数据打开,对象创建,导入导出
- ArcEngine和GDAL读写栅格数据机制对比(一)
- 基于ArcEngine+C#设计与开发国土资源一张图空间数据管理平台软件
- 基于ArcEngine+C#开发的空间数据管理平台架构设计及功能说明
- ArcEngine 栅格数据
- .net C# 获得数据集行和列
- C#获得SQLServer服务器名、数据库名、表名、以及字段名【转载】
- ArcEngine加载SDE中的栅格数据的问题
- C# +AE加载shp、栅格、地图文档数据