乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 80|回复: 4

[编程交流] 更改文本颜色

[复制链接]

21

主题

61

帖子

44

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
108
发表于 2022-7-5 15:00:01 | 显示全部楼层 |阅读模式
我有这个复制粘贴autolisp,我缝合了从不同的人(因为IDK如何编码)
但我被困住了。。我想做的是选择所有文本并全部更改
我的复制粘贴代码是针对单个文本。。。
  1. (defun c:TcolAu (/ hcol clr pt1 ss)
  2. (While T
  3. (setq ss (ssget "_:S" '((0 . ",TEXT"))))
  4. (setq hcol (atof(cdr (assoc 1 (entget (ssname ss 0))))))
  5. (cond
  6. ((<= hcol 0.09)(setq clr 252))
  7. ((<= hcol 0.49)(setq clr 5))
  8. ((<= hcol 0.99)(setq clr 3))
  9. ((<= hcol 1.99)(setq clr 2))
  10. ((<= hcol 2.99)(setq clr 30))
  11. ((>= hcol 3)(setq clr 6))
  12. )
  13. (command "change" ss "" "_p" "Color" clr "")
  14. (princ)))
回复

使用道具 举报

rlx

21

主题

1505

帖子

1551

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
81
发表于 2022-7-5 15:25:12 | 显示全部楼层
回复

使用道具 举报

21

主题

61

帖子

44

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
108
发表于 2022-7-5 15:38:23 | 显示全部楼层
 
 
no sir, i mean how can i change my code to select all text and change the color based on the value of the text...
the one you gave will actually make the process longer if i use "search"
回复

使用道具 举报

rlx

21

主题

1505

帖子

1551

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
81
发表于 2022-7-5 15:45:21 | 显示全部楼层
haven't got a drawing to test it on so untested :

[code](defun c:foo (/ ss hcol clr e) (if (setq ss (ssget "_X" (list '(0 . "TEXT"))))   (foreach e (mapcar 'cadr (ssnamex ss))     (setq hcol (atof (cdr (assoc 1 (entget e)))))     (cond ((
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-5 16:12:02 | 显示全部楼层
Hi,
My attempt.
  1. (defun c:foo (/ str int sel ent get lst) (and   (setq str ""         lst '(("0.09" 252) ("0.49" 5) ("0.99" 3)) ;; add your more desired of strings with colours here         int -1         sel (ssget               "_X"               (list                 '(0 . "TEXT")                 (cons                   1                   (apply                     'strcat                     (mapcar '(lambda (u) (setq str (strcat (car u) ",")))                             lst                     )                   )                 )               )             )   )   (while (setq ent (ssname sel (setq int (1+ int))))     (entmod       (append (setq get (entget ent))               (list (cons 62 (cadr (assoc (cdr (assoc 1 get)) lst))))       )     )   ) ) (princ))
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-15 00:52 , Processed in 3.653875 second(s), 62 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表