明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: raimo

[函数] [已解决]请高手帮忙做个简单的等分工具

  [复制链接]
发表于 2011-6-21 07:45 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2011-6-21 08:42 | 显示全部楼层
回复 ljpnb 的帖子

是我考虑不周,谢谢提醒!
发表于 2011-6-21 10:27 | 显示全部楼层
回复 1078815748 的帖子

不知道你要什么样的效果。
发表于 2011-6-21 11:03 | 显示全部楼层
zhynt 发表于 2011-6-20 21:05
也来凑个热闹(改了一下)
修改了一下,相对完美了一些。

我看程序还不够完美,当等分线与参考线不垂直时,出来的结果会不一样。。
我图片贴不上来,不然会一看就明白了。。。。
发表于 2011-6-21 11:29 | 显示全部楼层
本帖最后由 zhynt 于 2011-6-21 11:34 编辑

回复 ljpnb 的帖子

哦,按你的要求改了一下,增加参考线方向的判断:

  1.   (setq ptangle (angle pt1 pt2)
  2.           ptangle2 (angle pt3 pt4)          ;参考线角度
  3.           ptn (polar pta ptangle2 0.01)   ;按参考线方向生成参考点
  4.           jpt (inters pta ptn pt1 pt2 nil)
  5.           ang (angle jpt pta)
  6.            l3 (/ (- l1 (* jianju (- n 1))) n)
  7.           pt5 (polar pt1 ptangle l3)
  8.   )


本帖子中包含更多资源

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

x
发表于 2011-6-21 12:01 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2011-6-21 12:07 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2011-6-21 14:02 | 显示全部楼层
本帖最后由 ljpnb 于 2011-6-21 14:04 编辑
1078815748 发表于 2011-6-21 12:07
回复 1078815748 的帖子

遇到这样的分格总是用手算出来再把点放上去,工作用量太大了,也太麻烦了,总想找 ...


  1. (defun c:test ()
  2.   (princ "\n请选择需要等分的圆弧:")
  3.   (if (setq ss (ssget '((0 . "ARC"))))
  4.     (progn
  5.       (setq n (getint "\n 输入几个大格:"))
  6.       (or (setq l (getreal "\n输入小格弧长<15>:")) (setq l 15.))
  7.       (setq i 0)
  8.       (setq os (getvar "osmode"))
  9.       (setvar "osmode" 0)
  10.       (setvar "pdmode" 34);;值可以设定其它的           
  11.       (SETVAR "CMDECHO" 0)
  12.       (command "undo" "g")
  13.       (repeat (sslength ss)
  14.         (setq obj (vlax-Ename->Vla-Object (ssname ss i)))
  15.         (setq len (vla-get-arclength obj))
  16.         (setq dis (/ (- len (* l (1- n))) n))
  17.         (setq k 1.)
  18.         (repeat        (1- n)
  19.           (setq        point1
  20.                  (vlax-curve-getPointAtDist obj (+ (* k dis) (* (1- k) l)))
  21.           )
  22.           (setq        point2
  23.                  (vlax-curve-getPointAtDist obj (+ (* k dis) (* k l)))
  24.           )
  25.           (command "point" point1)
  26.           (command "point" point2)
  27.           (setq k (1+ k))
  28.         )
  29.         (setq i (1+ i))
  30.       )
  31.     )
  32.   )
  33.   (setvar "osmode" os)
  34.   (command "undo" "e")
  35.   (SETVAR "CMDECHO" 1)
  36.   (princ)
  37. )

评分

参与人数 1金钱 +20 收起 理由
429014673 + 20 谢谢。

查看全部评分

发表于 2011-6-21 14:14 | 显示全部楼层
另类等分

本帖子中包含更多资源

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

x
发表于 2011-6-21 14:34 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-5-7 20:29 , Processed in 0.302611 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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