乐筑天下

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

vba cad合并多段线

[复制链接]

3

主题

10

帖子

3

银币

初来乍到

Rank: 1

铜币
22
发表于 2012-5-10 09:54:00 | 显示全部楼层 |阅读模式
在网上搜集合并多段线的代码,运行了,还是合并不了,估计问题出在选择对象上,希望大家指导下:
' 转换多个图元的函数
Public Function axSSet2lspEnts(ByVal SSet As AcadSelectionSet) As String
    If SSet.Count = 0 Then Exit Function
    Dim entHandle As String
    Dim strEnts As String
    entHandle = SSet.Item(0).Handle
    strEnts = "(handent " & Chr(34) & entHandle & Chr(34) & ")"
    If SSet.Count > 1 Then
        Dim i As Integer
        For i = 1 To SSet.Count - 1
            entHandle = SSet.Item(i).Handle
            strEnts = strEnts & vbCr & "(handent " & Chr(34) & entHandle & Chr(34) & ")"
        Next i
    End If
    axSSet2lspEnts = strEnts
End Function
' 连接多段线
Public Function EditPline(ByVal pt1 As Variant, ByVal pt2 As Variant) As AcadPolyline
On Error Resume Next
Dim det As Variant
Dim FilterType As Integer
Dim FilterData As Variant
FilterType = 0                                   '按类型选择
FilterData = "Polyline"
Dim SSet As AcadSelectionSet
    If Not IsNull(ThisDrawing.SelectionSets.Item("PLineSet")) Then
        Set SSet = ThisDrawing.SelectionSets.Item("PLineSet")
        SSet.Delete
    End If
    Set SSet = ThisDrawing.SelectionSets.Add("PLineSet")
SSet.Delete
    SSet.Select acSelectionSetCrossing, pt1, pt2, FilterType, FilterData
    det = axSSet2lspEnts(SSet)
    ' 使用SendCommand听后方法完成连接操作
    ThisDrawing.SendCommand "_PEDIT" & vbCr & "M" & vbCr & det & vbCr & "J" & vbCr & det & "0.000" & vbCr & vbCr
End Function
回复

使用道具 举报

3

主题

10

帖子

3

银币

初来乍到

Rank: 1

铜币
22
发表于 2012-5-11 15:10:00 | 显示全部楼层
自己顶一下咯
回复

使用道具 举报

31

主题

227

帖子

8

银币

后起之秀

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

铜币
351
发表于 2012-5-11 16:26:00 | 显示全部楼层
strEnts = "(handent " & Chr(34) & entHandle & Chr(34) & ")"
strEnts = strEnts & vbCr & "(handent " & Chr(34) & entHandle & Chr(34) & ")" 转换过就是
strEnts = "(handent "    " entHandle "    ")"
strEnts = strEnts   回车   " (handent "   " entHandle"   ")   "
               "(handent "    " entHandle "    ")"  回车   " (handent "   " entHandle"   ")   "
是不是 "(handent "    " entHandle "    ")" 会是  " (  "handent "    " entHandle "    )" ?
回复

使用道具 举报

3

主题

10

帖子

3

银币

初来乍到

Rank: 1

铜币
22
发表于 2012-5-11 17:21:00 | 显示全部楼层
水平有限,没看懂是什么意思?
回复

使用道具 举报

3

主题

10

帖子

3

银币

初来乍到

Rank: 1

铜币
22
发表于 2012-5-11 17:24:00 | 显示全部楼层

水平有限,没看懂是什么意思?
回复

使用道具 举报

3

主题

40

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
52
发表于 2012-5-11 17:24:00 | 显示全部楼层
关注
回复

使用道具 举报

0

主题

13

帖子

2

银币

初来乍到

Rank: 1

铜币
13
发表于 2013-1-10 13:24:00 | 显示全部楼层
用  ThisDrawing.SendCommand "_PEDIT"的方式只能合并首位重合的多段线.
回复

使用道具 举报

85

主题

1175

帖子

11

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1518
发表于 2013-1-11 08:59:00 | 显示全部楼层
请参阅
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-6-29 22:30 , Processed in 3.105306 second(s), 75 queries .

© 2020-2025 乐筑天下

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