全国高分辨率土地利用数据服务 土地利用数据服务 土地覆盖数据服务 坡度数据服务 土壤侵蚀数据服务 全国各省市DEM数据服务 耕地资源空间分布数据服务 草地资源空间分布数据服务 林地资源空间分布数据服务 水域资源空间分布数据服务 建设用地空间分布数据服务 地形、地貌、土壤数据服务 分坡度耕地数据服务 全国大宗农作物种植范围空间分布数据服务
多种卫星遥感数据反演植被覆盖度数据服务 地表反照率数据服务 比辐射率数据服务 地表温度数据服务 地表蒸腾与蒸散数据服务 归一化植被指数数据服务 叶面积指数数据服务 净初级生产力数据服务 净生态系统生产力数据服务 生态系统总初级生产力数据服务 生态系统类型分布数据服务 土壤类型质地养分数据服务 生态系统空间分布数据服务 增强型植被指数数据服务
多年平均气温空间分布数据服务 多年平均降水量空间分布数据服务 湿润指数数据服务 大于0℃积温空间分布数据服务 光合有效辐射分量数据服务 显热/潜热信息数据服务 波文比信息数据服务 地表净辐射通量数据服务 光合有效辐射数据服务 温度带分区数据服务 山区小气候因子精细数据服务
全国夜间灯光指数数据服务 全国GDP公里格网数据服务 全国建筑物总面积公里格网数据服务 全国人口密度数据服务 全国县级医院分布数据服务 人口调查空间分布数据服务 收入统计空间分布数据服务 矿山面积统计及分布数据服务 载畜量及空间分布数据服务 农作物种植面积统计数据服务 农田分类面积统计数据服务 农作物长势遥感监测数据服务 医疗资源统计数据服务 教育资源统计数据服务 行政辖区信息数据服务
Landsat 8 高分二号 高分一号 SPOT-6卫星影像 法国Pleiades高分卫星 资源三号卫星 风云3号 中巴资源卫星 NOAA/AVHRR MODIS Landsat TM 环境小卫星 Landsat MSS 天绘一号卫星影像
剖面图,就是在具有高程值的raster上画一条直线,这条直线上的每个点除了x,y坐标为更具附加了高程值,便可画出高程值随直线的一个曲线图。高程值只是一个最简单的例子,当raster不是以高程值而是以某个我们想要的值来渲染的时候,这条曲线图便表达的是,随直线变化而变化的某个值的曲线图,开始做这个的时候遇到了一些无法解释的困难,如Com组件错误等,这里参考了韩鹏的<<ArcObject方法>>,这里推荐一下,这是本好书,值得拥有啊,以下是我的代码,我用的是ArcgisEngine来做的,不过ArcgisServer也可以实现
//得到要做剖面分析的面
IRasterLayer layer = this.axMapControl1.Map.get_Layer(0) as IRasterLayer;
IRasterSurface rasterSurf = new RasterSurfaceClass();
rasterSurf.PutRaster(layer.Raster, 0);
ISurface surface = rasterSurf as ISurface;
//得到画的直线
IPolyline inputLine = new PolylineClass();
IPoint start = new PointClass();
start.X = -96.522;
start.Y = 25.589;
inputLine.FromPoint = start;
IPoint end = new PointClass();
end.X = 1.048;
end.Y = 28.664;
inputLine.ToPoint = end;
//用ISurface的 InterpolateShape方法,得到这条直线做剖面后的Geometry,方法说明详见帮助
IGeometry OutShape;
object size = new object();
surface.InterpolateShape(inputLine, out OutShape, ref size);
//将结果QI为 PointCollection,QI成功显示结果是直线上单一的几个离散点,InterpolateShape会自动将分析的结果直线上选取六个等分的离散点,以这六个点的值来作曲线图
IPointCollection pointCollection = OutShape as IPointCollection;
IMAware maware = pointCollection as IMAware;
maware.MAware = true;
IZAware zaware = pointCollection as IZAware;
zaware.ZAware = true;
IMSegmentation mseg = pointCollection as IMSegmentation;
//设置M的值为距离
mseg.SetMsAsDistance(false);
//建立featureClass,为后面曲线图提供数据
IWorkspaceFactory workspaceFactory = new InMemoryWorkspaceFactoryClass();
ESRI.ArcGIS.Geodatabase.IWorkspaceName workspaceName = workspaceFactory.Create("", "MyWorkspace", null, 0);
ESRI.ArcGIS.esriSystem.IName name = (IName)workspaceName;
ESRI.ArcGIS.Geodatabase.IWorkspace inmemWor = (IWorkspace)name.Open();
IFields fields = new FieldsClass();
IFieldsEdit fieldsEdit = fields as IFieldsEdit;
IField oidField = new FieldClass();
IFieldEdit oidFieldEdit = oidField as IFieldEdit;
oidFieldEdit.Name_2 = "OID";
oidFieldEdit.Type_2 = esriFieldType.esriFieldTypeOID;
fieldsEdit.AddField(oidField);
IGeometryDef geometryDef = new GeometryDefClass();
IGeometryDefEdit geometryDefEdit = geometryDef as IGeometryDefEdit;
geometryDefEdit.GeometryType_2 = ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPoint;
geometryDefEdit.HasM_2 = true;
geometryDefEdit.HasZ_2 = true;
ISpatialReferenceFactory spatialReferenceFactory = new SpatialReferenceEnvironmentClass();
ISpatialReference spatialReference = spatialReferenceFactory.CreateGeographicCoordinateSystem((int)esriSRGeoCSType.esriSRGeoCS_WGS1984);
ISpatialReferenceResolution spatialReferenceResolution = (ISpatialReferenceResolution)spatialReference; spatialReferenceResolution.ConstructFromHorizon();
ISpatialReferenceTolerance spatialReferenceTolerance = (ISpatialReferenceTolerance)spatialReference; spatialReferenceTolerance.SetDefaultXYTolerance();
geometryDefEdit.SpatialReference_2 = spatialReference;
IField geometryField = new FieldClass();
IFieldEdit geometryFieldEdit = (IFieldEdit)geometryField;
geometryFieldEdit.Name_2 = "Shape";
geometryFieldEdit.Type_2 = esriFieldType.esriFieldTypeGeometry;
geometryFieldEdit.GeometryDef_2 = geometryDef;
fieldsEdit.AddField(geometryField);
IField mField = new FieldClass();
IFieldEdit mFieldEdit = (IFieldEdit)mField;
mFieldEdit.Name_2 = "M";
mFieldEdit.Type_2 = esriFieldType.esriFieldTypeDouble;
mFieldEdit.Length_2 = 8;
fieldsEdit.AddField(mField);
IField zField = new FieldClass();
IFieldEdit zFieldEdit = (IFieldEdit)zField;
zFieldEdit.Name_2 = "Z";
zFieldEdit.Type_2 = esriFieldType.esriFieldTypeDouble;
zFieldEdit.Length_2 = 8;
fieldsEdit.AddField(zField);
IFieldChecker fieldChecker = new FieldCheckerClass();
IEnumFieldError enumFieldError = null;
IFields validatedFields = null;
fieldChecker.ValidateWorkspace = inmemWor;
fieldChecker.Validate(fields, out enumFieldError, out validatedFields);
IFeatureClass featureClass = (inmemWor as IFeatureWorkspace).CreateFeatureClass("test", validatedFields, null, null, esriFeatureType.esriFTSimple, "Shape", "");
IFeatureCursor cursor = featureClass.Insert(true);
IFeatureBuffer buffer = featureClass.CreateFeatureBuffer();
int count = pointCollection.PointCount;
for (int i = 0; i < count; ++i)
{
IPoint p = pointCollection.get_Point(i);
buffer.Shape = p as IGeometry;
buffer.set_Value(buffer.Fields.FindField("M"), p.M);
buffer.set_Value(buffer.Fields.FindField("Z"), p.Z);
cursor.InsertFeature(buffer);
}
cursor.Flush();
//开始做曲线图
IFeatureLayer featurelayer = new FeatureLayerClass();
featurelayer.FeatureClass = featureClass;
ITable table = featurelayer as ITable;
IDataGraph datagraph = new DataGraphClass();
datagraph.Table = table;
datagraph.FieldSet1 = "Z";
datagraph.FieldSet2 = "M";
IDataGraphProperties proper = datagraph as IDataGraphProperties;
proper.Title = "曲线图";
proper.SubTitle = "跟据Z和M值做的剖面图";
proper.GraphType = esriDataGraphTypeEnum.esriDataGraphTypeLine;
proper.GraphSubtype = esriDataGraphSubtypeEnum.esriDataGraphSubtypeLine2DSimple;
proper.ShowXAxisLabels = true;
proper.ShowLegend = false;
datagraph.Reload();
datagraph.Draw();
datagraph.ExportToFile("c:\\victorcxj.jpg");
需要注意的是,如果是在b/s上做剖面图开发,上面的对象都不能用new 而是用serverContext来创建, 但我在开发中遇到一个奇怪的问题就是datagraph导不出来图片,我后来把DataGraph用new来创建就可以了,有时候AO的东西真是奇怪到你无法解释。。。。