明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1300|回复: 3

再问一个问题:)

[复制链接]
发表于 2004-10-4 16:51:00 | 显示全部楼层 |阅读模式
我的程序主要过程是:打开若干个DXF文件,将其中的线一一按原坐标复制到新的dwg文件中,但是这其中总是不稳定,有时会在原点处加几个识别不了的文字,显示问几个问号.下面是复制时用的命令: ThisDrawing.Application.Documents(lst2.List(I)).SendCommand Chr(3) + Chr(3) + "._copyclip all " + Chr(32) + Chr(32) ' str + Chr(59)
ThisDrawing.Application.Documents(MStrPrjName + "坡面.DWG").SendCommand Chr(3) + Chr(3) + "._pasteorig " '粘贴到原坐标系
ThisDrawing.Application.Documents(lst2.List(I)).Close , False '关闭原文件
ThisDrawing.SendCommand Chr(3) + Chr(3) + "Z E "
发表于 2004-10-4 19:03:00 | 显示全部楼层
用CopyObjects方法
发表于 2004-10-5 13:47:00 | 显示全部楼层
本帖最后由 作者 于 2004-10-6 12:53:39 编辑

图元很多的情况下,copyObjects 方法效率其实比较低的,可以试试WBlock方法与 Explode方法相结合。
 楼主| 发表于 2004-10-5 14:49:00 | 显示全部楼层
还好,俺的程序就是将一些线粘贴到一张新图中去,用copyObjects简单容易 实现 Dim Doc1 As AcadDocument, Doc2 As Object
Dim ssetObj As AcadSelectionSet
Dim objCollection() As AcadEntity
Set Doc1 = Application.Documents(lst2.List(I))'有多个DXF文件 DeleAllSelect
Set ssetObj = ThisDrawing.SelectionSets.Add("ybssa")
Set ssetObj = Doc1.ActiveSelectionSet
ssetObj.Select acSelectionSetAll If ssetObj.count > 0 Then
ReDim objCollection(ssetObj.count - 1) As AcadEntity
For K = 0 To ssetObj.count - 1
Set objCollection(K) = ssetObj(K)
Next K Set Doc2 = Documents("D:\mydwg.DWG")
Doc1.CopyObjects objCollection, Doc2.ModelSpace
End If
ThisDrawing.Application.Documents(lst2.List(I)).Close , False
ThisDrawing.Application.ZoomExtents
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-28 02:28 , Processed in 0.198866 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表