乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 54|回复: 3

[求助]怎样把已有的图形加入自己新建的块中?

[复制链接]

5

主题

6

帖子

1

银币

初来乍到

Rank: 1

铜币
26
发表于 2004-3-12 20:09:00 | 显示全部楼层 |阅读模式
是内部块还是外部块?
回复

使用道具 举报

21

主题

166

帖子

7

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
250
发表于 2004-3-12 21:56:00 | 显示全部楼层
可使用.CopyObjects方法。
回复

使用道具 举报

158

主题

2315

帖子

10

银币

顶梁支柱

Rank: 50Rank: 50

铜币
2951
发表于 2004-3-13 17:34:00 | 显示全部楼层
针对你的程序改了一下.如下: Sub join()
                         Dim ss As AcadSelectionSet
                         Dim po(0 To 2) As Double
                         
                         On Error Resume Next
                         
                         po(0) = 0
                         po(1) = 0
                         po(2) = 0
                         
                         'ThisDrawing.Blocks.Item("ok").Delete
                         Dim bk As AcadBlock
                         
                         Set bk = ThisDrawing.Blocks.Add(po, "tempb")
                         
                         Set ss = ThisDrawing.SelectionSets.item("ssss")
                         '------------------------------------------------
                         If Err Then
                         Err.Clear
                         Set ss = ThisDrawing.SelectionSets.Add("ssss")
                         End If
                         '------------------------------------------------
                         
                         Dim ftype(0) As Integer
                         Dim fdata(0) As Variant
                         Dim i As Long
                         
                         ftype(0) = 8
                         fdata(0) = "layer"
                         ss.Select acSelectionSetAll, , , ftype, fdata                 '过滤
                         ReDim retVal(0 To ss.count - 1) As AcadEntity
                         For i = 0 To ss.count - 1
                                                         Set retVal(i) = ss.item(i)
                         Next
                         
                         ''------------------------------------------------过滤对象
                         'Dim retVal(), Ent As AcadEntity
                         '
                         '
                         'Dim i As Integer
                         'i = 0
                         '
                         '                         ReDim retVal(0 To ss.count - 1)
                         '
                         '                         For Each Ent In ss
                         '
                         '                                                         If (Ent.layer = "layer") Then
                         '                                                                                         Set retVal(i) = Ent
                         '                                                                                         i = i + 1
                         '                                                         End If
                         '
                         '                         Next
                         '                         ReDim Preserve retVal(0 To i - 1)
                         
                         '------------------------------------------------
                         
                         ThisDrawing.CopyObjects retVal, bk         '         在这里出问题了
                         Erase retVal
End Sub
回复

使用道具 举报

5

主题

6

帖子

1

银币

初来乍到

Rank: 1

铜币
26
发表于 2004-4-8 22:02:00 | 显示全部楼层
关键是在定义数组上,这样写就没有问题:
Dim retVal() As AcadEntity, Ent As AcadEntity
注意:一般不要这样写:
Dim retVal() , Ent As AcadEntity
这样写的话,第一个变量会被定义成Variant,所以会造成CopyObjects时传递的不是图元数组。
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-15 16:18 , Processed in 0.384893 second(s), 60 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表