找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2450|回复: 3

[研讨] 圆、弧时,如果中心点没有相互垂直的两条线,画十字中心线

[复制链接]

已领礼包: 604个

财富等级: 财运亨通

发表于 2013-11-18 12:06:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
  1. ;;圆、弧时,如果中心点没有相互垂直的两条线,画十字中心线
  2. (defun HH:circleCross (en / ANG1 ANG2 E1EN E1ST E2EN E2ST EN1 EN2 ENT P10 PX1 PX2 PY1 PY2 R SS)
  3.   (setq ent (entget en))
  4.   (setq p10 (cdr (assoc 10 ent)))
  5.   (setq r (* (cdr (assoc 40 ent)) 1.25))
  6.   (if (and (setq ss (ssget "_C"
  7.                            p10
  8.                            p10
  9.                            (list '(-4 . "<or")          '(0 . "LINE")           '(-4 . "<and")
  10.                                  '(0 . "LWPOLYLINE")                   '(90 . 2)
  11.                                  '(-4 . "and>")          '(-4 . "or>")
  12.                                 )
  13.                     )
  14.            )
  15.            (equal (sslength ss) 2)
  16.            (setq en1 (ssname ss 0))
  17.            (setq en2 (ssname ss 1))
  18.            (setq e1st (vlax-curve-getStartPoint en1))
  19.            (setq e1en (vlax-curve-getendPoint en1))
  20.            (setq e2st (vlax-curve-getStartPoint en2))
  21.            (setq e2en (vlax-curve-getendPoint en2))
  22.            (setq ang1 (angle e1st e1en))
  23.            (setq ang2 (angle e2st e2en))
  24.            (equal (rem (- ang1 ang2) (/ pi 2)) 0)
  25.       )
  26.     nil
  27.     (progn
  28.       (setq px1 (mapcar '- p10 (list r 0 0)))
  29.       (setq px2 (mapcar '+ p10 (list r 0 0)))     
  30.       (entmake (list (cons 0 "LINE") (cons 10 px1) (cons 11 px2)))
  31.       (setq py1 (mapcar '- p10 (list 0 r 0)))
  32.       (setq py2 (mapcar '+ p10 (list 0 r 0)))
  33.       (entmake (list (cons 0 "LINE") (cons 10 py1) (cons 11 py2)))
  34.     )
  35.   )
  36. )
  37. (defun C:W3 (/ EN)
  38.   (setq en (car (entsel)))
  39.   (HH:circleCross en)
  40.   (princ)
  41. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-18 12:49:42 来自手机 | 显示全部楼层
圆在屏幕内,圆心不一定在,所以ssget不一定对
吹毛求疵

点评

说得有道理 如果修改过滤条件,也只能满足水平或者垂直的情况,其它的可能难考虑到  详情 回复 发表于 2013-11-18 13:18
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 604个

财富等级: 财运亨通

 楼主| 发表于 2013-11-18 13:18:23 | 显示全部楼层
st788796 发表于 2013-11-18 12:49
圆在屏幕内,圆心不一定在,所以ssget不一定对
吹毛求疵

说得有道理
如果修改过滤条件,也只能满足水平或者垂直的情况,其它的可能难考虑到

点评

这种应用可以把十字线记录到圆上,或者用组,或者用 ldata 等,这样选择后判断是不是存在且在原位置,不存在重画并更新,不在移回来  详情 回复 发表于 2013-11-18 15:56
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-18 15:56:28 | 显示全部楼层
/db_自贡黄明儒_ 发表于 2013-11-18 13:18
说得有道理
如果修改过滤条件,也只能满足水平或者垂直的情况,其它的可能难考虑到

这种应用可以把十字线记录到圆上,或者用组,或者用 ldata 等,这样选择后判断是不是存在且在原位置,不存在重画并更新,不在移回来
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-15 08:56 , Processed in 0.195293 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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