明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1716|回复: 4

【求助】求助帮忙修改一程序。谢谢。

[复制链接]
发表于 2012-2-17 00:24:42 | 显示全部楼层 |阅读模式
在明经网找到了一个批量偏移的程序,但在使用过程中出现了一些问题,正如论坛会员据说的:颜色不会变;上大下小的梯形,选择外偏移,出来的还是向里偏移。请求大家帮忙修改下。

;;luyu9635 2009/02/22
;;多对象同时偏移(setq end(entlast))
;;不支持自相交曲线和不封闭曲线
(defun c:qq(/ di ds en po1 po2 obj endxf fx a1 a2 ys)
  (vl-load-com)
  (setq os(getvar 'osmode) cmd(getvar 'cmdecho))
  (setq oer *error* *error* my)
  (setq po nil fx nil dd nil)
  (setvar "osmode" 0)
  (setvar "cmdecho" 0)
  (setvar "nomutt" 1)
  (setq ss(ssget(car(list nil(print '请选择要同时偏移的对象:)))))
  (setvar "nomutt" 0)
  (setq dd(abs(getvar "offsetdist")))
  (setq ds(getdist(strcat "\n输入偏移距离<" (rtos dd) ">:")))
  (if (not ds) (setq ds dd))
  (initget "1 2 3 4 nil")
  (setq fx(getkword "\n请选择偏移方式:1/内-2/外-3双向-4/自定义<2>:"))
  (if (not fx)(setq fx "2"))
  (initget "1 2 3 4 5 6 7 nil")
  (setq ys(getint "\n颜色改为:1红-2黄-3绿-4青-5蓝-6紫-7白<1>:"))
  (if (not ys)(setq ys 1))
  (setq sslen(sslength ss) i 0)
  (vl-cmdf "UNDO" "G")
  (repeat sslen
    (setq en(ssname ss i))
    (setq obj (vlax-ename->vla-object EN))
    (setq endxf(dxf 0 en))
    (cond ((or (= endxf "CIRCLE") (= endxf "ELLIPSE"))
    (vla-getboundingbox obj 'll 'rr)
    (setq po2(vlax-safearray->list ll))
           (setq po1(dxf 10 en))
   )
  ((= endxf "ARC")(setq po1(dxf 10 en) PO2(POLAR PO1 0 (1+ (dxf 40 en)))))
         ((= endxf "SPLINE")
   (setq spo(vlax-curve-getStartPoint obj))
   (setq po1(polar spo 0 0.01) po2(polar spo 3.14 0.01))
         )
  ((= endxf "LINE")
   (setq p1(dxf 10 en) p2(dxf 11 en) an(angle p1 p2))
   (setq po1(polar p1 (+ an 0.01) 0.01) po2(polar p1 (- an 0.01) 0.01))
   )
  ((= endxf "LWPOLYLINE")
   (setq plist '())
   (mapcar '(lambda (x) (if (= (car x) 10) (setq plist(cons (cdr x) plist))))(entget en))
   (setq p1(nth 0 plist) p2(nth 1 plist) p3(nth 2 plist))
   (setq a1(+ (angle p2 p1) 0.01) a2(+ (angle p2 p3) 0.01))
   (setq po1(polar  p2 a1 0.01) po2(polar p2 a2 0.01))
         )
     )
    (cond ((= fx "1")
     (command "offset" ds en po1 "")
            (if (> (eaa (entlast)) (eaa obj))
       (progn (entdel (entlast)) (setq po po2)
              (command "offset" ds en po2 "")))
    )
   ((= fx "2")      
            (command "offset" ds en po1 "")
            (if (< (eaa (entlast)) (eaa obj))
       (progn (entdel (entlast)) (setq po po2)
              (command "offset" ds en po2 "")))
           )
   ((= fx "3")
    (command "offset" ds en po1 "")
    (command "offset" ds en po2 "")
    )
   ((= fx "4")
    (if (not po) (setq po(getpoint "\n请指定要偏移的一侧:")))
    (command "offset" ds en po "")
    )
   )
    (setq i(1+ i))
    )
  (while (setq end(entnext end))
    (command "chprop" end "" "c" ys "")
    )
  (command "select" ss "")
  (vl-cmdf "UNDO" "E")
  (setvar 'osmode os)(setvar 'cmdecho cmd)
  (princ)
  )
;;;;
(defun EAA(x) ;求面积
  (setq ena(vlax-curve-getArea x))
  )
;;;
(defun dxf(n en)
  (cdr(assoc n (entget en)))
  )
;;;
(defun my(s)
   (if (/= s "Function canccelled")
     (princ"取消"))
  (setvar 'osmode os)(setvar 'cmdecho cmd)(setvar "nomutt" 0)
  (setq *error* oer)
  )


该贴已经同步到 CTC的微博
发表于 2012-2-17 01:30:14 | 显示全部楼层
本帖最后由 langjs 于 2012-2-17 01:32 编辑

不知道怎么回事
 楼主| 发表于 2012-2-17 01:36:34 | 显示全部楼层
langjs 发表于 2012-2-17 01:30
不知道怎么回事

原程序问题:   一是偏移出来的线不会按提示变颜色,二是大下小的梯形,选择外偏移,出来的有时是向里偏移了
 楼主| 发表于 2012-2-17 23:16:53 | 显示全部楼层
ZZXXQQ超版,帮忙呀...
发表于 2013-4-3 09:53:57 | 显示全部楼层
我也发现这个问题了  不知道是不是版本的问题
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-31 00:23 , Processed in 0.193912 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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