找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 765|回复: 4

[密技]:CAD中输入带圈的数字的办法

[复制链接]
发表于 2006-9-18 12:44:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
 *运行宏 数变编号,加圆圈
Public Sub bh()
ThisDrawing.Utility.Prompt "请选择要加圆圈的文本" + vbCrLf
Dim sset As AcadSelectionSet
Dim gp(0) As Integer
Dim data(0) As Variant
If ThisDrawing.SelectionSets.Count <> 0 Then
For i = 0 To ThisDrawing.SelectionSets.Count - 1
Set sset = ThisDrawing.SelectionSets.Item(i)
sset.Delete
Next
Else
End If
Set sset = ThisDrawing.SelectionSets.Add("ss")
AcadApplication.Visible = True
gp(0) = 0
data(0) = "*Text"
123: sset.SelectOnScreen gp, data
Dim min As Variant
Dim max As Variant
Dim o(0 To 2) As Double
Dim cir As AcadCircle
If sset.Count < 1 Then
MsgBox "没选文本"
GoTo 123
End If
For i = 0 To sset.Count - 1
sset(i).GetBoundingBox min, max
o(0) = (min(0) + max(0)) / 2
o(1) = (min(1) + max(1)) / 2
o(2) = 0
ThisDrawing.ModelSpace.AddCircle o, 4.5
Next
End Sub
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2006-9-18 12:57:14 | 显示全部楼层
如何运行宏呀?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-9-20 10:01:56 | 显示全部楼层
这个东东好用么??象是带属性的文本,轴线上用的那种??
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-9-20 11:06:17 | 显示全部楼层
好用吗
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 111个

财富等级: 日进斗金

发表于 2006-9-20 15:24:35 | 显示全部楼层
试试这个

  1. ;;;by yshf
  2. (defun c:cc()
  3.    (vl-load-com)
  4.    (if (progn (Prompt "\n请选择要加圆圈的文本")
  5.               (setq ssa (ssget '((0 . "*TEXT")))))
  6.        (while (setq ent (ssname ssa 0))
  7.           (vla-getboundingbox (vlax-ename->vla-object ent) 'minpt 'maxpt)
  8.           (setq con (mapcar 'vlax-safearray->list (list minpt maxpt))
  9.                 po  (mapcar '* '(0.5 0.5) (mapcar '+ (car con) (cadr con)))
  10.                 ssa (ssdel ent ssa)
  11.           )
  12.           (entmake (list '(0 . "CIRCLE") (cons 10 po)
  13.                           (cons 40 (distance po (car con)))))  
  14.        )
  15.        (alert "没有选择到任何文本!")
  16.    )
  17.    (princ)
  18. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-21 17:45 , Processed in 0.437108 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表