田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

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


站点统计

最新评论



Cad 快捷方式命令行参数 建筑节能计算
未知 vba 检查cad中字体高度不得小于多少   [ 日期:2007-07-06 ]   [ 来自:本站原创 ]  HTML
vba 检查cad中字体高度不得小于多少


当CAD中的文字 标注 注释 等文字过小时候,在预览时候很难发现。打印出来之后才发现,文字过小,看不清楚。晒成蓝图可能更看不清楚。

因此写了个小程序,检查文字高度不得小于多少(比如300) 如果小于300则改为300高。 
同时还有检查参照块中的文字,文字高的乘以块的放大系数,同样不得小于最小高度。

Sub CheckTextHeight()
    Dim T As AcadText
    Dim H As Long
    Dim LH As Long
    Dim Sc As Double
    Dim N As Long
    On Error Resume Next
    
    LH = 300
    LH = ThisDrawing.Utility.GetDistance(, "输入最小文字高度(" & LH & "):")
    '错误检查
    If Err.Number = -2147352567 Then                                    '用户按下Esc键,则退出.(错误代码可以通过MsgBox提示获得)
        Err.Clear
        Exit Sub
    ElseIf Err Then                                                     '如果用户按下 enter 按钮或者输入有误,使用默认值
        LH = 300
        Err.Clear
    End If

    For Each T In ThisDrawing.ModelSpace
        H = T.height
        If H < LH Then
            T.height = LH
            N = N + 1
        End If
    Next
    
    '检查图块中的文字
    '   如果参照图块中的文字高度乘以图块的放大系数小于文字的最小高度,则改为文字的最小高度除以图块的放大系数。
    Dim E As AcadEntity
    Dim B As AcadBlock
    Dim BRef As AcadBlockReference
    For Each E In ThisDrawing.ModelSpace
        If E.ObjectName = "AcDbBlockReference" Then
            MsgBox E.Name
            Set B = ThisDrawing.Blocks(E.Name)
            Set BRef = E
            For Each T In B
                H = T.height
                Sc = BRef.YScaleFactor
                If LH > H * Sc Then
                   T.height = LH / Sc
                   N = N + 1
                End If
            Next
        End If
    Next
       
    ThisDrawing.SendCommand "re" & vbLf
    '
    If N = 0 Then
        ThisDrawing.Utility.Prompt ("图中没有出现字体高度小于" & LH & "mm高的文字." & vbLf)
    Else
        ThisDrawing.Utility.Prompt ("图中共有" & N & "处字体过小,已经将其全部调整为" & LH & "mm高" & vbLf)
    End If
    
End Sub

[本日志由 田草 于 2007-07-07 09:28 PM 编辑]


引用这个评论 田草 于 2007-07-07 09:29 PM 发表评论: 
今天才知道 ModelSpace其实也是一个block(匿名块*Model_Space),[布局同样也是一个block("*Paper_Space0" or "*Paper_Space"]。

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

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

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