找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 364|回复: 3

[每日一码] GRDRAW使用线型

[复制链接]

已领礼包: 19个

财富等级: 恭喜发财

发表于 2021-1-19 10:52:06 | 显示全部楼层 |阅读模式

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

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

×
  1. ;;;   ----------- GrDraw eXension - Version 1.0 -----------
  2. ;;;   Copyright (C) 2010 by ResourceCAD International
  3. ;;;   Author:   K.E. Blackie
  4. ;;;   
  5. ;;;   
  6. ;;;   RCI PROVIDES THIS PROGRAM "AS IS" AND WITH ALL FAULTS.
  7. ;;;   RESOURCECAD INTERNATIONAL SPECIFICALLY DISCLAIMS ANY
  8. ;;;   IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR
  9. ;;;   USE.  RESOURCECAD INTERNATIONAL DOES NOT WARRANT THAT THE OPERATION
  10. ;;;   OF THE PROGRAM WILL BE UNINTERRUPTED OR ERROR FREE.
  11. ;;;   
  12. ;;;   
  13. ;;;   ResouceCAD International
  14. ;;;   http://www.resourcecad.com
  15. ;;;   
  16. ;;;   DESCRIPTION
  17. ;;;   GrDraw eXtension draws linetypes representative of the linetype specified
  18. ;;;   This does not including complex linetypes using text and shape modifiers,
  19. ;;;   although those may be added in the future.
  20. ;;;   
  21. ;;;   USAGE
  22. ;;;   (grdrawlinetype <point> <point> intColor "CENTER")
  23. ;;;   i.e. (grdrawlinetype '(0 0 0) '(0 10 0) 2 "CENTER") will draw a yellow line
  24. ;;;   from 0,0,0 to 0,10,0 with the linetype of CENTER
  25. ;;;   
  26. ;;;   
  27. ;;;   May 04, 2010
  28. ;;;   
  29. ;;;   ------------------------------------------------------------

  30. (defun grdrawlinetype (start end color linetype / elelist end firstelement linelength ltypedef ndx nend nstart numelements patlength start tmppoint)
  31.   (if (setq ltypedef (tblsearch "ltype" linetype))
  32.     (progn
  33.       ;get the elements of the linetype
  34.       (setq numelements (cdr (assoc 73 ltypedef))
  35.             elelist (member (assoc 49 ltypedef) ltypedef)
  36.       )
  37.       ;calculate the pattern length
  38.       (setq patlength 0 ndx 0)
  39.       (repeat numelements
  40.               (setq patlength (+ patlength (*(abs (cdr (nth ndx elelist)))(getvar "ltscale")))
  41.               ndx (1+ ndx))
  42.       )
  43.       (setq linelength (distance start end))
  44.       (setq firstelement (*(abs (cdr (nth 0 elelist)))(getvar "ltscale")))
  45.       (if (< linelength patlength)
  46.         (setq numelements 0
  47.               elelist nil)
  48.         (setq firstelement (/ (- (* (+ (-(/ linelength patlength)(fix(/ linelength patlength)))1) patlength)(- patlength firstelement))2.0))
  49.       )
  50.       ;draw the pattern
  51.       (setq nstart start
  52.             nend end)
  53.       (while (and (> (distance nstart nend) 0) (> numelements 0))
  54.         (setq ndx 0)
  55.         (while (< ndx numelements)
  56.           (if (< (cdr (nth ndx elelist)) 0)
  57.             (progn
  58.               (if (= (distance nstart nend) linelength)
  59.                 (progn
  60.                   (setq tmppoint (polar nstart (angle nstart nend) firstelement))
  61.                         (if (> (distance nstart tmppoint) (distance nstart nend))
  62.                     (setq nstart nend
  63.                           ndx numelements)
  64.                     (setq nstart tmppoint
  65.                           ndx (+ ndx 1))
  66.                         )
  67.                 )
  68.                 (progn
  69.                         (setq tmppoint (polar nstart (angle nstart nend)(*(*(cdr (nth ndx elelist))-1)(getvar "ltscale"))))
  70.                         (if (> (distance nstart tmppoint) (distance nstart nend))
  71.                     (setq nstart nend
  72.                           ndx numelements)
  73.                     (setq nstart tmppoint
  74.                           ndx (+ ndx 1))
  75.                         )
  76.                 )
  77.               )
  78.             )
  79.             (progn
  80.               (if (= (distance nstart nend) linelength)
  81.                 (setq tmppoint (polar nstart (angle nstart nend) firstelement))
  82.                 (setq tmppoint (polar nstart (angle nstart nend) (*(cdr (nth ndx elelist))(getvar "ltscale"))))
  83.               )
  84.               (if (> (distance nstart tmppoint) (distance nstart nend))
  85.                 (setq tmppoint nend
  86.                       ndx numelements)
  87.                 (if (> (+ (distance nstart tmppoint)(abs (cdr (nth ndx elelist))))(distance nstart nend))
  88.                   (setq tmppoint nend
  89.                         ndx numelements)
  90.                 )
  91.               )
  92.               (grdraw nstart tmppoint color)
  93.               (setq nstart tmppoint)
  94.               (setq ndx (+ ndx 1))
  95.             )
  96.           )
  97.           (if (<= (distance nstart nend) 0)
  98.             (setq ndx numelements)
  99.           )
  100.         )
  101.       )
  102.       (if (= numelements 0)
  103.         (grdraw start end color)
  104.       )
  105.     )
  106.     (grdraw start end color)
  107.   )
  108. )

评分

参与人数 1D豆 +5 收起 理由
/db_自贡黄明儒_ + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

已领礼包: 5586个

财富等级: 富甲天下

发表于 2021-1-19 16:24:31 | 显示全部楼层
大师,你这贴与主题不符,内容与上一贴是一样的
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 604个

财富等级: 财运亨通

发表于 2021-1-19 17:03:38 | 显示全部楼层
HLCAD 发表于 2021-1-19 16:24
大师,你这贴与主题不符,内容与上一贴是一样的

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

使用道具 举报

已领礼包: 19个

财富等级: 恭喜发财

 楼主| 发表于 2021-1-19 17:20:11 | 显示全部楼层
HLCAD 发表于 2021-1-19 16:24
大师,你这贴与主题不符,内容与上一贴是一样的

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-26 22:33 , Processed in 0.180992 second(s), 38 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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