乐筑天下

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

[编程交流] 在li的中点插入块

[复制链接]

5

主题

23

帖子

18

银币

初来乍到

Rank: 1

铜币
25
发表于 2022-7-5 20:40:17 | 显示全部楼层
 
我发现这是你的旧代码,稍加修改就可以了。
仍然存在一些错误,并且没有进行优化。
 
  1. (defun c:VHlines ( / _Ang *error* kw e i sn ss )
  2. ;;; Tharwat 13. Dec. 2012  ;;;
  3. ;;; modified by miller87 27/04/2015
  4. (defun _Ang (e) (angle (cddr (assoc 10 e)) (cddr (assoc 11 e))))
  5. (defun *error* (msg) (princ "\n Error...*Cancelled*"))
  6. (if (and (progn
  7.                  (setq kw "Vertical"
  8.                  )
  9.           )
  10.           (setq s  (ssadd)
  11.                 ss (ssget "_x" (list '(0 . "LINE") (cons 410 (getvar 'ctab))))
  12.           )
  13.      )
  14.    (progn
  15.      (repeat (setq i (sslength ss))
  16.        (setq sn (ssname ss (setq i (1- i)))
  17.              e  (entget sn)
  18.        )
  19.        (cond ((eq kw "Vertical")
  20.               (if (or (equal (_Ang e) (* pi 0.5)) (equal (_Ang e) (* pi 1.5)))
  21.                 (ssadd sn s)
  22.               )
  23.              )
  24.              ((eq kw "Horizontal")
  25.               (if (or (equal (_Ang e) pi) (equal (_Ang e) 0.))
  26.                 (ssadd sn s)
  27.               )
  28.              )
  29.              (t
  30.               (if (or (equal (_Ang e) (* pi 0.5)) (equal (_Ang e) (* pi 1.5)) (equal (_Ang e) pi) (equal (_Ang e) 0.))
  31.                 (ssadd sn s)
  32.               )
  33.              )
  34.        )
  35.      )
  36.      (sssetfirst nil s)
  37.    )
  38. )
  39. (princ)
  40. )
回复

使用道具 举报

26

主题

1495

帖子

20

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
118
发表于 2022-7-5 20:46:57 | 显示全部楼层
也许 吧:
 
  1. [b][color=BLACK]([/color][/b]defun c:mvert [b][color=FUCHSIA]([/color][/b]/ ss i en ed p1 p2 z1 z2 ll ip bn[b][color=FUCHSIA])[/color][/b]
  2. [b][color=FUCHSIA]([/color][/b]and [b][color=NAVY]([/color][/b]setq ss [b][color=MAROON]([/color][/b]ssget [color=#2f4f4f]"X"[/color] '[b][color=GREEN]([/color][/b][b][color=BLUE]([/color][/b]0 . [color=#2f4f4f]"LINE"[/color][b][color=BLUE])[/color][/b][b][color=GREEN])[/color][/b][b][color=MAROON])[/color][/b][b][color=NAVY])[/color][/b]
  3.      [b][color=NAVY]([/color][/b]setq i 0[b][color=NAVY])[/color][/b]
  4.      [b][color=NAVY]([/color][/b]while [b][color=MAROON]([/color][/b]setq en [b][color=GREEN]([/color][/b]ssname ss i[b][color=GREEN])[/color][/b][b][color=MAROON])[/color][/b]
  5.             [b][color=MAROON]([/color][/b]setq ed [b][color=GREEN]([/color][/b]entget en[b][color=GREEN])[/color][/b]
  6.                   p1 [b][color=GREEN]([/color][/b]cdr [b][color=BLUE]([/color][/b]assoc 10 ed[b][color=BLUE])[/color][/b][b][color=GREEN])[/color][/b]
  7.                   p2 [b][color=GREEN]([/color][/b]cdr [b][color=BLUE]([/color][/b]assoc 11 ed[b][color=BLUE])[/color][/b][b][color=GREEN])[/color][/b][b][color=MAROON])[/color][/b]
  8.             [b][color=MAROON]([/color][/b]and [b][color=GREEN]([/color][/b]equal [b][color=BLUE]([/color][/b]car  p1[b][color=BLUE])[/color][/b] [b][color=BLUE]([/color][/b]car  p2[b][color=BLUE])[/color][/b] 1e-8[b][color=GREEN])[/color][/b]
  9.                  [b][color=GREEN]([/color][/b]equal [b][color=BLUE]([/color][/b]cadr p1[b][color=BLUE])[/color][/b] [b][color=BLUE]([/color][/b]cadr p2[b][color=BLUE])[/color][/b] 1e-8[b][color=GREEN])[/color][/b]
  10.                  [b][color=GREEN]([/color][/b]setq z1 [b][color=BLUE]([/color][/b]caddr p1[b][color=BLUE])[/color][/b]
  11.                        z2 [b][color=BLUE]([/color][/b]caddr p2[b][color=BLUE])[/color][/b]
  12.                        ll [b][color=BLUE]([/color][/b]abs [b][color=RED]([/color][/b]- z1 z2[b][color=RED])[/color][/b][b][color=BLUE])[/color][/b]
  13.                        ip [b][color=BLUE]([/color][/b]list [b][color=RED]([/color][/b]car p1[b][color=RED])[/color][/b] [b][color=RED]([/color][/b]cadr p2[b][color=RED])[/color][/b] [b][color=RED]([/color][/b]+ [b][color=PURPLE]([/color][/b]min z1 z2[b][color=PURPLE])[/color][/b] [b][color=PURPLE]([/color][/b]* ll 0.5[b][color=PURPLE])[/color][/b][b][color=RED])[/color][/b][b][color=BLUE])[/color][/b]
  14.                        bn [b][color=BLUE]([/color][/b]strcat [color=#2f4f4f]"M"[/color] [b][color=RED]([/color][/b]rtos ll 2 0[b][color=RED])[/color][/b][b][color=BLUE])[/color][/b][b][color=GREEN])[/color][/b]
  15.                  [b][color=GREEN]([/color][/b]tblsearch [color=#2f4f4f]"BLOCK"[/color] bn[b][color=GREEN])[/color][/b]
  16.                  [b][color=GREEN]([/color][/b]entmake [b][color=BLUE]([/color][/b]list [b][color=RED]([/color][/b]cons 0 [color=#2f4f4f]"INSERT"[/color][b][color=RED])[/color][/b][b][color=RED]([/color][/b]cons 2 bn[b][color=RED])[/color][/b][b][color=RED]([/color][/b]cons 10 ip[b][color=RED])[/color][/b][b][color=BLUE])[/color][/b][b][color=GREEN])[/color][/b][b][color=MAROON])[/color][/b]
  17.             [b][color=MAROON]([/color][/b]setq i [b][color=GREEN]([/color][/b]1+ i[b][color=GREEN])[/color][/b][b][color=MAROON])[/color][/b][b][color=NAVY])[/color][/b][b][color=FUCHSIA])[/color][/b]
  18. [b][color=FUCHSIA]([/color][/b]prin1[b][color=FUCHSIA])[/color][/b][b][color=BLACK])[/color][/b]

 
 
插入角度没有意义,因为所有线点值都是WCS。
 
-大卫
回复

使用道具 举报

5

主题

23

帖子

18

银币

初来乍到

Rank: 1

铜币
25
发表于 2022-7-5 20:50:23 | 显示全部楼层
作品
我用我的块的正确名称进行了修改:
50M、100M、150M、200M、250M、300M
以下是最终结果:
  1. (defun c:mvert (/ )
  2. (and (setq ss (ssget "X" '((0 . "LINE"))))
  3.      (setq i 0)
  4.      (while (setq en (ssname ss i))
  5.             (setq ed (entget en)
  6.                   p1 (cdr (assoc 10 ed))
  7.                   p2 (cdr (assoc 11 ed)))
  8.             (and (equal (car  p1) (car  p2) 1e-
  9.                  (equal (cadr p1) (cadr p2) 1e-
  10.                  (setq z1 (caddr p1)
  11.                        z2 (caddr p2)
  12.                        ll (/ (abs (- z1 z2)) 10.0)
  13.                 lll (* ll 10.0)
  14.                        ip (list (car p1) (cadr p2) (+ (min z1 z2) (* lll 0.5)))
  15.                        bn (strcat  (rtos ll 2 0) "M"))
  16.                  (tblsearch "BLOCK" bn)
  17.                  (entmake (list (cons 0 "INSERT")(cons 2 bn)(cons 10 ip))))
  18.             (setq i (1+ i))))
  19. (prin1)
  20. )

 
我可以更改块的名称,但操纵lisp更令人愉快!!
谢谢David
回复

使用道具 举报

26

主题

1495

帖子

20

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
118
发表于 2022-7-5 20:53:27 | 显示全部楼层
英雄联盟
 
我确实假设块表定义存在。
 
您始终可以添加块创建或插入调用
 
-戴维斯
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-8-18 22:58 , Processed in 1.983825 second(s), 58 queries .

© 2020-2025 乐筑天下

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