田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

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


站点统计

最新评论



AutoCAD 绘图历史成灰色 计算器
未知 VB.net 在AutoCAD中拖拽一个“大括号"   [ 日期:2012-03-14 ]   [ 来自:本站原创 ]  HTML
'大括号
Public Class 大括号
    ' 从DrawJig类继承.
    Inherits DrawJig
    ' 拖拽的对象.
    Dim Ent As Polyline
    ' 拖拽指向的点.
    Private StartPt, EndPt As Point3d
    '大括号
    <CommandMethod("DKH")> _
    Public Sub DKH()
        'On Error Resume Next
        GetPoint(StartPt)
        Dim acCurDb As Database = HostApplicationServices.WorkingDatabase
        Dim acEditor As Editor = Application.DocumentManager.MdiActiveDocument.Editor
        ' 开始拖拽.
        Dim resJig As PromptResult = acEditor.Drag(Me)
        If resJig.Status = PromptStatus.OK Then
            '确定后添加对象
            AddEnt(Ent)
        End If
    End Sub
    ' Sampler函数用于检测用户的输入.
    Protected Overrides Function Sampler(ByVal Prompts As JigPrompts) As SamplerStatus
        ' 定义一个点拖动交互类.
        Dim optJigPoint As New JigPromptPointOptions(vbCrLf & "请指定插入点:")
        ' 设置拖拽光标类型.
        optJigPoint.Cursor = CursorType.RubberBand
        ' 设置拖动光标基点.
        optJigPoint.BasePoint = StartPt
        optJigPoint.UseBasePoint = True
        ' 用AcquirePoint函数得到用户输入的点.
        Dim resJigPoint1 As PromptPointResult = Prompts.AcquirePoint(optJigPoint)
        Dim curPt As Point3d = resJigPoint1.Value
        If curPt <> EndPt Then
            '折断线绘制*******************************************************
            '
            '                         ∧
            '    ------------------- /  \ ---------------------- 
            '   /                                               \
            '                         P3
            '
            '    P1               P2       P4            P5
            '   P0                                          P6
            ' 
            Dim L As Double = StartPt.DistanceTo(curPt)
            Dim A As Double = P2P_AngleByVBA(StartPt.ToArray, curPt.ToArray)
            Dim Pc As Point3d = New Point3d((StartPt.X + curPt.X) / 2, (StartPt.Y + curPt.Y) / 2, 0)
            Dim Pi As Double = System.Math.PI
            Ent = New Polyline
            Dim Temp As Point3d = StartPt
            Ent.AddVertexAt(0, P32(Temp), 0, 0, 0)                      'p0
            Temp = GetPointAR(Temp, L / 10, A * 180 / Pi - 45)
            Ent.AddVertexAt(1, P32(Temp), 0, 0, 0)                      'p1
            Temp = GetPointAR(Temp, 0.359 * L, A * 180 / Pi)
            Ent.AddVertexAt(2, P32(Temp), 0, 0, 0)                      'p2
            Temp = GetPointAR(Temp, L / 10, A * 180 / Pi - 45)
            Ent.AddVertexAt(3, P32(Temp), 0, 0, 0)                      'p3
            Temp = GetPointAR(Temp, L / 10, A * 180 / Pi + 45)
            Ent.AddVertexAt(4, P32(Temp), 0, 0, 0)                      'p4
            Temp = GetPointAR(Temp, 0.359 * L, A * 180 / Pi)
            Ent.AddVertexAt(5, P32(Temp), 0, 0, 0)                      'p5
            Temp = GetPointAR(Temp, L / 10, A * 180 / Pi + 45)
            Ent.AddVertexAt(6, P32(Temp), 0, 0, 0)                      'p6
            Ent.Highlight()
            ' 保存当前点.
            EndPt = curPt
            Return SamplerStatus.OK
        Else
            Return SamplerStatus.NoChange
        End If
    End Function
    ' WorldDraw函数用于刷新屏幕上显示的图形.
    Protected Overrides Function WorldDraw(ByVal Draw As WorldDraw) As Boolean
        ' 刷新画面.
        Draw.Geometry.Draw(Ent)
        Return True
    End Function
End Class


按此在新窗口打开图片


[本日志由 tiancao1001 于 2012-03-14 02:53 PM 编辑]


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

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

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