找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1244|回复: 0

[[coior=red]文档类] (XD::Doc:GetRectang)动态拖动画矩形向量

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2016-5-28 11:13:52 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Doc:GetRectang
调用格式: (XD::Doc:GetRectang info pts clr)
参数说明: info ---- 提示字符串
pts ---- 点表(UCS),给一个点,平行UCS对角画矩形
给二个点,两点为底边拖动画矩形
clr ---- 向量的颜色,负值画实线
返回值: 四点表(UCS)
函数简介: 动态拖动画矩形向量
函数来源: 原创
函数作者: Newer
适用版本: XDRX API 
最后更新时间: 2016-05-28
备注: -
演示图片:

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

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

×
本帖最后由 newer 于 2016-5-28 14:01 编辑

  1. (defun XD::Doc:GetRectang (info pts clr / con dis dynpt flag ins lastPnts
  2.                                 msg myerr olderr p1 p2 p3 p4 pts1 ret vec
  3.                                 xdir ydir RecCallback1 RecCallback2
  4.                           )
  5.   (defun RecCallback1 (dynpt /)
  6.     (redraw)
  7.     (setq ins (car (xd::pnts:orthoproject (list dynpt) p1 p2)))
  8.     (setq vec (mapcar
  9.                 '-
  10.                 dynpt
  11.                 ins
  12.               )
  13.     )
  14.     (if (not lastPnts)
  15.       (setq lastPnts (cons dynpt lastPnts))
  16.       (setq lastPnts (list dynpt (car lastPnts)))
  17.     )
  18.     (setq p3 (mapcar
  19.                '+
  20.                p2
  21.                vec
  22.              )
  23.           p4 (mapcar
  24.                '+
  25.                p1
  26.                vec
  27.              )
  28.           pts1 (list p1 p2 p3 p4)
  29.     )
  30.     (apply
  31.       'xdrx_grdraw
  32.       (append
  33.         (list clr con)
  34.         (xd::pnts:close pts1)
  35.       )
  36.     )
  37.     p3
  38.   )
  39.   (defun RecCallback2 (dynpt /)
  40.     (redraw)
  41.     (setq p3 dynpt
  42.           p2 (mapcar
  43.                '+
  44.                p1
  45.                xdir
  46.              )
  47.           p2 (car (xd::pnts:orthoproject (list p3) p1 p2))
  48.           p4 (car (xd::pnts:orthoproject (list p3) p1 (mapcar
  49.                                                         '+
  50.                                                         p1
  51.                                                         ydir
  52.                                                       )
  53.                   )
  54.              )
  55.     )
  56.     (if (not lastPnts)
  57.       (setq lastPnts (cons dynpt lastPnts))
  58.       (setq lastPnts (list dynpt (car lastPnts)))
  59.     )
  60.     (xdrx_grdraw clr con p1 p2 p3 p4 p1)
  61.     dynpt
  62.   )
  63.   (defun myerr (msg)
  64.     (princ (strcat "\n" msg))
  65.     (setq *error* myerr)
  66.     (redraw)
  67.     (xdrx_end)
  68.     (XD::Doc:Command (list ".undo" 1))
  69.   )
  70.   (setq olderr *error*)
  71.   (setq *error* myerr)
  72.   (xdrx_begin)
  73.   (setq p1 (car pts)
  74.         p2 (cadr pts)
  75.         flag 0
  76.   )                                     
  77.   (setq p1 (trans p1 1 0))
  78.   (if p2
  79.     (setq p2 (trans p2 1 0))
  80.   )
  81.   (setq xdir (getvar "ucsxdir")
  82.         ydir (getvar "ucsydir")
  83.   )
  84.   (setvar "lastPoint" (trans p1 0 1))
  85.   (if p2
  86.     (progn
  87.       (setq flag 1)
  88.     )
  89.   )
  90.   (if (not clr)
  91.     (setq clr 1)
  92.   )
  93.   (if (minusp clr)
  94.     (setq con 0
  95.           clr (abs clr)
  96.     )
  97.     (setq con 1)
  98.   )
  99.   (xdrx_pointmonitor (if (= flag 1)
  100.                        "RecCallback1"
  101.                        "RecCallback2"
  102.                      )
  103.   )
  104.   (setq ret (getpoint info))
  105.   (xdrx_pointmonitor)
  106.   (cond
  107.     ((= (type ret) 'STR))
  108.     ((= (type ret) 'LIST)
  109.       (if (not (equal (last lastpnts) (trans ret 1 0) 1e-3))
  110.         (progn
  111.           (if (cadr pts)
  112.             (progn
  113.               (setq dis (distance ret (trans p1 0 1))
  114.                     ins (car (xd::pnts:orthoproject (list (trans ret 1 0))
  115.                                                     p1 p2
  116.                              )
  117.                         )
  118.               )
  119.               (setq vec (mapcar
  120.                           '-
  121.                           (trans ret 1 0)
  122.                           ins
  123.                         )
  124.               )
  125.               (setq vec (xdrx_vector_product (xdrx_vector_normalize vec) dis)
  126.                     p3 (mapcar
  127.                          '+
  128.                          p2
  129.                          vec
  130.                        )
  131.                     p4 (mapcar
  132.                          '+
  133.                          p1
  134.                          vec
  135.                        )
  136.               )
  137.             )
  138.           )
  139.         )
  140.       )
  141.       (setq ret (xd::pnts:wcs2ucs (list p1 p2 p3 p4)))
  142.     )
  143.   )
  144.   (redraw)
  145.   (setq *error* olderr)
  146.   (xdrx_end)
  147.   ret
  148. )


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

本版积分规则

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

GMT+8, 2024-4-27 04:34 , Processed in 0.377896 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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