明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: 燃烧

我写的加中心线的程序,可以加矩形、圆、平行线的

    [复制链接]
发表于 2012-3-8 14:19 | 显示全部楼层
h008 发表于 2012-3-8 09:32
我试试,我是菜鸟,写的代码不够漂亮!

(defun 2d_mid (pt1 pt2);求两点中点 这就是函数应该是来自是明 ...

有点小问题:

本帖子中包含更多资源

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

x

点评

加了开头,结尾处理就行了。 至于后面那种直线,如果要竖线长些,直接改 bgd (* (- (cadr PtRT) (cadr PtLB)) ccbs 0.5);半高度 把0.5改大就好了  发表于 2012-3-8 14:32
发表于 2012-3-16 10:12 | 显示全部楼层
谢谢楼主,下载用了,很好
发表于 2012-4-27 13:11 | 显示全部楼层
很好啊 ,支持
发表于 2012-4-27 13:24 | 显示全部楼层
这个必须顶
发表于 2012-4-27 13:34 | 显示全部楼层
谢谢楼主,好用不错,
发表于 2012-4-27 13:54 | 显示全部楼层
好东西。。。谢谢分享~~~~
发表于 2012-4-27 22:59 | 显示全部楼层
本帖最后由 xiaoyingzi 于 2012-4-28 13:25 编辑

修改一下,支持框选,支持圆、圆弧、椭圆、矩形,去掉了平行线



  1. ;;源码来自明经通道-燃烧
  2. ;;支持圆、圆弧、椭圆、矩形框选加中心线
  3. ;;xiaoyingzi修改,增加支持框选和椭圆
  4. (defun c:zxx (/ v1 v2 v3  ss n in en endata entype cenpt r
  5.                 b l dist ptlist p1 p2 p3 p4 pt1 pt2 pt3 pt4 )
  6.   ;获得点p1和p2两点的中点坐标
  7.   (defun MidPof2P (p1 p2)
  8.     (mapcar '(lambda(x y) (/ (+ x y) 2.0) ) p1 p2)
  9.   )
  10.   (setq v1 (getvar "osmode"))
  11.   (setq v2 (getvar "cmdecho"))
  12.   (setq v3 (getvar "clayer"))
  13.   (setvar "cmdecho" 0)
  14.   (setvar "osmode" 0)
  15.   (princ "\n选择要加中心线的圆、圆弧、椭圆、矩形!")
  16.   (if (setq ss (ssget (list(cons 0 "ARC,CIRCLE,ELLIPSE,LWPOLYLINE"))))
  17.     (progn
  18.       (setq n (sslength ss) in 0)
  19.       (repeat n
  20.         (setq en (ssname ss in) in (1+ in))
  21.         (setq endata (entget en))
  22.         (setq entype (cdr (assoc 0 endata)))
  23.         (cond
  24.           ((or (= "CIRCLE" entype) (= "ARC" entype)) ;圆、圆弧
  25.            (setq cenpt (cdr (assoc 10 endata)))
  26.            (setq r (cdr (assoc 40 endata)))
  27.            (setq dist (* r 0.4))
  28.            (setq pt1 (polar cenpt pi (+ dist r))
  29.                  pt2 (polar cenpt 0 (+ dist r))
  30.                  pt3 (polar cenpt (* 0.5 pi) (+ dist r))
  31.                  pt4 (polar cenpt (* 1.5 pi) (+ dist r))
  32.            )
  33.           )
  34.           ((= "ELLIPSE" entype) ;椭圆
  35.            (setq cenpt (cdr (assoc 10 endata)))
  36.            (setq l (distance (list 0 0) (cdr (assoc 11 endata))))
  37.            (setq b (* (cdr (assoc 40 endata)) l))
  38.            (setq rotangle (angle (list 0 0) (cdr (assoc 11 endata))))
  39.            (setq dist (* b 0.4))
  40.            (setq pt1 (polar cenpt rotangle (+ l dist))
  41.                  pt2 (polar cenpt (+ pi rotangle) (+ l dist))
  42.                  pt3 (polar cenpt (+ (* 0.5 pi) rotangle) (+ b dist))
  43.                  pt4 (polar cenpt (+ (* 1.5 pi) rotangle) (+ b dist))
  44.            )
  45.           )
  46.           ((and (= "LWPOLYLINE" entype) (=  (cdr (assoc 90 (entget en))) 4)) ;矩形
  47.            (setq ptlist (vl-remove-if '(lambda (x) (/= 10 (car x))) endata))
  48.            (setq ptlist (mapcar 'cdr ptlist)
  49.                  p1 (nth 0 ptlist)
  50.                  p2 (nth 1 ptlist)
  51.                  p3 (nth 2 ptlist)
  52.                  p4 (nth 3 ptlist)
  53.            )
  54.            (setq
  55.                  b (distance p1 p2)
  56.                  l (distance p1 p4)
  57.                  pt1 (MidPof2P p1 p2)
  58.                  pt2 (MidPof2P p3 p4)
  59.                  pt3 (MidPof2P p1 p4)
  60.                  pt4 (MidPof2P p2 p3)
  61.            )
  62.            (if (< b l)
  63.                (setq dist (* b 0.2))
  64.                (setq dist (* l 0.2))
  65.            )
  66.            (setq
  67.                  pt1 (polar pt1 (angle pt2 pt1) dist)
  68.                  pt2 (polar pt2 (angle pt1 pt2) dist)
  69.                  pt3 (polar pt3 (angle pt4 pt3) dist)
  70.                  pt4 (polar pt4 (angle pt3 pt4) dist)
  71.            )
  72.           )
  73.         )  
  74.         (if (and pt1 pt2 pt3 pt4)
  75.             (progn
  76.               (if (not (tblsearch "LAYER" "Cen"))
  77.                   (command "layer" "m" "Cen" "c" 2 "" "l" "center2" "" "lw"
  78.                            0.18 "" "")
  79.               )
  80.               (command "layer" "s" "cen" "")
  81.               (command "line" pt1 pt2 "")
  82.               (command "line" pt3 pt4 "")
  83.               (setvar "clayer" v3)
  84.             )
  85.        )
  86.       )
  87.     )
  88.   )
  89.   (setvar "osmode" v1)
  90.   (setvar "cmdecho" v2)
  91.   (princ)
  92. )

点评

谢谢!我需要线段不平行角外角平分线!  发表于 2015-3-6 20:49

评分

参与人数 2明经币 +2 收起 理由
1993063 + 1
yjr111 + 1

查看全部评分

发表于 2012-4-28 06:13 来自手机 | 显示全部楼层
手机上网,回头试用。
发表于 2012-4-28 13:26 | 显示全部楼层
更新了下,支持椭圆
发表于 2012-4-30 20:54 | 显示全部楼层
这个是别人开发的智能中心线,目前还没发现谁上传像这样的中心线,本人以现还没有能力,但相信以后肯定能写出来,可惜没有参考,无法去研究。

本帖子中包含更多资源

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

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

本版积分规则

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

GMT+8, 2024-5-4 04:13 , Processed in 0.336007 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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