版块导航
正在加载中...
客户端APP下载
登录
注册
帖子
帖子
用户
本版
应《网络安全法》要求,自2017年10月1日起,未进行实名认证将不得使用互联网跟帖服务。为保障您的帐号能够正常使用,请尽快对帐号进行手机号验证,感谢您的理解与支持!
24小时热门版块排行榜
>
论坛更新日志
(401)
>
虫友互识
(33)
>
休闲灌水
(20)
>
文献求助
(11)
>
仿真模拟
(6)
>
考博
(5)
>
外文书籍求助
(4)
>
文献求助完结子版
(3)
>
版块工场
(2)
>
绿色求助(高悬赏)
(2)
>
基金申请
(2)
>
导师招生
(1)
>
博后之家
(1)
>
考研
(1)
小木虫论坛-学术科研互动平台
»
专业学科区
»
地学
»
3S技术
»
Vb.net+ArcEngine生成点状图层的速度太慢了该怎么办?
5
1/1
返回列表
查看: 2049 | 回复: 10
只看楼主
@他人
存档
新回复提醒
(忽略)
收藏
在APP中查看
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖
zzahkj
木虫
(著名写手)
应助: 42
(小学生)
金币: 1931.7
帖子: 1522
在线: 465.8小时
虫号: 964751
[交流]
Vb.net+ArcEngine生成点状图层的速度太慢了该怎么办?
Vb.net+ArcEngine生成点状图层的速度太慢了该怎么办?由于我做的是预警预报系统,速度尽可能短,现在生成全部点要好几天,这也太慢了,根本就不适用,请问有什么好的办法解决吗?我的代码如下:
CODE:
Public Sub dianshengcheng()
Dim filePath As String = My.Computer.FileSystem.CurrentDirectory & "\ResultsFileName"
If System.IO.File.Exists(filePath & "\点.shp") Then
MessageBox.Show("点文件已存在")
Main.AxMapControl1.AddShapeFile(filePath, "点")
Else
Dim pShpWksFact As IWorkspaceFactory = New ShapefileWorkspaceFactory()
Dim pFeatWks As IFeatureWorkspace
pFeatWks = CType(pShpWksFact.OpenFromFile(filePath, 0), IFeatureWorkspace)
Const strShapeFieldName As String = "shape"
Dim pFields1 As IFields
Dim pFieldsEdit1 As IFieldsEdit
pFields1 = New FieldsClass()
pFieldsEdit1 = CType(pFields1, IFieldsEdit)
Dim pField1 As IField = New FieldClass()
Dim pFieldEdit1 As IFieldEdit = New FieldClass()
pFieldEdit1.Name_2 = strShapeFieldName
pFieldEdit1.Type_2 = esriFieldType.esriFieldTypeGeometry
pField1 = CType(pFieldEdit1, IField)
Dim pGeomDef1 As IGeometryDef = New GeometryDefClass()
Dim pGeomDefEdit1 As IGeometryDefEdit = New GeometryDefClass()
pGeomDefEdit1 = CType(pGeomDef1, IGeometryDefEdit)
pGeomDefEdit1.GeometryType_2 = esriGeometryType.esriGeometryPoint
pGeomDefEdit1.SpatialReference_2 = Main.AxMapControl1.Map.SpatialReference
'pGeomDefEdit1.HasZ_2 = True
pFieldEdit1.GeometryDef_2 = pGeomDef1
pFieldsEdit1.AddField(pField1)
pFields1 = CType(pFieldsEdit1, IFields)
pField1 = New Field
pFieldEdit1 = pField1
With pFieldEdit1
pFieldEdit1.Length_2 = 10
pFieldEdit1.Name_2 = "温度"
pFieldEdit1.Type_2 = esriFieldType.esriFieldTypeDouble
End With
pFieldsEdit1.AddField(pField1)
pField1 = New Field
pFieldEdit1 = pField1
With pFieldEdit1
pFieldEdit1.Length_2 = 10
pFieldEdit1.Name_2 = "盐度"
pFieldEdit1.Type_2 = esriFieldType.esriFieldTypeDouble
End With
pFieldsEdit1.AddField(pField1)
pField1 = New Field
pFieldEdit1 = pField1
With pFieldEdit1
pFieldEdit1.Length_2 = 10
pFieldEdit1.Name_2 = "水质指标"
pFieldEdit1.Type_2 = esriFieldType.esriFieldTypeDouble
End With
pFieldsEdit1.AddField(pField1)
Dim pFeatureClass1 As IFeatureClass
pFeatureClass1 = pFeatWks.CreateFeatureClass("点", pFields1, Nothing, Nothing, esriFeatureType.esriFTSimple, strShapeFieldName, "")
Dim pPointCol As IPointCollection = New MultipointClass()
Dim sr As StreamReader = New StreamReader(My.Computer.FileSystem.CurrentDirectory & "\shu\dianceng.txt")
Dim str As String = sr.ReadLine()
While str IsNot Nothing
Dim strs() As String = Regex.Split(str, " ")
Dim x As Double = Convert.ToDouble(strs(0))
Dim y As Double = Convert.ToDouble(strs(1))
Dim t As Double = Convert.ToDouble(strs(2))
Dim s As Double = Convert.ToDouble(strs(3))
Dim c As Double = Convert.ToDouble(strs(4))
Dim pPoint As IPoint = New PointClass()
pPoint.X = x
pPoint.Y = y
Dim missing As Object = Type.Missing
pPointCol.AddPoint(pPoint, missing, missing)
str = sr.ReadLine()
Dim i As Integer
For i = 0 To pPointCol.PointCount - 1 Step 1
Dim newFeature As IFeature = pFeatureClass1.CreateFeature
newFeature.Shape = pPointCol.Point(i)
newFeature.Value(newFeature.Fields.FindField("温度")) = t
newFeature.Value(newFeature.Fields.FindField("盐度")) = s
newFeature.Value(newFeature.Fields.FindField("水质指标")) = c
newFeature.Store()
Next
End While
Main.AxMapControl1.Refresh()
Main.AxMapControl1.AddShapeFile(filePath, "点")
MessageBox.Show("文件创建成功")
End If
End Sub
[
Last edited by zzahkj on 2011-5-6 at 15:36
]
回复此楼
» 猜你喜欢
西南科技大学 调剂 绵阳
已经有10人回复
散金币,求基金中标!!
已经有47人回复
地球物理学和空间物理学论文润色/翻译怎么收费?
已经有129人回复
诚邀
已经有0人回复
考研求调剂
已经有4人回复
考研求调剂
已经有2人回复
东北石油大学地球科学学院地质资源与地质工程专业接收调剂
已经有0人回复
高级回复
» 本主题相关价值贴推荐,对您同样有帮助:
昆虫科学怎么这么慢?
已经有3人回复
为什么羧酸盐和醇可以生成酯?
已经有12人回复
急,刚投稿之后回复生成的PDF有问题,请教~~~
已经有5人回复
大家帮忙看看应该怎么办?
已经有7人回复
现在Elsevier旗下的期刊处理速度慢,是不是科学家抵制的结果?
已经有28人回复
Electrochimica Acta现在处理速度貌似很慢???
已经有19人回复
RAW264.7细胞长得很慢吗?
已经有12人回复
(高悬赏求教)SDS-PAGE时间过长,速度慢
已经有5人回复
Vb.net+ArcEngine生成的点状图层不显示?
已经有10人回复
SCI如何写撤稿信,杂志审稿太慢,我要撤稿重新投
已经有4人回复
【求助】求助裸鼠移植瘤生长慢
已经有3人回复
» 抢金币啦!回帖就可以得到:
查看全部散金贴
2026年江西师范大学药学院陈芬儿院士课题组招收智能药学博士生
+
2
/136
电子科技大学(深圳)高等研究院陈明豪课题组招收推免硕士研究生
+
1
/82
温州医科大学吴平课题组招聘博士后,年薪≥50W/年
+
1
/80
从137到p₃₃:精细结构常数的素数起源—86年未解之谜
+
1
/75
北京-89175-事业单位-诚征女友
+
1
/63
树脂真空干燥除水时的泡沫问题
+
2
/42
西北工业大学物理科学与技术学院-诚聘【AI与光学交叉方向】博士后
+
1
/31
坐标南京
+
1
/25
香港理工大学汪志勋课题组招收2026年9月入学全奖博士生一名
+
1
/14
深圳理工大学-湖南大学项目招收钙钛矿方向博士生
+
1
/12
2026年北京化工大学化学工程学院程元徽教授团队博士研究生招生-考核
+
1
/6
浙江大学长江学者特聘教授黄飞鹤招聘博士后(年薪35万+)
+
1
/5
宁夏大学2026博士招生
+
1
/5
双一流高校南林化学工程学院-国家级青年人才团队招2026级博士(最后一波)
+
1
/5
我用DeepSeek和豆包写了三个月论文,最后发现真正好用的不是它们
+
1
/3
上海交通大学陈向洋计算化学课题组诚聘2027级博士研究生
+
1
/3
QS百强名校招收“AI赋能固废低碳热转化”方向博士(免统考/直博友好)
+
1
/3
大湾区大学-中山大学联培博士招生(电磁方向)
+
1
/2
土木工程--陆工大2026年第二批博士研究生补充招录
+
2
/2
985院长团队!(大连理工,光电融合芯片方向) 招收2026秋入学博士生 5月初截止!
+
1
/1
1楼
2011-05-06 15:34:28
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
zzahkj
木虫
(著名写手)
应助: 42
(小学生)
金币: 1931.7
帖子: 1522
在线: 465.8小时
虫号: 964751
引用回帖:
Originally posted by
雷小雨
at 2011-05-08 11:37:00:
没有运行环境,读了一下代码
在while循环里面,第1次for循环生成pPointCol的第1个点
第2次for循环生成pPointCol的第1~2个点
第3次for循环生成pPointCol的第1~3个点
第N次for循环生成pPointCol的第1~N个点
...
呵呵 是啊 我搞错了 我现在把for循环去掉 速度大概是6000多个点完全生成要二十多分钟,这个速度是快是慢呢,由于我做的是预警系统,十分钟别人都嫌慢,不知还有没有提高速度的方法?
赞
一下
回复此楼
高级回复
10楼
2011-05-08 12:46:52
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
查看全部 11 个回答
efeng522
木虫
(初入文坛)
应助: 0
(幼儿园)
金币: 2234.8
帖子: 38
在线: 58.3小时
虫号: 1082724
★
小木虫(金币
+0.5
):给个红包,谢谢回帖
这个要看你数据量的大小,如果数据量不大,那么这个效率肯定是不正常的;如果数据量确实有这么大,你就要考虑是否有必要一次性生成这么多数据,或者在这么大的空间范围内生成数据。
VB不熟,所以代码没细看,只是泛泛而谈,抛砖引玉
赞
一下
(1人)
回复此楼
2楼
2011-05-06 16:07:05
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
zzahkj
木虫
(著名写手)
应助: 42
(小学生)
金币: 1931.7
帖子: 1522
在线: 465.8小时
虫号: 964751
引用回帖:
Originally posted by
efeng522
at 2011-05-06 16:07:05:
这个要看你数据量的大小,如果数据量不大,那么这个效率肯定是不正常的;如果数据量确实有这么大,你就要考虑是否有必要一次性生成这么多数据,或者在这么大的空间范围内生成数据。
VB不熟,所以代码没细看,只是 ...
数据量还是非常大的,必须得一次性生成这么多数据!我也觉得这个效率不正常,可没有很好的办法解决?
赞
一下
回复此楼
3楼
2011-05-06 16:25:22
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
xiangling1
金虫
(正式写手)
应助: 2
(幼儿园)
金币: 709.2
帖子: 339
在线: 80.9小时
虫号: 1234309
★
小木虫(金币
+0.5
):给个红包,谢谢回帖
zzahkj(金币+10): 2011-05-07 15:43:13
后面的循环可以优化,你把For循环提出来
你把三个属性封装一下,循环一次,把三个属性赋进去值
你这样做出来的点的属性值是不对的
你多写几个函数,把这段代码分解开一定不要循环里面再有循环
速度会增加的
赞
一下
(1人)
回复此楼
4楼
2011-05-06 21:31:46
已阅
回复此楼
关注TA
给TA发消息
送TA红花
TA的回帖
查看全部 11 个回答
如果回帖内容含有宣传信息,请如实选中。否则帐号将被全论坛禁言
普通表情
龙
兔
虎
猫
高级回复
(可上传附件)
百度网盘
|
360云盘
|
千易网盘
|
华为网盘
在新窗口页面中打开自己喜欢的网盘网站,将文件上传后,然后将下载链接复制到帖子内容中就可以了。
信息提示
关闭
请填处理意见
关闭
确定