明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2907|回复: 4

如何求填充边界,请教大侠

[复制链接]
发表于 2004-4-5 08:22:00 | 显示全部楼层 |阅读模式
请问用哪个函数可以来求填充边界,并用多义块画出来?
 楼主| 发表于 2004-4-6 08:16:00 | 显示全部楼层
是多义线,不是多义块,打错字了


我查了不少书,填充边界就是很难找到,哪位能帮一下吗
 楼主| 发表于 2004-4-11 17:26:00 | 显示全部楼层
有人给点提示也好呀!!!!!
发表于 2004-4-11 19:24:00 | 显示全部楼层
以下程序只对于那些边界还关联着的填充图案有效。如果删除边界后还需要取得边界,则需要使用LISP的方法。
  1. Sub HatchBound()
  2.        Dim Ent As AcadEntity
  3.        Dim Pnt As Variant
  4.        Dim Hat As AcadHatch
  5.        Dim LoopNum As Integer
  6.        Dim i As Integer
  7.        Dim LoopObjs As Variant
  8.        Dim j As Integer
  9.        'On Error Resume Next
  10.        Do
  11.                ThisDrawing.Utility.GetEntity Ent, Pnt, vbCr & "选择填充图案:"
  12.                If Err.Number <> 0 Then Exit Sub
  13.                If Ent.ObjectName = "AcDbHatch" Then Exit Do
  14.        Loop
  15.        Set Hat = Ent
  16.        LoopNum = Hat.NumberOfLoops
  17.        For i = 0 To LoopNum - 1
  18.                Debug.Print "第" & i & "个环的对象:"
  19.                Hat.GetLoopAt i, LoopObjs
  20.                For j = 0 To UBound(LoopObjs)
  21.                        Debug.Print LoopObjs(j).ObjectName
  22.                Next j
  23.        Next i
  24. End Sub
发表于 2004-4-12 13:12:00 | 显示全部楼层
给你个函数参考 '外轮廓
Public Function OutBoundary(Point1 As Variant, Point2 As Variant) As AcadLWPolyline
On Error Resume Next
Dim PointToString As String
PointToString = Trim(Str(Point1(0))) & "," & Trim(Str(Point1(1))) '转换点为字符
Dim PrevTotal As Long
PrevTotal = MoSpace.Count
'辅助边界
Dim AssistantBoundary As AcadLWPolyline
Dim PntList(0 To 9) As Double
PntList(0) = Point2(0): PntList(1) = Point2(1)
PntList(2) = Point2(0): PntList(3) = Point2(3)
PntList(4) = Point2(2): PntList(5) = Point2(3)
PntList(6) = Point2(2): PntList(7) = Point2(0)
PntList(8) = Point2(0): PntList(9) = Point2(1)
Set AssistantBoundary = MoSpace.AddLightWeightPolyline(PntList)
'AcadDoc.SetVariable "NOMUTT", 1 '禁止不确定的消息反馈
AcadDoc.SendCommand "-boundary" & vbCr & PointToString & vbCr & vbCr '调用BOUNDARY命令获取一点的边界
'AcadDoc.SetVariable "NOMUTT", 0 '恢复普通模式的消息反馈
'Sleep (1000)
If MoSpace.Count > PrevTotal Then
Set OutBoundary = MoSpace.Item(MoSpace.Count - 2)
End If
MoSpace.Item(MoSpace.Count - 1).Delete '删除辅助边界
AssistantBoundary.Delete
End Function
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-28 06:34 , Processed in 0.157699 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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