明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1671|回复: 6

请大家帮我挑错

[复制链接]
发表于 2002-11-27 11:32:00 | 显示全部楼层 |阅读模式
小弟有一作业,情况是这样的:
在任意直线上得一点,再得不在这一直线上的点作为方向,然后画表面粗糙度.
小弟参考了上次网友 chg 在 "用(ssget )可以做到" 一文中的办法
想半天,做不出,ssget实体选择实在有点过不去
请各位帮忙挑错,感谢感谢...
(defun c:t2(/ p1 p2 p3 p4 p5 p6 p7 p8 ang ang1 k ename ss)
  (setq p1 (getpoint "\n input p1"))
  (setq p5 (getpoint "\n input p2"))
  (setq k (getdist "\n input k"))
  (setq ss (ssget p1))
  (setq ename (ssname ss 0))
  (setq p2 (cdr (assoc 10 (entget ename))))
  (setq p3 (cdr (assoc 11 (entget ename))))
  (setq ang (angle p2 p3))
  (setq ang1 (angle p1 p5))
  (cond
    ((> (- ang1 pi) ang)
     (setq p6 (polar p1 (- ang (/ pi 3)) (* 10 k)))
     (setq p7 (polar p1 (- ang (* (/ pi 3) 2) (* 10 k))))
     (setq p8 (polar p1 (- ang (* (/ pi 3) 2) (* 20 K)))))
    ((and (> ang1 ang) (< ang1 (+ ang pi)))
     (setq p6 (polar p1 (+ ang (* (/ pi 3) 2) (* 10 k))))
     (setq p7 (polar p1 (+ ang (/ pi 3) (* 10 k))))
     (setq p8 (polar p1 (+ ang (/ pi 3) (* 20 K)))))
    ((and (> ang1 0) (< ang1 ang))
     (setq p6 (polar p1 (- ang (/ pi 3)) (* 10 k)))
     (setq p7 (polar p1 (- ang (* (/ pi 3) 2) (* 10 k))))
     (setq p8 (polar p1 (- ang (* (/ pi 3) 2) (* 20 K))))))
  (command "pline" p7 p6 p1 p8 "")
  )
  
注:k是画粗糙度的比例系数
发表于 2002-11-28 11:04:00 | 显示全部楼层

你也太粗心了吧。

你的思路和方法基本正确,但是括号不匹配。
将正确的程序贴给你。
(defun c:t2 (/ p1 p2 p3 p4 p5 p6 p7 p8 ang ang1 k ename ss)
  (setq p1 (getpoint "\n input p1"))
  (setq p5 (getpoint "\n input p2"))
  (setq k (getdist "\n input k"))
  (setq ss (ssget p1))
  (setq ename (ssname ss 0))
  (setq p2 (cdr (assoc 10 (entget ename))))
  (setq p3 (cdr (assoc 11 (entget ename))))
  (setq ang (rem (angle p2 p3) (* 2 pi)))
  (setq ang1 (angle p1 p5))
  (cond
    ((> (- ang1 pi) ang)
     (setq p6 (polar p1 (- ang (/ pi 3)) (* 10 k)))
     (setq p7 (polar p1 (- ang (* (/ pi 3) 2)) (* 10 k)))
     (setq p8 (polar p1 (- ang (* (/ pi 3) 2)) (* 20 K)))
    )
    ((and (> ang1 ang) (< ang1 (+ ang pi)))
     (setq p6 (polar p1 (+ ang (* (/ pi 3) 2)) (* 10 k)))
     (setq p7 (polar p1 (+ ang (/ pi 3)) (* 10 k)))
     (setq p8 (polar p1 (+ ang (/ pi 3)) (* 20 K)))
    )
    ((and (> ang1 0) (< ang1 ang))
     (setq p6 (polar p1 (- ang (/ pi 3)) (* 10 k)))
     (setq p7 (polar p1 (- ang (* (/ pi 3) 2)) (* 10 k)))
     (setq p8 (polar p1 (- ang (* (/ pi 3) 2)) (* 20 K)))
    )
  )
  (command "pline" p7 p6 p1 p8 "")
)
发表于 2002-11-28 12:36:00 | 显示全部楼层

在(setq SS (ssget P1))前要增加一行程序(setq P1 (osnap P1 "NEA"))

 楼主| 发表于 2002-11-28 12:48:00 | 显示全部楼层

有问题

只能画一半呀
我看看...
 楼主| 发表于 2002-11-30 09:39:00 | 显示全部楼层

有问题呀!

还是不行
只能画到一半
发表于 2002-12-2 16:32:00 | 显示全部楼层

TRY

(defun C:T2 (/ HOLDOSMODE P1 P2 P3 P4 P5 P6 P7 P8 ANG ANG1 K ENAME SS)
  (setq HOLDOSMODE (getvar "OSMODE"))
  (setvar "OSMODE" 0)
  (initget 1)
  (setq P1 (getpoint "\n任意直线上得一点: "))
  (initget 1)
  (setq P5 (getpoint "\n方向点: "))
  (setq K (getdist "\n粗糙度的比例系数: "))
  (if (= K NIL)
    (setq K 1)
  )
  (setq P1 (osnap P1 "NEA"))
  (setq SS (ssget P1))
  (setq ENAME (ssname SS 0))
  (setq P2 (cdr (assoc 10 (entget ENAME))))
  (setq P3 (cdr (assoc 11 (entget ENAME))))
  (setq ANG (angle P2 P3))
  (setq ANG1 (angle P1 P5))
  (cond
    ((> (- ANG1 pi) ANG)
     (setq P6 (polar P1 (- ANG (/ pi 3)) (* 10 K)))
     (setq P7 (polar P1 (- ANG (* (/ pi 3) 2)) (* 10 K)))
     (setq P8 (polar P1 (- ANG (* (/ pi 3) 2)) (* 20 K)))
    )
    ((and (> ANG1 ANG) (< ANG1 (+ ANG pi)))
     (setq P6 (polar P1 (+ ANG (* (/ pi 3) 2)) (* 10 K)))
     (setq P7 (polar P1 (+ ANG (/ pi 3)) (* 10 K)))
     (setq P8 (polar P1 (+ ANG (/ pi 3)) (* 20 K)))
    )
    ((and (> ANG1 0) (< ANG1 ANG))
     (setq P6 (polar P1 (- ANG (/ pi 3)) (* 10 K)))
     (setq P7 (polar P1 (- ANG (* (/ pi 3) 2)) (* 10 K)))
     (setq P8 (polar P1 (- ANG (* (/ pi 3) 2)) (* 20 K)))
    )
  )
  (command "pline" P7 P6 P1 P8 "")
  (setvar "osmode" HOLDOSMODE)
  (princ)
)
 楼主| 发表于 2002-12-2 19:54:00 | 显示全部楼层

多谢!!!

感谢!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-9-28 02:14 , Processed in 0.195858 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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