乐筑天下

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

旋转文字方向怎末无效

[复制链接]

7

主题

12

帖子

1

银币

初来乍到

Rank: 1

铜币
40
发表于 2004-5-26 21:47:00 | 显示全部楼层 |阅读模式
我用VBA编制的粗糙度程序,数值不能随粗糙度符号方向改变而改变,请大家帮忙看看。谢谢了!!
Sub rough()
        Dim p1(0 To 2)         As Double
        Dim p2(0 To 2)         As Double
        Dim p3(0 To 2)         As Double
         Dim p0 As Variant
         Dim a, a1, a2 As Double
         Dim h1 As Double
         Dim text As String
                 On Error Resume Next
         p0 = ThisDrawing.Utility.GetPoint(, "请输入粗糙度符号插入点:")
         a = ThisDrawing.Utility.GetAngle(, "请输入粗糙度符号旋转角:")
         text = ThisDrawing.Utility.GetString(1, vbCrLf & "请输入粗糙度符号Ra值:")
         h = ThisDrawing.Utility.GetReal("请输入粗糙度符号文本字符高度:")
         h1 = 1.4 * h / Cos(30 * 3.14159 / 180)
         p1(0) = p0(0) + 2 * h1 * Cos(60 * 3.14159 / 180 + a)
                 p1(1) = p0(1) + 2 * h1 * Sin(60 * 3.14159 / 180 + a)
                 p1(2) = 0
                 
                 p2(0) = p0(0) - h1 * Cos(60 * 3.14159 / 180 - a)
                 p2(1) = p0(1) + h1 * Sin(60 * 3.14159 / 180 - a)
                 p2(2) = 0
                 
                 p3(0) = p0(0) + h1 * Cos(60 * 3.14159 / 180 + a)
                 p3(1) = p0(1) + h1 * Sin(60 * 3.14159 / 180 + a)
                 p3(2) = 0
                 
                 Dim line1 As AcadLine
         Dim line2 As AcadLine
         Dim line3 As AcadLine
         Set line1 = ThisDrawing.ModelSpace.AddLine(p0, p2)
         Set line2 = ThisDrawing.ModelSpace.AddLine(p2, p3)
         Set line3 = ThisDrawing.ModelSpace.AddLine(p0, p1)
         ThisDrawing.Application.ZoomExtents
         
         
         Dim tobject As AcadText
         tobject = ThisDrawing.ModelSpace.AddText(text, p2, h)
         ThisDrawing.Application.ZoomExtents
         
         a2 = 180 * a / 3.14159
         If a2 > 90 And a2  270 Then
                         a1 = a - 2 * 3.14159
                 ElseIf a2 = -90 Then
                                         a1 = 3.14159 / 2
                 ElseIf a2 < 90 Then
                                         a1 = a
                                 
        End If
        tobject.Alignment = acAlignmentLeft
        tobject.Rotation = a1
        tobject.Update
                 
                 End Sub
回复

使用道具 举报

72

主题

2726

帖子

9

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3014
发表于 2004-5-27 12:32:00 | 显示全部楼层
你把它做成属性块插入不就玩了
回复

使用道具 举报

8

主题

23

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
55
发表于 2004-5-27 15:33:00 | 显示全部楼层
楼主,Rotation,应该给PI的
回复

使用道具 举报

12

主题

71

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
119
发表于 2004-5-27 16:56:00 | 显示全部楼层
错在这句(跟踪发现后面tobject是空的)tobject = ThisDrawing.ModelSpace.AddText(text, p2, h)
创建是完成了,但是没有赋给变量,而且这是不报错的.
对象赋值别忘了用Set
Set tobject = ThisDrawing.ModelSpace.AddText(text, p2, h)
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-15 17:31 , Processed in 0.347781 second(s), 60 queries .

© 2020-2025 乐筑天下

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