全国高分辨率土地利用数据服务 土地利用数据服务 土地覆盖数据服务 坡度数据服务 土壤侵蚀数据服务 全国各省市DEM数据服务 耕地资源空间分布数据服务 草地资源空间分布数据服务 林地资源空间分布数据服务 水域资源空间分布数据服务 建设用地空间分布数据服务 地形、地貌、土壤数据服务 分坡度耕地数据服务 全国大宗农作物种植范围空间分布数据服务
多种卫星遥感数据反演植被覆盖度数据服务 地表反照率数据服务 比辐射率数据服务 地表温度数据服务 地表蒸腾与蒸散数据服务 归一化植被指数数据服务 叶面积指数数据服务 净初级生产力数据服务 净生态系统生产力数据服务 生态系统总初级生产力数据服务 生态系统类型分布数据服务 土壤类型质地养分数据服务 生态系统空间分布数据服务 增强型植被指数数据服务
多年平均气温空间分布数据服务 多年平均降水量空间分布数据服务 湿润指数数据服务 大于0℃积温空间分布数据服务 光合有效辐射分量数据服务 显热/潜热信息数据服务 波文比信息数据服务 地表净辐射通量数据服务 光合有效辐射数据服务 温度带分区数据服务 山区小气候因子精细数据服务
全国夜间灯光指数数据服务 全国GDP公里格网数据服务 全国建筑物总面积公里格网数据服务 全国人口密度数据服务 全国县级医院分布数据服务 人口调查空间分布数据服务 收入统计空间分布数据服务 矿山面积统计及分布数据服务 载畜量及空间分布数据服务 农作物种植面积统计数据服务 农田分类面积统计数据服务 农作物长势遥感监测数据服务 医疗资源统计数据服务 教育资源统计数据服务 行政辖区信息数据服务
Landsat 8 高分二号 高分一号 SPOT-6卫星影像 法国Pleiades高分卫星 资源三号卫星 风云3号 中巴资源卫星 NOAA/AVHRR MODIS Landsat TM 环境小卫星 Landsat MSS 天绘一号卫星影像
除去 Point,MultiPoint 和 Envelope 外,其他所有的几何体都可以看做是 Curve(曲线)。Line,Polyline, Polygon,CircularArc,BezierCurve,EllipticArc 和 CircularArc 都是曲线的一种,它们都实现了 ICurve 接口。
ICurve 接口的 Length 属性用于返回一个 Curve 对象的长度。
ICurve 接口的 FromPoint 和 ToPoint 属性可以获得 Curve 对象的起止点。
ICurve 接口的 Reverseorientation 方法可以改变一个 Curve 对象的节点次序即调动 Curve 对象的起 始点和终止点互相调换。
ICurve 接口的 IsClosed 属性则可以判断一个 Curve 对象起始点和终止点是否在一个位置上。
ICurve 接口的 GetSubcurve 方法可以复制一条 Curve 对象的特定部分,例如一条 10 千米公路的 Curve对象,获取 2-5 千米处的公路的曲线代码片段如下所示:
//QI 到 ICurve 接口
ICurve pCurve = pPolyline as ICurve;
//创建一个 Polyline 对象
ICurve pNewCurve = new PolylineClass ();
bool btrue = true;
//获取-5 千米间的曲线对象
pCurve.GetSubcurve(2, 5, btrue, out pNewCurve);
此外 ICurve 的 QueryTangent 和 QueryNormal 方法分别用于获取 Curve 对象上某一点的曲线的切线和法线。
平头缓冲
思路就是将线向左右两边移动相同的距离,然后将一条线的方向反向,加入另外一条,构造矩形或者矩形面
private IPolygon FlatBuffer (IPolyline pLline1, double pBufferDis)
{
object o = System.Type.Missing;
//分别对输入的线平移两次(正方向和负方向) IConstructCurve pCurve1 = new PolylineClass();
pCurve1.ConstructOffset (pLline1, pBufferDis, ref o, ref o);
IPointCollection pCol = pCurve1 as IPointCollection;
IConstructCurve pCurve2 = new PolylineClass ();
pCurve2.ConstructOffset (pLline1, - 1 * pBufferDis, ref o, ref o);
//把第二次平移的线的所有节点翻转
IPolyline pline2 = pCurve2 as IPolyline;
pline2.ReverseOrientation ();
//把第二条的所有节点放到第一条线的IPointCollection里面
IPointCollection pCol2 = pline2 as IPointCollection;
pCol.AddPointCollection (pCol2);
//用面去初始化一个IPointCollection IPointCollection
pPointCol = new PolygonClass ();
pPointCol.AddPointCollection (pCol);
//把IPointCollection转换为面
IPolygon pPolygon = pPointCol as IPolygon;
//简化节点次序
pPolygon.SimplifyPreserveFromTo ();
return pPolygon;
}