找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2017|回复: 7

[研讨] 【炫翔】根据点表生成直线最快方法

[复制链接]

已领礼包: 1742个

财富等级: 堆金积玉

发表于 2013-9-11 11:48:58 | 显示全部楼层 |阅读模式

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

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

×
方法一用ENTMAKE
  1. ;点集生成直线
  2. ;(xx-mk-line-pts '((0 0 0)(0 5 0)(5 0 0)(0 10 5)))
  3. ;(xx-mk-line-pts (list(getpoint)(getpoint)(getpoint)))
  4. (DEFUN xx-mk-line-pts(pts / lst)
  5.   (setq lst (xx-lst-DengFen pts 2))
  6.   (mapcar(function(lambda (x)(xx-mk-line (car x) (cadr x)))) lst)
  7. )

  8. (defun xx-lst-DengFen (Lst mun / flag i k n rl tmp)
  9. (IF(AND(= (type LST) 'LIST)(= (type MUN) 'INT) )
  10.   (progn
  11.     (setq i 0)
  12.     (setq n (- (length lsT) (1- MUN)));表的长度减去MUN减去1
  13.    (repeat n;循环上面的次数
  14.       (setq k i flag t tmp nil);初始化
  15.     (while (and flag (nth k lsT));当表的第K个值为真时,循环
  16.       (setq tmp(cons (nth k lsT) tmp ));组合第K个表元素
  17.       (setq k (1+ k))
  18.      (if (zerop(rem (- k i) MUN));直到表中元素为MUN的个数时,?
  19.         (setq flag nil;退出循环
  20.                rl (cons (reverse tmp) rl);将表依次加入表
  21.          )
  22.       )
  23.      )
  24.     (setq i (1+ i))
  25.    )
  26.    (reverse rl);跌倒表
  27.   )
  28.   (princ "\n xx-lst-DengFen  错了!")
  29. )
  30. )

  31. (defun xx-mk-line (pt1 pt2)
  32. (if(and pt1 pt2)
  33.   (progn
  34.    (entmake(list '(0 . "line")(cons 10 pt1)(cons 11 pt2)))
  35.   )
  36.   (princ "\n xx-mk-line  错了!")
  37. )(entlast)
  38. )



方法二:用CAD命令
  1. (defun xxx (pts / os)
  2. (setq os(getvar 'osmode))
  3. (setvar "osmode" 0)
  4.   (vl-cmdf "_.line")
  5.   (mapcar 'vl-cmdf pts)
  6.   (vl-cmdf "")
  7.   (setvar "osmode" os)
  8. )
测试程序

  1. (defun get-utime()(* 86400.0 (getvar"tdusrtimer")))
  2. (defun c:xx ( / pt pts)
  3.   (setq pt (getpoint) pts nil)
  4.   (repeat 100000
  5.    (setq pts(cons (setq pt1 (polar pt (* pi 0.5) 1)) pts))
  6.    (setq pt pt1)
  7.   )
  8.   (setq t1(get-utime))
  9.   (xxx pts)
  10.   (setq t2(get-utime))
  11.   (PRINC (list 0 0 (- t2 t1)))
  12.   (princ)
  13. )

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

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-11 06:45:28 来自手机 | 显示全部楼层
(mapcar '(lambda (p1 p2) (mkline p1 p2)) pts (cdr pts))

点评

虽然不懂,但还是支持  详情 回复 发表于 2014-12-22 20:22

评分

参与人数 1D豆 +5 收起 理由
炫翔 + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

使用道具 举报

发表于 2013-9-11 12:38:27 | 显示全部楼层
肯定ENTMAKE快,VLA/VBA/.NET/COMMAND/VL-CMDF/ENTMAKE   比较,C++没有测试过
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 145个

财富等级: 日进斗金

发表于 2013-9-11 12:48:04 | 显示全部楼层
翔版,把测试数据贴出来啊。

点评

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

使用道具 举报

发表于 2013-9-11 13:05:06 | 显示全部楼层
本帖最后由 Love-Lisp 于 2013-9-11 13:10 编辑

炫翔版主的entmake 点表直线的代码写的太累赘了,肯定没效率!
  1. (defun mkline (pts / p1 p2)
  2.   (setq p1 (car pts)
  3.   pts (cdr pts))
  4.   (foreach p2 pts
  5. (entmake      (list '(0 . "line")
  6.             '(100 . "AcDbEntity")
  7.             '(67 . 0)
  8.             '(410 . "Model")
  9.             '(100 . "AcDbLine")
  10.             (cons 10 p1)
  11.             (cons 11 p2)
  12.             )
  13.       )
  14.     (setq p1 p2)
  15.     )
  16.   )



评分

参与人数 1D豆 +5 收起 理由
炫翔 + 5 技术引导讨论和指点奖!

查看全部评分

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

使用道具 举报

已领礼包: 1742个

财富等级: 堆金积玉

 楼主| 发表于 2013-9-11 13:45:03 | 显示全部楼层
另一种思路:测试时间为:2.0几秒
  1. (defun makline (lst)
  2.    (entmake
  3.       (append   
  4.          (list
  5.            '(0 . "lwpolyline")
  6.            '(100 . "AcDbEntity")
  7.            '(100 . "AcDbPolyline")
  8.            (cons 90 (length lst))
  9.          )
  10.       (mapcar (function (lambda (pt)(cons 10 pt))) lst )
  11.      )
  12.    )
  13.    (vl-cmdf "_.EXPLODE" (entlast) "")
  14. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2014-12-22 20:22:57 | 显示全部楼层
st788796 发表于 2013-11-11 06:45
(mapcar '(lambda (p1 p2) (mkline p1 p2)) pts (cdr pts))

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-24 16:30 , Processed in 0.392479 second(s), 48 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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