找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1192|回复: 12

[编程申请]:申请批量scale的程序,请高手帮忙!

[复制链接]
发表于 2004-5-4 18:18:58 | 显示全部楼层 |阅读模式

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

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

×
那位兄弟能帮忙编一个程序,满足以下效果:
1.执行命令后所选物体直接放大1.5倍,不提示基点和比例因子
2.执行命令后若选择多个块物体,这些块物体以各自的基点缩放1.5倍,不提示基点和比例因子

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

使用道具 举报

 楼主| 发表于 2004-5-5 14:23:34 | 显示全部楼层
最初由 自由的鱼 发布
[B]各自基点是以块中心吗? [/B]


是啊!老兄你会啊!能否帮忙编一个程序啊?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

使用道具 举报

发表于 2004-5-7 17:58:24 | 显示全部楼层
这个程序用在你这张图上正好,:)
第一个是全选,第二个是屏选

Option Explicit

Sub allscale()
Dim ent As AcadEntity
Dim sset As AcadSelectionSet
Dim Ftype(0) As Integer
Dim Fdata(0) As Variant
Dim i As Integer
For i = 0 To ThisDrawing.SelectionSets.Count - 1
    ThisDrawing.SelectionSets.Item(i).Clear
    ThisDrawing.SelectionSets.Item(i).Delete
Next

Ftype(0) = 0
Fdata(0) = "INSERT"

Dim minpnt As Variant
Dim maxpnt As Variant
Dim cpnt(0 To 2) As Double


Set sset = ThisDrawing.SelectionSets.Add("TKsel")
sset.Select acSelectionSetAll, , , Ftype, Fdata
For Each ent In sset
ent.GetBoundingBox minpnt, maxpnt
cpnt(0) = (minpnt(0) + maxpnt(0)) / 2
cpnt(1) = (minpnt(1) + maxpnt(1)) / 2
cpnt(2) = 0
ent.ScaleEntity cpnt, 1.5
Next

End Sub


Sub choosescale()
Dim ent As AcadEntity
Dim sset As AcadSelectionSet
Dim Ftype(0) As Integer
Dim Fdata(0) As Variant
Dim i As Integer
For i = 0 To ThisDrawing.SelectionSets.Count - 1
    ThisDrawing.SelectionSets.Item(i).Clear
    ThisDrawing.SelectionSets.Item(i).Delete
Next

Ftype(0) = 0
Fdata(0) = "INSERT"

Dim minpnt As Variant
Dim maxpnt As Variant
Dim cpnt(0 To 2) As Double


Set sset = ThisDrawing.SelectionSets.Add("TKsel")
sset.SelectOnScreen Ftype, Fdata
For Each ent In sset
ent.GetBoundingBox minpnt, maxpnt
cpnt(0) = (minpnt(0) + maxpnt(0)) / 2
cpnt(1) = (minpnt(1) + maxpnt(1)) / 2
cpnt(2) = 0
ent.ScaleEntity cpnt, 1.5
Next

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

使用道具 举报

 楼主| 发表于 2004-5-11 12:59:07 | 显示全部楼层
我是低手,不知道你的这个程序怎么用。好像只是子程序,不知道怎么加载啊!大哥能不能说得明白些?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-5-11 21:29:50 | 显示全部楼层
在CAD的命令行中输入vbaide,把我上面的代码帖进去,然后在命令行输入VBARUN,选择需要执行的过程就可以了!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-5-12 12:59:46 | 显示全部楼层
长老真是个好人啊!多谢多谢!
请问长老:想学cad编程和二次开发需要从哪里开始学起?有什么好方法没有?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-5-12 21:17:49 | 显示全部楼层
先买一本入门的书,按照上面的例子练,入门之后就在论坛多看看别人的程序,慢慢来!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-5-12 23:13:08 | 显示全部楼层
wcs下使用
[php]
(defun c:test ()
  (vl-cmdf ".undo" "be")
  (setq ss (ssget) sc (getdist "\n缩放比例:") i -1)
  (repeat (sslength ss)
    (vl-cmdf ".scale" (setq e(ssname ss (setq i(1+ i)))) "" (trans (cdr (assoc 10 (entget e))) 0 1) )
(vl-cmdf ".undo" "e")
)[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2008-4-14 00:37:18 | 显示全部楼层

  1. (defun C:TT ( / ss sc i e)
  2.     (while (setq SS (ssget))
  3.         (if (setq SC (getdist "\n缩放比例:"))
  4.             (progn
  5.                 (setq I 0)
  6.                 (repeat        (sslength SS)
  7.                     (command "_.scale"
  8.                              (setq e(ssname SS I))
  9.                              ""
  10.                              (trans (cdr (assoc 10 (entget E))) 0 1)
  11.                              SC
  12.                     )
  13.                     (setq I (1+ I))
  14.                 )
  15.             )
  16.         )
  17.     )
  18.     (princ)
  19. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-17 21:53 , Processed in 0.415229 second(s), 56 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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