田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 11 48
     12
3456789
10111213141516
17181920212223
24252627282930


站点统计

最新评论



VBA平法梁配筋率分析 AutoCAD VBA 单行文字编辑器
未知 将Solid实体转换成图案填充   [ 日期:2008-11-17 ]   [ 来自:本站原创 ]  HTML
'将Solid实体转换成图案填充
Sub Solid2Hatch()
    Dim Obj As Object
    Dim SSet As AcadSelectionSet
    'On Error Resume Next
    Set SSet = CreateSelectionSet("XXX")
    '定义过滤机制
    Dim filterType(0) As Integer
    Dim filterData(0) As Variant
    filterType(0) = 0
    filterData(0) = "Solid"
    SSet.SelectOnScreen filterType, filterData
    '对选择集中的对象进行操作
    Dim PS As Variant
    Dim PL As AcadLWPolyline
    Dim P2() As Double
    For Each Obj In SSet
        PS = Obj.Coordinates
        ReDim P2(7)
        P3ToP2_2 PS, P2
        Set PL = ThisDrawing.ModelSpace.AddLightWeightPolyline(P2)
        PL.color = acRed
        PL.Closed = True
        TC PL
        Obj.Delete
    Next
End Sub
'3D坐标组,转换成2D坐标组
'solid 四个顶点中的第三个和第四个交换
Function P3ToP2_2(P3 As Variant, ByRef P2() As Double)
    Dim i As Long
    i = UBound(P2)
    Dim j As Long
    For j = 0 To i Step 2
        P2(j) = P3(j / 2 * 3)
        P2(j + 1) = P3(j / 2 * 3 + 1)
    Next j
    Dim temp1 As Double, temp2 As Double
    temp1 = P2(6): temp2 = P2(7)
    P2(6) = P2(4): P2(7) = P2(5)
    P2(4) = temp1: P2(5) = temp2
End Function
'3D坐标组,转换成2D坐标组
Function P3ToP2(P3 As Variant, ByRef P2() As Double)
    Dim i As Long
    i = UBound(P2)
    Dim j As Long
    For j = 0 To i Step 2
        P2(j) = P3(j / 2 * 3)
        P2(j + 1) = P3(j / 2 * 3 + 1)
    Next j
End Function


[本日志由 tiancao1001 于 2008-11-17 02:16 PM 编辑]


引用这个评论 tiancao1001 于 2008-11-17 11:55 AM 发表评论: 
Function TC(e As AcadEntity)
    On Error Resume Next
       '填充面域
    Dim TC_Entity(0 To 0) As AcadEntity
    Dim TC1 As AcadHatch
    Dim TC_Name As String
    Dim TC_Type As Long
    Dim TC_Associativity As Boolean
    TC_Name = "SOLID"
    TC_Type = 0
    TC_Associativity = True
    
    Set TC1 = ThisDrawing.ModelSpace.AddHatch(TC_Type, TC_Name, TC_Associativity)
    
    Set TC_Entity(0) = e
    TC1.AppendInnerLoop (TC_Entity)
    TC1.Evaluate
    'ThisDrawing.SetVariable "HPDRAWORDER", 1
End Function

发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:1*7=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©