明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4708|回复: 12

如何删除一条被打断的直线?

  [复制链接]
发表于 2005-4-6 17:37:00 | 显示全部楼层 |阅读模式
有一条直线与很多直线相交,在交点处均被打断,不知有没有方法删除这条被打断的直线,一段一段的删好像太费力了,恳请高手指点!先谢过了
发表于 2005-4-6 21:22:00 | 显示全部楼层
是程序打断的还是已经打断的?
 楼主| 发表于 2005-4-7 09:34:00 | 显示全部楼层
是程序打断的,程序搜索到轮廓后,把与边界相交的线条都打断了。因为我两个图形迭加,在交点处需要打断,然后我删除被覆盖的线条。现在有点迷茫,不晓得咋删,恳请高手指点,谢谢!
发表于 2005-4-7 11:24:00 | 显示全部楼层
你的程序呢?既然是序打断的怎么会迷茫呢?
 楼主| 发表于 2005-4-7 19:41:00 | 显示全部楼层
本帖最后由 作者 于 2005-4-7 21:37:05 编辑

Public Sub BreakHide() Dim Pnt1 As Variant
Dim det1 As String,det2 As String
Dim EntObj1 As AcadEntity, EntObj2 As AcadEntity
AcadDoc.Utility.GetEntity EntObj1, Pnt1, "选择图元:"

Dim SS As AcadSelectionSet
Set SS = AcadDoc.ActiveSelectionSet
SS.SelectOnScreen '获得相交实体交点,即打断点
Dim lspPnt As String
Dim IntPnt As Variant
Dim IntPnt1(0 To 2) As Double
Dim n As Integer
For Each EntObj2 In SS
On Error Resume Next
IntPnt = EntObj2.IntersectWith(EntObj1, acExtendNone) If IsArray(IntPnt) Then
For n = 0 To UBound(IntPnt) Step 3
IntPnt1(0) = IntPnt(n + 0)
IntPnt1(1) = IntPnt(n + 1)
IntPnt1(2) = IntPnt(n + 2)
lspPnt = axPoint2lspPoint(IntPnt1)
det2 = lspPnt
AcadDoc.SendCommand "_break" & vbCr & det2 & vbCr & lspPnt & vbCr
Next
End If
Next End Sub 此法可以打断和一条直线相交的直线,但是好像断得没啥规律,交点是断了,断的不一定都是直线上的
发表于 2005-4-7 22:58:00 | 显示全部楼层
这几天怎么看到的都是调用SendCommand的,晕


把交点排序,再用AddLine顺次连接
发表于 2005-4-8 08:43:00 | 显示全部楼层
请问这个axPoint2lspPoint(IntPnt1)是什么意思?? det2 = lspPnt
AcadDoc.SendCommand "_break" & vbCr & det2 & vbCr & lspPnt & vbCr
那这里面不是一样的吗??? 我是来学习的,呵呵,请教
 楼主| 发表于 2005-4-8 08:57:00 | 显示全部楼层
那是因为直接用lspPnt作为打断点,系统是打不断的,因为Sendcommand有很多问题,不推荐使用,我也是实在没得办法啊!!


谢过飞狐版主!
发表于 2005-4-8 11:09:00 | 显示全部楼层
 楼主| 发表于 2005-4-8 12:39:00 | 显示全部楼层
这个方法不错,就是运算工作量多些,其实就是重新画了一遍了,呵呵


谢谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 22:43 , Processed in 0.171297 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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