请教大家一个带标注的图元缩放问题,恳请出手相助!
问题同截图里面的描述,恳请大家出手帮忙一下,谢谢!!论坛里搜到以前G版写的一个代码,只能实现缩放后数值保持不变,但标注全局比例不能调整,这是G大以前写的代码:这个G版已解决
图形大小缩放,标注尺寸值不变,用于局部视图
(defun c:cs (/ ss pt ss2 flag alst)
(defun lt:ss->list (ss / en)
(vl-remove nil (mapcar '(lambda (x)
(if (= (type (setq en (cadr x))) 'ename) en)
)
(ssnamex ss)
)
)
)
(if (and (setq ss (ssget))
(setq pt (getpoint "\n指定缩放的基点: "))
)
(progn
(if (setq ss2 (ssget "_p" '((0 . "DIMENSION"))))
(progn
(setq alst (mapcar '(lambda (d)
(setq d (vlax-ename->vla-object d))
(list d (vla-get-Measurement d))
)
(lt:ss->list ss2)
)
flag T
)
)
)
(princ "\n指定缩放的比例因子: ")
(command "_.scale" ss "" pt "\\")
(if flag
(mapcar '(lambda (x / d)
(setq d (car x))
(vla-put-LinearScaleFactor d (* (/ (cadr x) (vla-get-Measurement d))
(vla-get-LinearScaleFactor d)
)
)
)
alst
)
)
)
)
(princ)
)
wangxf888 发表于 2020-4-23 21:20
请start4444老师出手帮忙再调整下代码 谢谢!
(defun c:tt5 (/ alst flag lt:ss->list pt scf ss ss2)
(defun lt:ss->list (ss / en) (vl-remove nil (mapcar '(lambda (x) (if (= (type (setq en (cadr x))) 'ename) en)) (ssnamex ss))))
(if (and (setq ss (ssget)) (setq pt (getpoint "\n指定缩放的基点: ")))
(progn
(if (setq ss2 (ssget "_p" '((0 . "DIMENSION"))))
(progn
(setq alst (mapcar '(lambda (d) (setq d (vlax-ename->vla-object d)) (list d (vla-get-Measurement d))) (lt:ss->list ss2))
flag T
)
)
)
(command "_.scale" ss "" pt "\\")
(if flag
(progn (mapcar '(lambda (x / d)(setq d (car x)) (vla-put-LinearScaleFactor d (* (/ (cadr x) (vla-get-Measurement d))(vla-get-LinearScaleFactor d)))) alst)
(setq scf (getreal (strcat "\n设定标注全局比例<当前:" (rtos (vla-get-ScaleFactor (caar alst)) 2 1) ">:")))
(mapcar '(lambda (x / d) (setq d (car x)) (vla-put-ScaleFactor d scf)) alst)
)
)
)
)
(princ)
) 一般来说,全局比例是不变的,保持打印出来的文字是固定大小。
如果全局比例也跟着缩小,那么就相当于原来图形全部按比例缩小,通过设置打印比例,实质上是一样的,所以没有这么做的
如果你一定要这么做,那么批量选中这些标注,把全局比例统一改掉即可。
首先感谢超版的耐心细致回复,只所以有这个要求是行业需要,不需要考虑打印输出的问题,我就单纯需要把甲方提供的图纸按一定比例缩放后进行加工,有原尺寸标注显示,缩放后再测量下实际尺寸,清晰明了,我们就可以加工了,不炸开标注直接缩放的话,图纸乱的一塌糊涂! 调了一下,顺便学习一下高人的写码方式
(defun c:tt5 (/ ss pt ss2 flag alst)
(defun lt:ss->list (ss / en)
(vl-remove nil (mapcar '(lambda (x)
(if (= (type (setq en (cadr x))) 'ename) en)
)
(ssnamex ss)
)
)
)
(if (and (setq ss (ssget))
(setq pt (getpoint "\n指定缩放的基点: "))
)
(progn
(if (setq ss2 (ssget "_p" '((0 . "DIMENSION"))))
(progn
(setq alst (mapcar '(lambda (d)
(setq d (vlax-ename->vla-object d))
(list d (vla-get-Measurement d))
)
(lt:ss->list ss2)
)
flag T
)
)
)
(princ "\n指定缩放的比例因子: ")
(command "_.scale" ss "" pt "\\")
(if flag
(mapcar '(lambda (x / d)
(setq d (car x))
(vla-put-LinearScaleFactor d (* (/ (cadr x) (vla-get-Measurement d))
(vla-get-LinearScaleFactor d)
)
)
(vla-put-ScaleFactor d (/ (/ (cadr x) (vla-get-Measurement d))
(vla-get-LinearScaleFactor d)
)
)
)
alst
)
)
)
)
(princ)
) 谢谢start4444老师的回复,我上次在论坛提问的一个问题也是您给解决的 现在您帮忙修改后的代码还差一步就完美了问题如截图缩描述: start4444 发表于 2020-4-23 00:58
调了一下,顺便学习一下高人的写码方式
(defun c:tt5 (/ ss pt ss2 flag alst)
请start4444老师出手帮忙再调整下代码 谢谢! 功能贴,学习了! 本帖最后由 wangxf888 于 2020-4-23 23:47 编辑
start4444 发表于 2020-4-23 22:46
(defun c:tt5 (/ alst flag lt:ss->list pt scf ss ss2)
(defun lt:ss->list (ss / en) (vl-remove ni ...
非常感谢start4444老师的及时回复,修改后的源码对我来说算比较完美了,很实用的一个工具,如果追求极致的话,就是想再完善两个地方1.全局标注比例不需要输入,直接当前*输入的缩放系数2.支持两种或两种以上的不同标注比例。可能要求有点高,见笑:P比较麻烦的话可无视这两点要求。再次感谢start4444老师再次感谢明经! 学习学习,谢谢各位大神的讨论
页:
[1]