找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1636|回复: 0

[数学] (XD::Drag:Arc2)起点、圆心、终点圆弧拖动实现函数

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2013-7-20 21:30:41 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Drag:Arc2
调用格式: (XD::Drag:Arc2 info cen p1 KeyWord Cursor)
参数说明: info ---- 提示字符串
pj ---- 圆心
p2 ---- 起始点
keyWord --- 关键字字符串
Cursor --- 光标样式

0 - kCrosshair
1 - kCrosshair
2 - kRubberBand
3 - kNoSpecialCursor
4 - kEntitySelect
5 - kParallelogram
6 - kInvisible
其他值- kPkfirstOrGrips
返回值: 点或关键字串
函数简介: 起点、圆心、终点圆弧拖动实现函
函数来源: 原创
函数作者: Lispboy
适用版本: XDRX API 
最后更新时间: 2013-07-20
备注: -
演示图片:

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

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

×
  1. ;|
  2. 起点、圆心、终点圆弧拖动实现函数
  3. 参数:
  4.    info ---- 提示字符串
  5.   pj  ---- 圆心
  6.   p2  ---- 起始点
  7.   keyWord ---  关键字字符串
  8.   Cursor     --- 光标样式

  9.             0 - kCrosshair
  10.             1 - kCrosshair
  11.             2 - kRubberBand
  12.             3 - kNoSpecialCursor
  13.             4 - kEntitySelect
  14.             5 - kParallelogram
  15.             6 - kInvisible
  16.             其他值- kPkfirstOrGrips  
  17. |;
  18. (defun XD::Drag:Arc2 (info cen startPnt keyWord cursor / arcinfo dis dynpt e midp p3 pts r ret v)
  19.   (defun EdgeCallBack (dynPt / pts)
  20.     (setq v (mapcar
  21.               '-
  22.               dynPt
  23.               cen
  24.             )
  25.           v (xdrx_vector_normalize v)
  26.           r (distance cen startPnt)
  27.           p3 (mapcar
  28.                '+
  29.                cen
  30.                (xdrx_vector_product v r)
  31.              )
  32.           v (mapcar
  33.               '-
  34.               p3
  35.               startPnt
  36.             )
  37.           dis (distance startPnt p3)
  38.           v (xdrx_vector_normalize v)
  39.           midp (mapcar
  40.                  '+
  41.                  startPnt
  42.                  (xdrx_vector_product v (/ dis 2.0))
  43.                )
  44.           v (mapcar
  45.               '-
  46.               midp
  47.               cen
  48.             )
  49.           v (xdrx_vector_normalize v)
  50.           midp (mapcar
  51.                  '+
  52.                  cen
  53.                  (xdrx_vector_product v r)
  54.                )
  55.           arcinfo (xdrx_geom_3P2arc startPnt midp p3)
  56.     )
  57.     (if (not e)
  58.       (setq e (apply
  59.                 'xdrx_arc_make
  60.                 (cdr arcinfo)
  61.               )
  62.       )
  63.       (progn
  64.         (if (car arcinfo)
  65.           (xdrx_modent 10 cen 40 r 51 (nth 4 arcinfo) 50 (nth 3 arcinfo))
  66.           (xdrx_modent 10 cen 40 r 50 (nth 4 arcinfo) 51 (nth 3 arcinfo))
  67.         )
  68.       )
  69.     )
  70.     e
  71.   )

  72.   (setq cen (trans cen 1 0))
  73.   (setvar "lastPoint" cen)
  74.   (initget 1)
  75.   (setq ret (xdrx_drag_jig "EdgeCallBack" info keyWord (+ 1 2 4 8 16 128 512 65536) Cursor cen))
  76.   (cond
  77.     ((= ret -4)
  78.       (entdel (entlast))
  79.     )
  80.     (t
  81.       (if (= (type ret) 'STR)
  82.         (progn
  83.           
  84.           (entdel (entlast))
  85.         )
  86.       )
  87.     )
  88.   )

  89.   (gc)
  90.   ret
  91. )



  1. (defun c:test-drag-arc2()
  2.    (if (and (setq p1 (getpoint "\n圆心:"))
  3.             (setq p2 (getpoint "\n起始点:"))
  4.        )
  5.      (progn

  6.         (XD::Drag:Arc2 "\n终点[退出-Q]:" p1 p2 "Q" 0)
  7.      )
  8.   )
  9.   (princ)
  10. )


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-4-27 11:08 , Processed in 0.386781 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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