明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: yjr111

直线或多段线小调整

    [复制链接]
发表于 2012-12-31 23:35:24 | 显示全部楼层
有时候碰到一些外来图画得不是很规范,有这个程序好多了。
发表于 2013-1-1 00:41:22 | 显示全部楼层
梦里水香 发表于 2012-12-31 23:35
有时候碰到一些外来图画得不是很规范,有这个程序好多了。

非常实用,请问什么是轻多段线?
发表于 2013-1-1 10:38:45 | 显示全部楼层
这功能要能批量修改才好用,可以定义以左、右边夹点为基准的批量规正
发表于 2013-2-4 21:08:44 | 显示全部楼层
这个功能同highflybird的图元归整差不多。
发表于 2014-1-6 11:48:02 | 显示全部楼层
这个程序很好用。多谢楼主分享。
发表于 2014-1-13 14:27:27 | 显示全部楼层
这玩意不错
发表于 2014-2-17 13:04:59 | 显示全部楼层
一如既往的挺这种看似简单却很实用的lsp
发表于 2014-2-20 12:07:47 | 显示全部楼层

支持一下,不错,实用
发表于 2014-2-20 13:17:46 | 显示全部楼层
长老的内容
有实用价值
(defun c:ww (/ oldosmode e ee e1 e2 p10 dqp dis ang s1 nearp1 p10lst p11 SS N E3)
  (princ"**************正交化直线或轻多段线**********************")
  (COMMAND "UNDO" "BE")
  (setq oldosmode (getvar 'osmode))
  (setvar 'osmode 0)
  (defun makeline(pt1 pt2)
    (entmake (list '(0 . "LINE") (cons 10 pt1) (cons 11 pt2)))
  )
  (while (setq e (entsel "\n请选择直线或轻多段线:"))
    (setq e1  (car e)
          p1  (cadr e)
          s1(entget e1)
          )
    (cond
      ((= (cdr (assoc 0 s1))"LINE")
       (setq
          p10 (cdr (assoc 10 s1))
          p11 (cdr (assoc 11 s1))
          ang (rem (angle p10 p11) pi)
         )
      )
      ((= (cdr (assoc 0 s1))"LWPOLYLINE")
       (setq nearp1(vlax-curve-getclosestpointto e1 p1 ))
       (foreach x s1
         (if (= (car x)10)(setq p10lst(cons (cdr x) p10lst)))
       )
       (SETQ SS(SSADD))
       (foreach x p10lst
         (SETQ P10LST(cdr p10lst))
         (mapcar '(lambda(y)(makeline x y)(SSADD (ENTLAST) SS))p10lst)         
       )
       (REPEAT (SETQ N (SSLENGTH SS))
         (IF (EQUAL(DISTANCE nearp1(vlax-curve-getclosestpointto (SETQ E3(SSNAME SS (SETQ N(1- N)))) nearp1 ))0.0 1E-3)
            (setq
               p10 (REVERSE(CDR(REVERSE (cdr (assoc 10 (ENTGET E3))))))
               p11 (REVERSE(CDR(REVERSE (cdr (assoc 11 (ENTGET E3))))))
               ang (rem (angle p10 p11) pi)
              )          
         )
       )
       (COMMAND "ERASE" SS "")
      )
    )
    (if (> ang (/ pi 2))(setq ang (abs(- ang pi))))
    (cond
      ((and(<(distance p1 p10)(distance p1 p11))
           (< ang (/ pi 4))
           )
       (if(= (cdr (assoc 0 s1))"LINE")
          (entmod (subst (cons 11 (list (car p11)(cadr p10)))(cons 11 p11)s1))
          (entmod (subst (cons 10 (list (car p11)(cadr p10)))(cons 10 p11)s1))
         )
      )
      ((and(>(distance p1 p10)(distance p1 p11))
           (< ang (/ pi 4))
           )
       (if(= (cdr (assoc 0 s1))"LINE")
         (entmod (subst (cons 10 (list (car p10)(cadr p11)))(cons 10 p10)s1))
         (entmod (subst (cons 10 (list (car p10)(cadr p11)))(cons 10 p10)s1))
         )
      )
      ((and(<(distance p1 p10)(distance p1 p11))
           (> ang (/ pi 4))
           )
       (if(= (cdr (assoc 0 s1))"LINE")
         (entmod (subst (cons 11 (list (car p10)(cadr p11)))(cons 11 p11)s1))
         (entmod (subst (cons 10 (list (car p10)(cadr p11)))(cons 10 p11)s1))
         )
      )
      ((and(>(distance p1 p10)(distance p1 p11))
           (> ang (/ pi 4))
           )
       (if(= (cdr (assoc 0 s1))"LINE")
         (entmod (subst (cons 10 (list (car p11)(cadr p10)))(cons 10 p10)s1))
         (entmod (subst (cons 10 (list (car p11)(cadr p10)))(cons 10 p10)s1))
         )
      )
      )
  )
  (setvar 'osmode oldosmode)
  (COMMAND "UNDO" "E")
  (princ)
)
发表于 2014-7-15 22:11:07 | 显示全部楼层
要能框选且能指定以基点调整 就完美了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-20 01:26 , Processed in 0.217126 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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