田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

站点日历
73 2024 - 12 48
1234567
891011121314
15161718192021
22232425262728
293031


站点统计

最新评论



虚拟手机安卓系统 .Net API 激活CAD窗口
未知 用DrawableOverrule 在文字下加双下划线   [ 日期:2013-06-01 ]   [ 来自:本站原创 ]  HTML
Imports Autodesk.AutoCAD.ApplicationServices
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.EditorInput
Imports Autodesk.AutoCAD.Geometry
Imports Autodesk.AutoCAD.Runtime
Imports Autodesk.AutoCAD.GraphicsInterface
<Assembly: CommandClass(GetType(OverRule_图名.图名_Overule))> 
Namespace OverRule_图名
    Public Class 图名_Overule
        <CommandMethod("TcTuMingStart")> _
        Public Sub TcTuMingStart()
            Dim NewRule As New TuMing_OverRule()
            StartOverRule(RXClass.GetClass(GetType(DBText)), NewRule)
        End Sub
        <CommandMethod("TcTuMingEnd")> _
        Public Sub TcTuMingEnd()
            EndOverRule()
        End Sub
        Public Shared Sub StartOverRule(ByVal CADClass As RXClass, ByVal Rule As Overrule)
            Overrule.AddOverrule(CADClass, Rule, False)
            Overrule.Overruling = True
        End Sub
        Public Shared Sub EndOverRule()
            Overrule.Overruling = False
        End Sub
    End Class
    Public Class TuMing_OverRule
        Inherits DrawableOverrule
        Public Overrides Function WorldDraw(ByVal Drawable As Drawable, ByVal WD As WorldDraw) As Boolean
            On Error Resume Next
            '如果为单行文字,则进行规则重定义 
            If TypeOf Drawable Is DBText Then
                Dim DB As DBText = DirectCast(Drawable, DBText)
                If Not DB.Id.IsNull Then
                    If DB.Layer = "图名" Then '文字在"图名"图层上
                        Dim H As Double = DB.Height
                        Dim Xmin As Double = DB.GeometricExtents.MinPoint.X
                        Dim Xmax As Double = DB.GeometricExtents.MaxPoint.X
                        Dim Y As Double = DB.GeometricExtents.MinPoint.Y
                        Dim P1 As Point2d = New Point2d(Xmin, Y - H / 5)
                        Dim P2 As Point2d = New Point2d(Xmax, Y - H / 5)
                        Dim PL1 As Autodesk.AutoCAD.DatabaseServices.Polyline = New Autodesk.AutoCAD.DatabaseServices.Polyline
                        Dim PL2 As Autodesk.AutoCAD.DatabaseServices.Polyline = New Autodesk.AutoCAD.DatabaseServices.Polyline
                        PL1.AddVertexAt(0, P1, 0, H / 6, H / 6)
                        PL1.AddVertexAt(1, P2, 0, H / 6, H / 6)
                        P1 = New Point2d(Xmin, Y - 2 * H / 5)
                        P2 = New Point2d(Xmax, Y - 2 * H / 5)
                        PL2.AddVertexAt(0, P1, 0, 0, 0)
                        PL2.AddVertexAt(1, P2, 0, 0, 0)
                        PL1.WorldDraw(WD)
                        PL1.Dispose()
                        PL2.WorldDraw(WD)
                        PL2.Dispose()
                        MyBase.WorldDraw(DB, WD) '这句可以保留原对象
                    Else
                        MyBase.WorldDraw(DB, WD)
                    End If
                End If
            End If
            If Err.Number > 0 Then MsgBox(Err.Description)
            Return True
        End Function
    End Class
End Namespace


按此在新窗口打开图片

[本日志由 tiancao1001 于 2013-06-01 07:16 PM 编辑]


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

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

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