明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3157|回复: 8

圆可以转成多段线吗?

[复制链接]
发表于 2007-8-5 21:03 | 显示全部楼层 |阅读模式

圆可以转成多段线吗?想知道怎么写这样的程序,觉得无从下手。

发表于 2007-8-5 23:17 | 显示全部楼层
BO
发表于 2007-8-6 07:42 | 显示全部楼层

donut

或者利用多段线的凸度

发表于 2007-8-6 11:53 | 显示全部楼层
理论上不可以
发表于 2007-8-11 17:11 | 显示全部楼层
用两个半弧连起来就是个圆了,半弧当然可以转成多线。
发表于 2007-8-11 18:28 | 显示全部楼层
oyxx1023发表于2007-8-11 17:11:00用两个半弧连起来就是个圆了,半弧当然可以转成多线。

以前就是这么搞的.呵

发表于 2007-8-11 19:20 | 显示全部楼层
本帖最后由 作者 于 2007-8-11 19:23:16 编辑

  1. ;Written By: Jason Piercey 07.31.01
  2. ;Revised: 01.16.02 To handle multiple selection[code] (defun C:Circle2Pline (/ CirEnt   CirElst  CirCen   CirRad   CirLay
  3.                          CirLin   CirClr   CirLts   PlineEnt ss
  4.                          i        );ss1)
  5.   
  6.   (setq ss (ssget '((0 . "CIRCLE"))))
  7.   (if ss
  8.     (progn
  9.       (setq i 0 );ss1 (ssadd))
  10.       (repeat (sslength ss)
  11.         (setq CirEnt (ssname ss i)              
  12.               CirElst (entget CirEnt)
  13.               CirCen  (cdr (assoc 10 CirElst))
  14.               CirRad  (cdr (assoc 40 CirElst))
  15.               CirLay  (cdr (assoc  8 CirElst))
  16.               CirLin  (cdr (assoc  6 CirElst))
  17.               CirClr  (cdr (assoc 62 CirElst))
  18.               CirLts  (cdr (assoc 48 CirElst))
  19.               )
  20.         
  21.         (setq PlineEnt (list '(0 . "LWPOLYLINE")
  22.                              '(100 . "AcDbEntity")
  23.                              (cons 8 CirLay)
  24.                              '(100 . "AcDbPolyline")
  25.                              '(90 . 2)
  26.                              '(70 . 1)
  27.                              '(43 . 0.0)
  28.                              '(38 . 0.0)
  29.                              '(39 . 0.0)
  30.                              (cons 10 (polar CirCen (* pi) CirRad))
  31.                              '(40 . 0.0)
  32.                              '(41 . 0.0)
  33.                              '(42 . 1.0)
  34.                              (cons 10 (polar CirCen (* pi 2.0) CirRad))
  35.                              '(40 . 0.0)
  36.                              '(41 . 0.0)
  37.                              '(42 . 1.0)
  38.                              '(210 0.0 0.0 1.0)
  39.                              )
  40.               )
  41.         
  42.         (if CirLin (setq PlineEnt (append PlineEnt (list (cons 6  CirLin)))))
  43.         (if CirClr (setq PlineEnt (append PlineEnt (list (cons 62 CirClr)))))
  44.         (if CirLts (setq PlineEnt (append PlineEnt (list (cons 48 CirLts)))))
  45.         (entmake PlineEnt)
  46.         (entdel CirEnt)
  47.         (setq i (1+ i))
  48.         )
  49.       )
  50.     )
  51.   ;(ssget "p")
  52.   (princ (strcat "\n"(itoa i) " Circles converted to LwPolylines"))
  53.   (princ)
  54. )
[/code]
Ref link:
http://discussion.autodesk.com/thread.jspa?threadID=292586

本帖子中包含更多资源

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

x
 楼主| 发表于 2007-8-13 19:50 | 显示全部楼层
谢谢大侠,回去好好研究下。
发表于 2007-8-14 00:27 | 显示全部楼层
本帖最后由 作者 于 2007-8-14 0:39:11 编辑

  1. ;; ;;  (cc2pl) 圆转多义线. 支持保留扩展数据,实体特性.实例:  (cc2pl  (car(entsel)))
  2. (defun cc2pl  (e / ent cen r p1 p2 lst)
  3.   (setq ent (entget e '("*"))) ;; 支持扩展数据.
  4.   (setq cen (cdr (assoc 10 ent))
  5. r   (cdr (assoc 40 ent))
  6. p1  (polar cen 0 r)
  7. p2  (polar cen PI r)
  8. p1  (list (car p1) (cadr p1))
  9. p2  (list (car p2) (cadr p2))
  10. lst (list '(0 . "LWPOLYLINE")
  11.     '(100 . "AcDbEntity")
  12.     '(100 . "AcDbPolyline")
  13.     '(90 . 2)
  14.     '(70 . 1)
  15.     (cons 10 p1)
  16.     '(42 . -1.0)
  17.     (cons 10 p2)
  18.     '(42 . -1.0)))
  19.   (setq ent (vl-remove-if '(lambda (x) (member (car x) '(0 5 -1 40 10 100 330)))ent))
  20.   (entdel e)
  21.   (if (entmake (append lst ent))
  22.     (entlast)
  23.   )
  24. )
  25. ;| (ssc2pl ss) = 选集圆转多义线.---by lxx.2007.8
  26. 参数: ss = 选集(可包含其它实体,程序内自动过滤)
  27. 返回: 选集.亮显.新多义线存入预选集.可用"p"响应选择.
  28. 测试: 1. (ssc2pl (setq ss (ssget)))     2. (ssc2pl nil)
  29. |;
  30. (defun ssc2pl (ss / n ss2 e e2)
  31.   (if ss
  32.     (setq ss (ssget "p" '((0 . "CIRCLE"))))
  33.     (setq ss (ssget '((0 . "CIRCLE"))))
  34.   )
  35.   (setq ss2 (ssadd))
  36.   (if ss
  37.   (repeat (setq  n (sslength ss))
  38.     (setq e (ssname ss (setq n (1- n))))
  39.     (if (setq e2 (cc2pl e)) (ssadd e2 ss2))
  40.   ))
  41.   (car(sssetfirst ss2 ss2))
  42. )
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-18 12:57 , Processed in 0.205095 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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