明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: 669423907

按色选择与动态线型比例的完美结合,(作者zhynt大师)

  [复制链接]
发表于 2011-7-6 08:32:44 | 显示全部楼层
我说楼主呀,明经的热情人士很多呀,你的问题不但解决了也完美了!
 楼主| 发表于 2011-7-6 08:49:11 | 显示全部楼层
回复 simon8001 的帖子

也谢谢你的关注啊!
发表于 2011-7-8 08:44:48 | 显示全部楼层
我也试试,谢谢!
发表于 2011-7-8 10:01:42 | 显示全部楼层
好东西,看看
发表于 2011-7-22 09:05:43 | 显示全部楼层
回复 zhynt 的帖子

;;更改线型为虚线
(defun c:GL2()
          (setq a(ssget))
(command"change"a"" "p" "lt" "hidden"""))

你好,大哥,这个是更改为虚线的,但是有时候改出来比例不理想,又要调整比例,现在能不能和动态调整的程式结合,改虚线后马接着调整比例,谢谢。

动态修改线型比例(zhynt)2011-6-23 02:07
(defun c:sf(/ ss alts pt gr s1 lt newscale)
;(prompt "\n请选择非Contiiuous线型: ")
(setq ss (ssget) alts (getvar "LTSCALE") pt (getpoint "\n请指定一个点: "))
(while (= (car (setq gr (grread nil 5 0))) 5)
(redraw)(grdraw (cadr gr) pt 1 1)(setq i -1)
(while (setq s1 (ssname ss (setq i (1  i))))
(if (setq lt (cdr (assoc 6 (entget s1))))(progn
(setq zq (cdr (assoc 40 (tblsearch "ltype" lt))))
(if (/= zq 0)
(setq newscale (/ (distance (cadr gr) pt) zq alts 1.))
(setq newscale 1)))
(progn (setq zq (cdr (assoc 40 (tblsearch "ltype"
(cdr (assoc 6
(tblsearch "layer" (cdr (assoc 8 (entget s1))))))))))
(if (/= zq 0)(setq newscale (/ (distance (cadr gr) pt) zq alts 1.))
(setq newscale 1))))
(vla-put-LinetypeScale (vlax-ename->vla-object s1) newscale)))
(redraw)(princ))

发表于 2011-7-22 09:16:01 | 显示全部楼层
这个也挺好。学习了。
发表于 2011-7-22 09:25:26 | 显示全部楼层
神人制作!
发表于 2011-7-22 09:42:34 | 显示全部楼层
问一下为什么线型是位于层表中?
楼主的程序有一句子(tblsearch "ltype" (cdr (assoc 6 (tblsearch "layer" (cdr (assoc 8 (entget s1)))))))
发表于 2011-7-22 10:44:53 | 显示全部楼层
回复 crazylsp 的帖子

对于线型是随层的图元,不能直接提取到线型,这时就要通过图元所在的图层来提取线型,故此有上述语句。
发表于 2011-7-22 11:27:54 | 显示全部楼层
回复 pb.v@163.com 的帖子

  1. (defun c:GL2 ()
  2.   (setq ss (ssget))
  3.   (command "change" ss "" "p" "lt" "hidden" "")
  4.   (setq pt (getpoint "\n请为调整比例指定一个点:[不调整] "))
  5.   (if (/= pt nil)
  6.     (sf pt ss)
  7.   )
  8. )
  9. (defun sf (pt ss / alts gr s1 lt newscale)
  10.   (vl-load-com)
  11.   (setq alts (getvar "LTSCALE"))
  12.   (while (= (car (setq gr (grread nil 5 0))) 5)
  13.     (redraw)
  14.     (grdraw (cadr gr) pt 1 1)
  15.     (setq i -1)
  16.     (while (setq s1 (ssname ss (setq i (1+ i))))
  17.       (setq lt (cdr (assoc 6 (entget s1))))
  18.       (setq zq (cdr (assoc 40 (tblsearch "ltype" lt))))
  19.       (if (/= zq 0)
  20.         (setq newscale (/ (distance (cadr gr) pt) zq alts 1.0))
  21.         (setq newscale 1)
  22.       )
  23.       (vla-put-LinetypeScale (vlax-ename->vla-object s1) newscale)
  24.     )
  25.   )
  26.   (redraw)
  27.   (princ)
  28. )
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-17 08:24 , Processed in 0.152230 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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