乐筑天下

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

[编程交流] 自动布局 LISP

[复制链接]

6

主题

29

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
51
发表于 2018-8-25 16:00:10 | 显示全部楼层 |阅读模式
你好,
我一直在寻找一个能够做这么多次的例程。我有一个道路轴,188个块(视口)通过中点与它对齐。但是,逐个进行所有布局是浪费时间。那么,您是否知道一个例程能够通过模板选项卡的配置自动制作所有布局,并定向到相应的UCS视口?

看看这个例子,我希望你理解我的问题。
最好的问候,
丹尼尔。

本帖以下内容被隐藏保护;需要你回复后,才能看到!

游客,如果您要查看本帖隐藏内容请回复
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-8-3 10:04:23 | 显示全部楼层
你好,伦克,我发现了你的问题,几年后我有了答案。
你当然设法解决了。
但我这样做是作为一种挑战。
(如果我拼错了什么,我很抱歉,我用了谷歌翻译)
  1. (defun c:test (/ a cnt en entg entg_pline lista n num_str p1 p2 pini pins pline pt
  2.              ss1 ss2)
  3.   (setvar "cmdecho" 0)
  4.   (command ".ucs" "world")
  5.   (if (null (tblsearch "layer" "defpoints"))
  6.     (command ".layer" "m" "defpoints" "c" "7" "" "")
  7.   )
  8.   (if (setq pline (entsel "\nSelect the road axis:"))
  9.     (progn
  10.       (redraw (car pline) 3) ;_highlight object
  11.       (if (setq pini (getpoint
  12.                        "\nSelect a point near the beginning of the road pline: "
  13.                      )
  14.           )
  15.         (progn
  16.           (setq entg_pline (entget (car pline)))
  17.           (setq lista nil)
  18.           (mapcar '(lambda (a)
  19.                      (if (= (car a) 10)
  20.                        (setq lista (cons (cdr a) lista))
  21.                      )
  22.                    )
  23.                   entg_pline
  24.           )
  25.           (if (
  26.             (setq lista (reverse lista))
  27.           )
  28.           (setq ss1 (ssget "f" lista (list (cons '2 "viewport"))))
  29.           (setq cnt (sslength ss1))
  30.           (if (> cnt 0)
  31.             (progn
  32.               (setq n 0)
  33.               (repeat cnt
  34.                 (setq entg (entget (setq en (ssname ss1 n))))
  35.                 (setq n (1+ n))
  36.                 (setq pins (cdr (assoc 10 entg)))
  37.                 (setq pt (polar pins (cdr (assoc 50 entg)) 400))
  38.                 (setq p1
  39.                        (polar pins (+ (* pi 0.5) (cdr (assoc 50 entg))) 291.7293)
  40.                 )
  41.                 (setq p2
  42.                        (polar pins (+ (* pi 1.5) (cdr (assoc 50 entg))) 291.7293)
  43.                 )
  44.                 (setq p2 (polar p2 (cdr (assoc 50 entg)) 844.4204))
  45.                 (setq num_str (rtos n 2 0))
  46.                 (if (= (strlen num_str) 1)
  47.                   (setq num_str (strcat "0" num_str))
  48.                 )
  49.                 ;;;_the number is for verification
  50.                 ;;;_layer defpoints does not plot
  51.                 (entmakex (list (cons 0 "TEXT")
  52.                                 (cons 1 num_str)
  53.                                 (cons 10 pt)
  54.                                 (cons 11 pt)
  55.                                 (cons 8 "defpoints")
  56.                                 (cons 40 200)
  57.                                 (cons 50 (cdr (assoc 50 entg)))
  58.                                 (cons 72 1)
  59.                                 (cons 73 2)
  60.                           )
  61.                 )
  62.                 (command ".-layout" "copy" "template" num_str)
  63.                 (command ".-layout" "set" num_str)
  64.                 (setq
  65.                   ss2 (ssget
  66.                         "x"
  67.                         (list (cons 0 "VIEWPORT") (cons 410 (getvar "ctab")))
  68.                       )
  69.                 )
  70.                 (vla-put-displaylocked (vlax-ename->vla-object (ssname ss2 0))
  71.                                        :vlax-false
  72.                 )
  73.                 (command ".mspace")
  74.                 (command ".ucs" "ob" en)
  75.                 (command ".plan" "")
  76.                 (command ".zoom" "w" (trans p1 0 1) (trans p2 0 1))
  77.                 (command ".pspace")
  78.                 (setvar "tilemode" 1)
  79.               )
  80.               (command ".-layout" "delet" "template")
  81.             )
  82.           )
  83.         )
  84.       )
  85.     )
  86.   )
  87.   (if pline
  88.     (redraw (car pline) 4) ;_unhighlight object
  89.   )
  90.   (princ)
  91. )

EDIT (John):添加了代码标记。
回复

使用道具 举报

238

主题

769

帖子

33

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1721
发表于 2022-8-3 21:54:53 | 显示全部楼层
像这样的事情很乐意多说。目前正在为新的dcl进行重写。


回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-8-4 07:42:10 | 显示全部楼层
我有个问题。slj.engenharia怎么会比你的视频执行代码慢这么多?两者都令人印象深刻。干得好。真的很酷。
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-8-4 20:05:54 | 显示全部楼层
代码执行速度比视频的方式
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-1-31 07:47 , Processed in 0.359316 second(s), 67 queries .

© 2020-2025 乐筑天下

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