ArcEngine Geometry库定义了基本几何图形的矢量表达形式,顶级的几何图形有Points、Multipoints、Polylines、Polygons、Multipatches,Geodatabase和绘图系统使用这些几何图形来定义其他各种形状的特征和图形,提供了编辑图形的操作方法和地图符号系统符号化特征数据的途径。
Geometry库中几个核心类和接口构成了Geometry对象的基本框架。
GeometryEnvironment
GeometryEnvironment提供了从不同的输入、设置或获取全局变量来创建几何图形的方法,以便控制geometry方法的行为。GeometryEnvironment对象是一个单例对象。
new GeometryEnvironmentClass仅仅是创建了一个指向已存在的GeometryEnvironmentClass的引用。注意IGeometryBridge2接口的使用,addWKSPoints方法将WKSPoint二维点添加到PointCollection中,用于构建path、ring、polyline、polygon,或增加新点到Multipoint、TriangleFan、TriangleStrip。在Geometry库中,除了IGeometryBridge2还有IGeometryBridge接口,后者继承了前者,增加了一些编辑功能(添加点、插入点、重置点、分段等)。
GeometryBag
GeometryBag是支持IGeometry接口的几何对象引用的集合,任何几何对象都可以通过IGeometryCollection接口添加到GeometryBag中,但是在使用拓扑操作的时候,需要注意不同类型的几何类型可能会有相互不兼容的情况。在向GeometryBag中添加几何对象的时候,GeometryBag对象需要指定空间参考,添加到其中的几何对象均拥有和GeometryBag对象一样的空间参考。
Points
一个点包括X、Y坐标,同时可以增加M、Z值及ID属性来扩展点的功能。
Multipoints
点的集合,多点组成Multipoint几何类型,使用multipoint对象实现了的IPointCollection接口可以访问所有的点元素,这些点同样可以拥有M、Z值及ID属性来获得更多的地理空间内涵。
下面列举一个例子,通过一个已知的polyline来定义一个新的multipart polyline。
data:image/s3,"s3://crabby-images/ed424/ed4246f1e69f3216ed8a9483acc7363059b0b989" alt=""
data:image/s3,"s3://crabby-images/673fd/673fdcff72c0323a95ed9463054934b2c425b956" alt="" public IPolyline ConstructMultiPartPolyline(IPolyline inputPolyline)
data:image/s3,"s3://crabby-images/428be/428be4017ebae054caa2d9150bf1ef2860103c3b" alt="" data:image/s3,"s3://crabby-images/fbdfc/fbdfc013c4d7aa32e94aed45eba99c535767537d" alt="" data:image/s3,"s3://crabby-images/bc690/bc6904de971a85ff806e9a50cce77e7bb71b5dd3" alt="" {
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IGeometry outGeometry = new PolylineClass();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Always associate new, top-level geometries with an appropriate spatial reference.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" outGeometry.SpatialReference = inputPolyline.SpatialReference;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IGeometryCollection geometryCollection = outGeometry as IGeometryCollection;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" ISegmentCollection segmentCollection = inputPolyline as ISegmentCollection;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Iterate over existing polyline segments using a segment enumerator.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IEnumSegment segments = segmentCollection.EnumSegments;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" ISegment currentSegment;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" int partIndex = 0;;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" int segmentIndex = 0;;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" segments.Next(out currentSegment,ref partIndex, ref segmentIndex);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" while(currentSegment != null)
data:image/s3,"s3://crabby-images/57933/579339e059236fdff294d045924ab19670a66145" alt="" data:image/s3,"s3://crabby-images/bc690/bc6904de971a85ff806e9a50cce77e7bb71b5dd3" alt="" {
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" ILine normal = new LineClass();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Geometry methods with _Query_ in their name expect to modify existing geometries.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //In this case, the QueryNormal method modifies an existing line
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //segment (normal) to be the normal vector to
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //currentSegment at the specified location along currentSegment.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" currentSegment.QueryNormal(esriSegmentExtension.esriNoExtension, 0.5, true, currentSegment.Length / 3, normal);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Since each normal vector is not connected to others, create a new path for each one.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" ISegmentCollection newPath = new PathClass();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" object missing = Type.Missing;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" newPath.AddSegment(normal as ISegment, ref missing, ref missing);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //The spatial reference associated with geometryCollection will be assigned to all incoming paths and segments.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" geometryCollection.AddGeometry(newPath as IGeometry, ref missing, ref missing);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" segments.Next(out currentSegment,ref partIndex, ref segmentIndex);
data:image/s3,"s3://crabby-images/053b3/053b36b1ea6fffd142f70c825864feffea1854b0" alt="" }
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //The geometryCollection now contains the new, multipart polyline.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" return geometryCollection as IPolyline;
data:image/s3,"s3://crabby-images/f3edc/f3edc1792ad6a96129d88683e6cfed7778cc3a66" alt="" }
ISegment接口的QueryNormal方法用来在弧段上的某一点生成该弧段的法线,指定其长度,这样就生成了新的segment,并且多个path添加到geometryCollection中,以IPolyline的形式返回。
Polylines
Polylines是有序path组成的集合,可以拥有M、Z和ID属性值。Polyline对象的IPointCollection接口包含了所有节点的复制,IGeometryCollection接口可以获取polyline的paths,ISegmentCollection接口可以获取polyline的segments。
Polyline结构图
data:image/s3,"s3://crabby-images/f09be/f09be2689666a36c4d5cc6feef0d9f2c6283b225" alt=""
Polygons
Polygon是一系列rings组成的集合,可以拥有M、Z和ID属性值。每一个ring由一个或多个segment组成,Polygon或ring对象的IPointCollection接口包含了所有节点的复制,IGeometryCollection接口可以获取polygon的rings,ISegmentCollection接口可以获取polygon的segments。
Polygon结构图
data:image/s3,"s3://crabby-images/5e1a2/5e1a2db0025b068526456abde0b6c192c1728206" alt=""
Multipatch
Multipatch用于描述3D面状几何类型,由一系列的矢量三角形构成,如果其中的part是一个ring,那么它必须是封闭的,第一个节点和最后一个节点相同,另外每个part所包含节点的顺序非常重要,Inner Rings在Outer Rings之后,代表单个表面patch的一系列rings必须由第一个ring开始。
data:image/s3,"s3://crabby-images/45acf/45acf51b675720776b7ff214a15a4f01c1195910" alt=""
在9.0以后的开发包中,使用IGeneralMultiPatchCreator创建新的Multipatch,IGeometryMaterial进行材质贴图。
data:image/s3,"s3://crabby-images/673fd/673fdcff72c0323a95ed9463054934b2c425b956" alt="" public IMultiPatch CreateMultipatch()
data:image/s3,"s3://crabby-images/428be/428be4017ebae054caa2d9150bf1ef2860103c3b" alt="" data:image/s3,"s3://crabby-images/fbdfc/fbdfc013c4d7aa32e94aed45eba99c535767537d" alt="" data:image/s3,"s3://crabby-images/bc690/bc6904de971a85ff806e9a50cce77e7bb71b5dd3" alt="" {
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Prepare the geometry material list.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IGeometryMaterial texture = new GeometryMaterialClass();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" texture.TextureImage = C:TempMyImage.bmp;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IGeometryMaterialList materialList = new GeometryMaterialListClass();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" materialList.AddMaterial(texture);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Create the multipatch.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IGeneralMultiPatchCreator multiPatchCreator = new GeneralMultiPatchCreatorClass();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.Init(4, 1, false, false, false, 4, materialList);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Set up part.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Could also use a Ring or a TriangleFan.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetPatchType(0, esriPatchType.esriPatchTypeTriangleStrip);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetMaterialIndex(0, 0);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetPatchPointIndex(0, 0);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetPatchTexturePointIndex(0, 0);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Set real-world points.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPointZ upperLeft = new WKSPointZ();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPointZ lowerLeft = new WKSPointZ();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPointZ upperRight = new WKSPointZ();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPointZ lowerRight = new WKSPointZ();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" upperLeft.X = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" upperLeft.Y = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" upperLeft.Z = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" upperRight.X = 300;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" upperRight.Y = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" upperRight.Z = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" lowerLeft.X = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" lowerLeft.Y = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" lowerLeft.Z = -100;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" lowerRight.X = 300;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" lowerRight.Y = 1;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" lowerRight.Z = -100;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetWKSPointZ(0, ref upperRight);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetWKSPointZ(1, ref lowerRight);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetWKSPointZ(2, ref upperLeft);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetWKSPointZ(3, ref lowerLeft);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Set texture points.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" //Set the texture coordinates for a panel.
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPoint textureUpperLeft = new WKSPoint();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPoint textureLowerLeft = new WKSPoint();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPoint textureUpperRight = new WKSPoint();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" WKSPoint textureLowerRight = new WKSPoint();
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureUpperLeft.X = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureUpperLeft.Y = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureUpperRight.X = 1;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureUpperRight.Y = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureLowerLeft.X = 0;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureLowerLeft.Y = 1;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureLowerRight.X = 1;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" textureLowerRight.Y = 1;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetTextureWKSPoint(0, ref textureUpperRight);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetTextureWKSPoint(1, ref textureLowerRight);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetTextureWKSPoint(2, ref textureUpperLeft);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" multiPatchCreator.SetTextureWKSPoint(3, ref textureLowerLeft);
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" IMultiPatch multiPatch = multiPatchCreator.CreateMultiPatch() as IMultiPatch;
data:image/s3,"s3://crabby-images/ca8cc/ca8ccf68d10ccecb2814e64d10533b229c04ad87" alt="" return multiPatch;
data:image/s3,"s3://crabby-images/f3edc/f3edc1792ad6a96129d88683e6cfed7778cc3a66" alt="" } (责任编辑:admin) |