乐筑天下

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

[求助]各位大虾:可以用VBA对已有的图形实现自动填充吗?

[复制链接]

2

主题

6

帖子

1

银币

初来乍到

Rank: 1

铜币
14
发表于 2008-7-25 15:49:00 | 显示全部楼层 |阅读模式
我知道在模型空间里,用绘图菜单的图案填充可以选择一个对象很方便的进行图案填充。我也知道在VBA里可以用HATCH,加上outerloop和innerloop就可以创建填充的图形。我的问题是:既然在模型空间里有这么方便的实现填充的方法,那么有没有相应的VBA语句可以同样的实现呢?
回复

使用道具 举报

2

主题

6

帖子

1

银币

初来乍到

Rank: 1

铜币
14
发表于 2008-7-25 15:55:00 | 显示全部楼层
自己顶一下!请有经验的各位帮帮忙哈,在网上和书上查无所获希望能在这里聆听教诲
回复

使用道具 举报

2

主题

6

帖子

1

银币

初来乍到

Rank: 1

铜币
14
发表于 2008-7-25 16:24:00 | 显示全部楼层
在线等啊,请高手帮忙
回复

使用道具 举报

1

主题

113

帖子

6

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
117
发表于 2008-7-25 21:27:00 | 显示全部楼层

Sub TestHatch()
    '外边界和内边界
    Dim OuterLoop(0) As Object 'AcadEntity
    Dim innerLoop(0) As Object 'AcadEntity
   
    ' 为填充创建外边界边界
    Set OuterLoop(0) = CreateCircle
   
    ' 为填充创建内边界边界
    Set innerLoop(0) = CreateCircle(2.5)
   
    Dim HatchObj As Object
    Dim PatternName As String
    Dim PatternType As Long
    Dim bAssociativity As Boolean
        
    ' 定义填充
    PatternName = "ANSI31"
    PatternType = 0
    bAssociativity = True
        
    ' 在模型空间中创建关联填充
    Set HatchObj = ThisDrawing.ModelSpace.AddHatch(PatternType, PatternName, bAssociativity)
        
    HatchObj.AppendOuterLoop (OuterLoop)
    HatchObj.AppendInnerLoop (innerLoop)
        
    HatchObj.PatternScale = 0.25
    HatchObj.Lineweight = acLnWtByLwDefault
    HatchObj.Color = acByBlock
    HatchObj.Evaluate
End Sub
' 创建圆
Public Function CreateCircle(Optional Radius As Double = 3) As Object 'AcadCircle
    Dim ptBase(0 To 2) As Double
    ptBase(0) = 0: ptBase(1) = 0: ptBase(2) = 0
    Set CreateCircle = ThisDrawing.ModelSpace.AddCircle(ptBase, Radius)
End Function
回复

使用道具 举报

2

主题

6

帖子

1

银币

初来乍到

Rank: 1

铜币
14
发表于 2008-7-26 12:33:00 | 显示全部楼层
谢谢wylong!
不过您这个方法还是用的是外界和内界的hatch 方法。我的问题是:是不是用VBA填空只有这种方法了?有没有利用已有图形,像在模型界面一样,直接填充的方法?
不管怎么样,谢谢您。
回复

使用道具 举报

29

主题

503

帖子

8

银币

中流砥柱

Rank: 25

铜币
619
发表于 2008-7-26 12:57:00 | 显示全部楼层
Sub test()
Dim pl As AcadEntity
Dim pt As Variant
ThisDrawing.Utility.GetEntity pl, pt
Dim ht As AcadHatch
Set ht = ThisDrawing.ModelSpace.AddHatch(acHatchObject, "solid", True)
Dim ot(0) As AcadEntity
Set ot(0) = pl
ht.AppendOuterLoop (ot)
End Sub
回复

使用道具 举报

120

主题

326

帖子

7

银币

中流砥柱

Rank: 25

铜币
806
发表于 2008-7-30 09:41:00 | 显示全部楼层

此种方法简单实用,奖励。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-7-4 06:39 , Processed in 0.745610 second(s), 67 queries .

© 2020-2025 乐筑天下

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