CAD LISP 程序教程文件.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
1.计算所有线段总长度(加载后只需框选所有线段便可得出这些线段的总长度) (defun c:LL () (setvar cmdecho 1) (setq en (ssget (list (0 . spline,arc,line,ellipse,LWPOLYLINE)))) (setq i 0) (setq ll 0) (repeat (sslength en) ? (setq ss (ssname en i)) ? (setq endata (entget ss)) ? (command lengthen ss ) ? (setq dd (getvar perimeter)) (setq ll (+ dd ll)) ? (setq i (1+ i)) ) ? (princ 所选线条总长为:)(princ ll)(princ) ) 2.标注所有线段(加载后只需框选所有线段便可得标注这些线段) (defun c:LLL () (COMMAND UCS ) (setvar cmdecho 1) (SETVAR OSMODE 0) (setq ? ?AcadObject ? (vlax-get-acad-object) ? ?AcadDocument (vla-get-ActiveDocument Acadobject) ? ?mSpace ? ? ? (vla-get-ModelSpace Acaddocument) ) ;;选取需要测量的样条曲线、圆弧、直线、椭圆 (setq en (ssget (list (0 . spline,arc,line,ellipse,LWPOLYLINE)))) (setq i 0) ;;获取系统参数textsize (setq shh (getvar textsize)) (setq str_hh (strcat \n文字高度 (rtos shh 2) : )) (setq hh (getdist str_hh)) (while hh (setvar textsize hh) (setq hh nil)) ;;输入标注文字高度 ;;循环开始 (repeat (sslength en) ? (setq ss (ssname en i)) ? (setq endata (entget ss)) ? (command lengthen ss ) ? (setq dd (getvar perimeter)) ? (princ (strcat \n长度= (rtos dd 2))) ? ;;寻找代表图层的字符串 ? (setq aa (assoc 0 endata)) ? ;;获取图层名称 ? (setq aa1 (cdr aa)) ? ;;判断线条种类 ? (cond ? ? ((= aa1 SPLINE) ? ? ;;如果是spline ? ? (progn ? ? (setq arcObj (VLAX-ENAME-VLA-OBJECT ss)) ? ? (setq startPnt1 (vla-get-ControlPoints arcObj)) ? ? (setq p1 ? ? ? ?(vlax-safearray-list (vlax-variant-value startPnt1)) ? ? ) ? ? (setq x1 (car p1)) ? ? (setq y1 (cadr p1)) ? ? (setq z1 (caddr p1)) ? ? (setq pp1 (list x1 y1 z1)) ? ? (repeat (- (/ (length p1) 3) 1) ? ? ? ;;循环,寻找最后一个控制点 ? ? ? (setq p1 (cdddr p1)) ? ? ? (setq x2 (car p1)) ? ? ? (setq y2 (cadr p1)) ? ? ? (setq z2 (caddr p1)) ? ? ) ? ? (setq pp2 (list x2 y2 z2)) ? ? ) ? ? ) ? ? ((= aa1 LWPOLYLINE) ? ? ;;如果是LWPOLYLINE ? ? (progn ? ? (setq arcObj (VLAX-ENAME-VLA-OBJECT ss)) ? (setq startPnt1 (vla-get-Coordinates arcObj)) ? (setq p1 ? ? ? (vlax-safearray-list (vlax-variant-value startPnt1)) ? ) ? ? (setq x1 (car p1)) ? ? (setq y1 (cadr p1)) ? ? (setq z1 (caddr p1))

文档评论(0)

189****1013 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档