找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 955|回复: 0

[LISP函数]根据新y值形成新的偏移点表

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2013-8-16 09:03:41 | 显示全部楼层 |阅读模式

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

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

×
  1. ;;;根据新y值形成新的偏移点表,新点均在基点右侧 by PEACE 2013/06/28
  2. ;;;plst=原始点表 vy=y坐标 ang=角度(弧度)
  3. (defun PEACE:PointList_OffsetPointYR(plst vy ang / n newplst i p newp x0 y0)
  4.   (setq     n (length plst)
  5.       newplst '()
  6.             i 0
  7.   )
  8.   (repeat n
  9.     (setq p (nth i plst)
  10.          x0 (car p)
  11.          y0 (cadr p)
  12.     )
  13.     (if (> x0 (+ x0 (* (- vy y0) (/ (cos ang) (sin ang)))))
  14.       (setq ang (- pi ang))
  15.     )
  16.     (setq x (+ x0 (* (- vy y0) (/ (cos ang) (sin ang))))
  17.        newp (list x vy)
  18.     newplst (cons newp newplst)
  19.           i (1+ i)
  20.     )
  21.   )
  22.   (setq newplst (reverse newplst))
  23.   newplst
  24. )
  25. ;;;根据新y值形成新的偏移点表,新点均在基点左侧 by PEACE 2013/06/28
  26. ;;;plst=原始点表 vy=y坐标 ang=角度(弧度)
  27. (defun PEACE:PointList_OffsetPointYL(plst vy ang / n newplst i p newp x0 y0)
  28.   (setq     n (length plst)
  29.       newplst '()
  30.             i 0
  31.   )
  32.   (repeat n
  33.     (setq p (nth i plst)
  34.          x0 (car p)
  35.          y0 (cadr p)
  36.     )
  37.     (if (< x0 (+ x0 (* (- vy y0) (/ (cos ang) (sin ang)))))
  38.       (setq ang (- pi ang))
  39.     )
  40.     (setq x (+ x0 (* (- vy y0) (/ (cos ang) (sin ang))))
  41.        newp (list x vy)
  42.     newplst (cons newp newplst)
  43.           i (1+ i)
  44.     )
  45.   )
  46.   (setq newplst (reverse newplst))
  47.   newplst
  48. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-11-22 06:58 , Processed in 0.171033 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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