明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1062|回复: 9

[提问] 请教大家一个带标注的图元缩放问题,恳请出手相助!

[复制链接]
发表于 2020-4-22 14:20:08 | 显示全部楼层 |阅读模式
2明经币
问题同截图里面的描述,恳请大家出手帮忙一下,谢谢!!论坛里搜到以前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)
)

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

最佳答案

查看完整内容

(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-ena ...
发表于 2020-4-22 14:20:09 | 显示全部楼层
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)
)
回复

使用道具 举报

发表于 2020-4-22 15:33:46 | 显示全部楼层
一般来说,全局比例是不变的,保持打印出来的文字是固定大小。
如果全局比例也跟着缩小,那么就相当于原来图形全部按比例缩小,通过设置打印比例,实质上是一样的,所以没有这么做的
如果你一定要这么做,那么批量选中这些标注,把全局比例统一改掉即可。
回复

使用道具 举报

 楼主| 发表于 2020-4-23 00:22:44 | 显示全部楼层
首先感谢超版的耐心细致回复,只所以有这个要求是行业需要,不需要考虑打印输出的问题,我就单纯需要把甲方提供的图纸按一定比例缩放后进行加工,有原尺寸标注显示,缩放后再测量下实际尺寸,清晰明了,我们就可以加工了,不炸开标注直接缩放的话,图纸乱的一塌糊涂!
回复

使用道具 举报

发表于 2020-4-23 00:58:49 | 显示全部楼层
调了一下,顺便学习一下高人的写码方式

(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)
)
回复

使用道具 举报

 楼主| 发表于 2020-4-23 21:18:37 | 显示全部楼层
谢谢start4444老师的回复,我上次在论坛提问的一个问题也是您给解决的   现在您帮忙修改后的代码还差一步就完美了  问题如截图缩描述:

本帖子中包含更多资源

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

x
回复

使用道具 举报

 楼主| 发表于 2020-4-23 21:20:44 | 显示全部楼层
start4444 发表于 2020-4-23 00:58
调了一下,顺便学习一下高人的写码方式

(defun c:tt5 (/ ss pt ss2 flag alst)

请start4444老师出手帮忙再调整下代码   谢谢!
回复

使用道具 举报

发表于 2020-4-23 22:22:50 | 显示全部楼层
功能贴,学习了!
回复

使用道具 举报

 楼主| 发表于 2020-4-23 23:46:27 | 显示全部楼层
本帖最后由 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老师  再次感谢明经!
回复

使用道具 举报

发表于 2020-9-4 12:37:04 | 显示全部楼层
学习学习,谢谢各位大神的讨论
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-5-17 21:49 , Processed in 0.284183 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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