找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 865|回复: 1

[LISP程序]:两个函数。

[复制链接]

已领礼包: 593个

财富等级: 财运亨通

发表于 2002-10-11 14:07:36 | 显示全部楼层 |阅读模式

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

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

×

  1. (defun 3dPoint->2dPoint  (3dpt)
  2.         (list  (float (car 3dpt))  (float (cadr 3dpt)))
  3. )
  4. ;; '(0 1) (1 1) (2 2) ...) ----> '(0 1 1 1 2 2 ...)
  5. (defun mlist->slist (lst / tmplst)
  6.   (setq        lst    (reverse (mapcar '3dPoint->2dPoint lst)))
  7.   (foreach n lst
  8.     (setq tmplst (append (cdr n) tmplst)
  9.           tmplst (append (list (car n)) tmplst)
  10.     )
  11.   )
  12.   tmplst
  13. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2002-10-12 01:58:13 | 显示全部楼层
用你的第一个函数写了个小程序,
我叫它2维移动和2维拷贝,做三维
建模的时候挺方便:


  1. (defun c:m2d ()
  2.   (2dshift "move")
  3.   (princ)
  4. )
  5. (defun c:c2d ()
  6.   (2dshift "copy")
  7.   (princ)
  8. )
  9. (defun 2dshift (str_in / ss1 pt1 pt2 os cmd)
  10.   (setq ss1 (ssget))
  11.   (if ss1 (setq pt1 (getpoint "\nSpecify base point: ")))
  12.   (if pt1 (setq pt2 (getpoint pt1 "\nSpecify second point: ")))
  13.   (if pt2
  14.     (progn
  15.       (setq pt1 (3dPoint->2dPoint pt1)
  16.             pt2 (3dPoint->2dPoint pt2))
  17.       (setq os (getvar "osmode")
  18.             cmd (getvar "cmdecho"))
  19.       (setvar "osmode" 0)
  20.       (setvar "cmdecho" 0)
  21.       (command str_in ss1 "" pt1 pt2)
  22.       (setvar "osmode" os)
  23.       (setvar "cmdecho" cmd)
  24.     );progn
  25.   );if
  26. );end

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-26 02:23 , Processed in 0.152739 second(s), 34 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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