概述
1.打开数据属性表添加用于存储点坐标信息的字段(shape文件支持的字符类型长度为254,GDB中的字段理论长度可以达到2147483647)
2.选择计算字段值,并勾中advanced选项。在其中编写提取面要素边界点的VBA代码
3.核心代码如下(其中[shape]字段代表几何对象):
Dim geo As IGeometry
Set geo =[Shape]
Dim gtmp As IRing
Dim geos As IGeometryCollection
Dim points As IPointCollection
Set geos = geo
For i = 0 To geos.GeometryCount - 1
Set gtmp = geos.Geometry(i)
Set points = gtmp
For j = 0 To points.PointCount - 1
'根据实际情况设定保留的小数位数Round函数第二个参数
temp = temp + CStr(Format(Round(points.point(j).X, 3), ".000")) + "," + CStr (Format(Round(points.point(j).Y, 3), ".000")) + ";"
Next
Next
4.并在结果等于一栏中输入VBA计算的结果字符串temp,OK后即可完成操作
5.可以在此基础上扩展通用的点线面计算方法,并将脚本保存为扩展名为.cal的文件,以后使用直接通过load方式加载即可。
最后
以上就是火星上玫瑰为你收集整理的通过arcmap提取面要素边界点到属性表字段中的全部内容,希望文章能够帮你解决通过arcmap提取面要素边界点到属性表字段中所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复