明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 12507|回复: 31

[讨论] 表格处理:自动延伸+修剪

  [复制链接]
发表于 2013-9-29 23:26:20 | 显示全部楼层 |阅读模式
本帖最后由 xyp1964 于 2013-10-1 11:20 编辑

求以下延伸+修剪效果的代码:

本帖子中包含更多资源

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

x
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2013-10-2 20:40:58 | 显示全部楼层
xyp1964 发表于 2013-10-2 15:40
延伸和打断有点搞不清

之前的版本是端点就最近的线打断!
以下代码改成了端点全部都延伸的效果:
  1. 仅对水平和垂直相交直线有效 By Lisper 2013.10.02
  2. (defun c:LineExt (/ SS         N    E           EL        P1   P2          ANG  L1   L2         YL
  3.                     XL         MINX MAXX MINY        MAXY E1          E2   E3   E4         X1
  4.                     X2         X    I           Y1        Y2   Y
  5.                    )
  6.   (setq ss (ssget '((0 . "line"))))
  7.   (if ss
  8.     (progn
  9.       (repeat (setq n (sslength ss))
  10.         (setq e (ssname ss (setq n (1- n))))
  11.         (setq el  (entget e)
  12.               p1  (cdr (assoc 10 el))
  13.               p2  (cdr (assoc 11 el))
  14.               ang (angle p1 p2)
  15.         )
  16.         (if (or        (equal 0 ang 1e-4)
  17.                 (equal pi ang 1e-4)
  18.             )
  19.           (setq l1 (cons e l1))
  20.           (setq l2 (cons e l2))
  21.         )
  22.       )
  23.       (setq l1         (vl-sort l1
  24.                           '(lambda (a b)
  25.                              (<        (caddr (assoc 10 (entget a)))
  26.                                 (caddr (assoc 10 (entget b)))
  27.                              )
  28.                            )
  29.                  ) ;_ 水平
  30.             yl         (mapcar '(lambda (x) (caddr (assoc 10 (entget x)))) l1)
  31.             l2         (vl-sort l2
  32.                           '(lambda (a b)
  33.                              (<        (cadr (assoc 10 (entget a)))
  34.                                 (cadr (assoc 10 (entget b)))
  35.                              )
  36.                            )
  37.                  ) ;_ 垂直
  38.             xl         (mapcar '(lambda (x) (cadr (assoc 10 (entget x)))) l2)
  39.             minx (cadr (assoc 10 (entget (car l2))))
  40.             maxx (cadr (assoc 10 (entget (last l2))))
  41.             miny (caddr (assoc 10 (entget (car l1))))
  42.             maxy (caddr (assoc 10 (entget (last l1))))
  43.             e1         (car l1)
  44.             l1         (cdr l1)
  45.             e2         (last l1)
  46.             l1         (reverse (cdr (reverse l1)))
  47.             e3         (car l2)
  48.             l2         (cdr l2)
  49.             e4         (last l2)
  50.             l2         (reverse (cdr (reverse l2)))
  51.       )
  52.       (foreach line l1 ;_ 处理水平线
  53.         (setq el (entget line)
  54.               p1 (cdr (assoc 10 el))
  55.               x1 (car p1)
  56.               p2 (cdr (assoc 11 el))
  57.               x2 (car p2)
  58.         )
  59.         (setq i -1)
  60.         (vl-some '(lambda (a) (setq i (1+ i)) (< x1 a)) xl)
  61.         (if (> i 0) (setq i (1- i)))
  62.         (setq p1 (list (nth i xl) (cadr p1) (caddr p1)))
  63.         (setq i -1)
  64.         (vl-some '(lambda (a) (setq i (1+ i)) (< x2 a)) xl)
  65.        
  66.         (if
  67.           (nth i xl)
  68.           (setq p2 (list (nth i xl) (cadr p2) (caddr p2)))
  69.           (setq p2 (list (last xl) (cadr p2) (caddr p2)))
  70.           )
  71.        
  72.         (setq el (subst (cons 10 p1) (assoc 10 el) el)
  73.               el (subst (cons 11 p2) (assoc 11 el) el)
  74.         )
  75.         (entmod el)
  76.       )
  77.       (foreach line l2 ;_ 处理垂直线
  78.         (setq el (entget line)
  79.               p1 (cdr (assoc 10 el))
  80.               y1 (cadr p1)
  81.               p2 (cdr (assoc 11 el))
  82.               y2 (cadr p2)
  83.         )
  84.         (setq i -1)
  85.         (vl-some '(lambda (a) (setq i (1+ i)) (< y1 a)) yl)
  86.         (if (> i 0) (setq i (1- i)))
  87.         (setq p1 (list (car p1) (nth i yl)  (caddr p1)))
  88.         (setq i -1)
  89.         (vl-some '(lambda (a) (setq i (1+ i)) (< y2 a)) yl)
  90.         (if
  91.           (nth i yl)
  92.           (setq p2 (list (car p2) (nth i yl)  (caddr p2)))
  93.           (setq p2 (list (car p2) (last yl) (caddr p2)))
  94.           )
  95.        
  96.         (setq el (subst (cons 10 p1) (assoc 10 el) el)
  97.               el (subst (cons 11 p2) (assoc 11 el) el)
  98.         )
  99.         (entmod el)
  100.       )
  101.       (if e1
  102.         (progn
  103.           (setq el (entget e1))
  104.           (setq        el (subst (list 10 minx miny 0) (assoc 10 el) el)
  105.                 el (subst (list 11 maxx miny 0) (assoc 11 el) el)
  106.           )
  107.           (entmod el)
  108.         )
  109.       )
  110.       (if e2
  111.         (progn
  112.           (setq el (entget e2))
  113.           (setq        el (subst (list 10 minx maxy 0) (assoc 10 el) el)
  114.                 el (subst (list 11 maxx maxy 0) (assoc 11 el) el)
  115.           )
  116.           (entmod el)
  117.         )
  118.       )
  119.       (if e3
  120.         (progn
  121.           (setq el (entget e3))
  122.           (setq        el (subst (list 10 minx miny 0) (assoc 10 el) el)
  123.                 el (subst (list 11 minx maxy 0) (assoc 11 el) el)
  124.           )
  125.           (entmod el)
  126.         )
  127.       )
  128.       (if e4
  129.         (progn
  130.           (setq el (entget e4))
  131.           (setq        el (subst (list 10 maxx miny 0) (assoc 10 el) el)
  132.                 el (subst (list 11 maxx maxy 0) (assoc 11 el) el)
  133.           )
  134.           (entmod el)
  135.         )
  136.       )

  137.     )
  138.   )
  139.   (princ)
  140. )

评分

参与人数 3明经币 +5 金钱 +18 收起 理由
xyp1964 + 1 赞一个!
669423907 + 1 很给力!
Gu_xl + 3 + 18 赞一个!

查看全部评分

回复 支持 1 反对 0

使用道具 举报

发表于 2024-4-15 10:08:30 | 显示全部楼层
围观围观~~新手来学习
发表于 2024-4-13 11:54:33 | 显示全部楼层
一群牛人,,拜服。
发表于 2013-9-29 23:48:45 | 显示全部楼层
顶起+关注一下
发表于 2013-9-30 07:41:44 | 显示全部楼层
校长也求源码?
发表于 2013-9-30 08:13:43 | 显示全部楼层
院长帐号被盗
发表于 2013-9-30 08:46:23 | 显示全部楼层
本帖最后由 pxt2001 于 2013-9-30 08:50 编辑
669423907 发表于 2013-9-30 08:13
院长帐号被盗

这是个神回复!

网友的想像力很强大!
发表于 2013-9-30 11:38:06 | 显示全部楼层
校长也求源码?
发表于 2013-9-30 12:29:03 | 显示全部楼层
顶起+关注一下!!
发表于 2013-9-30 12:48:47 | 显示全部楼层
目测动画是院长的,发帖的是不是就不知道了。
也许是院长来调戏来了,院长赶紧放源码给我们围观吧。
发表于 2013-9-30 14:06:40 | 显示全部楼层
围观!!!!!!!!!
发表于 2013-9-30 14:13:38 | 显示全部楼层
表示围观,院长求源码不太可能吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-2-21 03:30 , Processed in 0.193006 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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