明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3359|回复: 12

请教各位高手,如何根据填充图案,反推出填充边界?

  [复制链接]
发表于 2006-1-25 21:06:00 | 显示全部楼层 |阅读模式
请教各位高手,如何根据填充图案,反推出填充边界(比如能反画出填充边界线)?
发表于 2006-1-26 17:58:00 | 显示全部楼层

;;; 11 功能:通过选定的阴影图案生成边界线=================================
(defun c:hb () (c:hatchb))  called hb
 ;; this line can be commented out if there is an existing command
(defun c:hatchb (/          es         blay       ed1        ed2
                 loops1     bptf       part       et         noe
                 plist      ic         bul        nr         ang1
                 ang2       obj        *ModelSpace*
                 *PaperSpace*          space      cw         errexit
                 undox      olderr     oldcmdecho ss1        lastent
                 en1        en2        ss         lwp
                 list->variantArray    3dPoint->2dPoint      A2k
                 ent        i          ss2        knot-list
                 controlpoint-list     kn         cn         pos
                 xv
                )
  (setq A2k (wcmatch (getvar "ACADVER") "15*"))
  (if A2k
    (defun list->variantArray (ptsList / arraySpace sArray)
      (setq arraySpace
             (vlax-make-safearray
               vlax-vbdouble
               (cons 0 (- (length ptsList) 1))
             ) ;_ 结束vlax-make-safearray
      ) ;_ 结束setq
      (setq sArray (vlax-safearray-fill arraySpace ptsList))
      (vlax-make-variant sArray)
    ) ;_ 结束defun
  ) ;_ 结束if
  (if A2k
    (defun 3dPoint->2dPoint (3dpt)
      (list (float (car 3dpt)) (float (cadr 3dpt)))
    ) ;_ 结束defun
  ) ;_ 结束if

  (defun errexit (s)
    (princ "\nError:  ")
    (princ s)
    (restore)
  ) ;_ 结束defun

  (defun undox ()
    (command "._ucs" "_p")
    (command "._undo" "_E")
    (setvar "cmdecho" oldcmdecho)
    (setq *error* olderr)
    (princ)
  ) ;_ 结束defun

  (setq olderr  *error*
        restore undox
        *error* errexit
  ) ;_ 结束setq
  (setq oldcmdecho (getvar "cmdecho"))
  (setvar "cmdecho" 0)
  (command "._UNDO" "_BE")
  (if A2k
    (progn
      (vl-load-com)
      (setq *ModelSpace* (vla-get-ModelSpace
                           (vla-get-ActiveDocument (vlax-get-acad-object))
                         ) ;_ 结束vla-get-ModelSpace
            *PaperSpace* (vla-get-PaperSpace
                           (vla-get-ActiveDocument (vlax-get-acad-object))
                         ) ;_ 结束vla-get-PaperSpace
      ) ;_ 结束setq
    ) ;_ 结束progn
  ) ;_ 结束if
  ;; For testing purpose
  ;; (setq A2k nil)
  (if (/= (setq ss2 (ssget '((0 . "HATCH")))) nil)
    (progn
      (setq i 0)
      (while (setq ent (ssname ss2 i))
        (setq ed1 (entget ent))
        (if (not (equal (assoc 210 ed1) '(210 0.0 0.0 1.0)))
          (princ "\nHatch not in WCS!")
        ) ;_ 结束if
        (setq xv (cdr (assoc 210 ed1)))
        (command "._ucs" "_w")
        (setq loops1 (cdr (assoc 91 ed1)))
                                        ; number of boundary paths (loops)
        (if (and A2k (= (strcase (cdr (assoc 410 ed1))) "MODEL"))
          (setq space *ModelSpace*)
          (setq space *PaperSpace*)
        ) ;_ 结束if
        (repeat loops1
          (setq ed1 (member (assoc 92 ed1) ed1))
          (setq bptf (cdr (car ed1)))   ; boundary path type flag
          (setq ic (cdr (assoc 73 ed1))) ; is closed
          (setq noe (cdr (assoc 93 ed1))) ; number of edges
          (setq ed1 (member (assoc 72 ed1) ed1))
          (setq bul (cdr (car ed1)))    ; bulge
          (setq plist nil)
          (setq blist nil)
          (cond
            ((> (boole 1 bptf 2) 0)     ; polyline
             (repeat noe
               (setq ed1 (member (assoc 10 (cdr ed1)) ed1))
               (setq plist (append plist (list (cdr (assoc 10 ed1)))))
               (setq blist (append blist
                                   (if (> bul 0)
                                     (list (cdr (assoc 42 ed1)))
                                     nil
                                   ) ;_ 结束if
                           ) ;_ 结束append
               ) ;_ 结束setq
             ) ;_ 结束repeat
             (if A2k
               (progn
                 (setq polypoints
                        (apply 'append
                               (mapcar '3dPoint->2dPoint plist)
                        ) ;_ 结束apply
                 ) ;_ 结束setq
                 (setq VLADataPts (list->variantArray polypoints))
                 (setq
                   obj (vla-addLightweightPolyline space VLADataPts)
                 ) ;_ 结束setq
                 (setq nr 0)
                 (repeat (length blist)
                   (if (/= (nth nr blist) 0)
                     (vla-setBulge obj nr (nth nr blist))
                   ) ;_ 结束if
                   (setq nr (1+ nr))
                 ) ;_ 结束repeat
                 (if (= ic 1)
                   (vla-put-closed obj T)
                 ) ;_ 结束if
               ) ;_ 结束progn
               (progn
                 (if (= ic 1)
                   (entmake '((0 . "POLYLINE") (66 . 1) (70 . 1)))
                   (entmake '((0 . "POLYLINE") (66 . 1)))
                 ) ;_ 结束if
                 (setq nr 0)
                 (repeat (length plist)
                   (if (= bul 0)
                     (entmake (list (cons 0 "VERTEX")
                                    (cons 10 (nth nr plist))
                              ) ;_ 结束list
                     ) ;_ 结束entmake
                     (entmake (list (cons 0 "VERTEX")
                                    (cons 10 (nth nr plist))
                                    (cons 42 (nth nr blist))
                              ) ;_ 结束list
                     ) ;_ 结束entmake
                   ) ;_ 结束if
                   (setq nr (1+ nr))
                 ) ;_ 结束repeat
                 (entmake '((0 . "SEQEND")))
               ) ;_ 结束progn
             ) ;_ 结束if
            )
            (t                          ; not polyline
             (setq lastent (entlast))
             (setq lwp T)
             (repeat noe
               (setq et (cdr (assoc 72 ed1)))
               (cond
                 ((= et 1)              ; line
                  (setq ed1 (member (assoc 10 (cdr ed1)) ed1))
                  (if A2k
                    (vla-AddLine
                      space
                      (vlax-3d-point (cdr (assoc 10 ed1)))
                      (vlax-3d-point (cdr (assoc 11 ed1)))
                    ) ;_ 结束vla-AddLine
                    (entmake
                      (list
                        (cons 0 "LINE")
                        (list 10
                              (cadr (assoc 10 ed1))
                              (caddr (assoc 10 ed1))
                              0
                        ) ;_ 结束list
                        (list 11
                              (cadr (assoc 11 ed1))
                              (caddr (assoc 11 ed1))
                              0
                        ) ;_ 结束list
                                        ;  (cons 210 xv)
                      ) ;_ 结束list
                    ) ;_ 结束entmake
                  ) ;_ 结束if
                  (setq ed1 (cddr ed1))
                 )
                 ((= et 2)              ; circular arc
                  (setq ed1 (member (assoc 10 (cdr ed1)) ed1))
                  (setq ang1 (cdr (assoc 50 ed1)))
                  (setq ang2 (cdr (assoc 51 ed1)))
                  (setq cw (cdr (assoc 73 ed1)))
                  (if (equal ang2 6.28319 0.00001)
                    (progn
                      (if A2k
                        (vla-AddCircle
                          space
                          (vlax-3d-point (cdr (assoc 10 ed1)))
                          (cdr (assoc 40 ed1))
                        ) ;_ 结束vla-AddCircle
                        (entmake (list (cons 0 "CIRCLE")
                                       (assoc 10 ed1)
                                       (assoc 40 ed1)
                                 ) ;_ 结束list
                        ) ;_ 结束entmake
                      ) ;_ 结束if
                      (setq lwp nil)
                    ) ;_ 结束progn
                    (if A2k
                      (vla-AddArc
                        space
                        (vlax-3d-point (cdr (assoc 10 ed1)))
                        (cdr (assoc 40 ed1))
                        (if (= cw 0)
                          (- 0 ang2)
                          ang1
                        ) ;_ 结束if
                        (if (= cw 0)
                          (- 0 ang1)
                          ang2
                        ) ;_ 结束if
                      ) ;_ 结束vla-AddArc
                      (entmake (list (cons 0 "ARC")
                                     (assoc 10 ed1)
                                     (assoc 40 ed1)
                                     (cons 50
                                           (if (= cw 0)
                                             (- 0 ang2)
                                             ang1
                                           ) ;_ 结束if
                                     ) ;_ 结束cons
                                     (cons 51
                                           (if (= cw 0)
                                             (- 0 ang1)
                                             ang2
                                           ) ;_ 结束if
                                     ) ;_ 结束cons
                               ) ;_ 结束list
                      ) ;_ 结束entmake
                    ) ;_ 结束if
                  ) ;_ 结束if
                  (setq ed1 (cddddr ed1))
                 )
                 ((= et 3)              ; elliptic arc
                  (setq ed1 (member (assoc 10 (cdr ed1)) ed1))
                  (setq ang1 (cdr (assoc 50 ed1)))
                  (setq ang2 (cdr (assoc 51 ed1)))
                  (setq cw (cdr (assoc 73 ed1)))
                  (if A2k
                    (progn
                      (setq obj (vla-AddEllipse
                                  space
                                  (vlax-3d-point (cdr (assoc 10 ed1)))
                                  (vlax-3d-point (cdr (assoc 11 ed1)))
                                  (cdr (assoc 40 ed1))
                                ) ;_ 结束vla-AddEllipse
                      ) ;_ 结束setq
                      (vla-put-startangle
                        obj
                        (if (= cw 0)
                          (- 0 ang2)
                          ang1
                        ) ;_ 结束if
                      ) ;_ 结束vla-put-startangle
                      (vla-put-endangle
                        obj
                        (if (= cw 0)
                          (- 0 ang1)
                          ang2
                        ) ;_ 结束if
                      ) ;_ 结束vla-put-endangle
                    ) ;_ 结束progn
                    (princ "\n不支持椭圆或椭圆弧!")
                  ) ;_ 结束if
                  (setq lwp nil)
                 )
                 ((= et 4)              ; spline
                  (setq ed1 (member (assoc 94 (cdr ed1)) ed1))
                  (setq knot-list nil)
                  (setq controlpoint-list nil)
                  (setq kn (cdr (assoc 95 ed1)))
                  (setq cn (cdr (assoc 96 ed1)))
                  (setq pos (vl-position (assoc 40 ed1) ed1))
                  (repeat kn
                    (setq
                      knot-list (cons (cons 40 (cdr (nth pos ed1)))
                                      knot-list
                                ) ;_ 结束cons
                    ) ;_ 结束setq
                    (setq pos (1+ pos))
                  ) ;_ 结束repeat
                  (setq pos (vl-position (assoc 10 ed1) ed1))
                  (repeat cn
                    (setq controlpoint-list
                           (cons
                             (cons 10 (cdr (nth pos ed1)))
                             controlpoint-list
                           ) ;_ 结束cons
                    ) ;_ 结束setq
                    (setq pos (1+ pos))
                  ) ;_ 结束repeat
                  (setq knot-list (reverse knot-list))
                  (setq controlpoint-list (reverse controlpoint-list))
                  (entmake (append
                             (list '(0 . "SPLINE"))
                             (list (cons 100 "AcDbEntity"))
                             (list (cons 100 "AcDbSpline"))
                             (list (cons 70
                                         (+ 1
                                            8
                                            (* 2 (cdr (assoc 74 ed1)))
                                            (* 4 (cdr (assoc 73 ed1)))
                                         ) ;_ 结束+
                                   ) ;_ 结束cons
                             ) ;_ 结束list
                             (list (cons 71 (cdr (assoc 94 ed1))))
                             (list (cons 72 kn))
                             (list (cons 73 cn))
                             knot-list
                             controlpoint-list
                           ) ;_ 结束append
                  ) ;_ 结束entmake
                  (setq ed1 (member (assoc 10 ed1) ed1))
                  (setq lwp nil)
                 )
               )                        ; end cond
             )                          ; end repeat noe
             (if lwp
               (progn
                 (setq en1 (entnext lastent))
                 (setq ss (ssadd))
                 (ssadd en1 ss)
                 (while (setq en2 (entnext en1))
                   (ssadd en2 ss)
                   (setq en1 en2)
                 ) ;_ 结束while
                 (command "_.pedit" (entlast) "_Y" "_J" ss "" "")
               ) ;_ 结束progn
             ) ;_ 结束if
            )                           ; end t
          )                             ; end cond
        )                               ; end repeat loops1
        (setq i (1+ i))
      ) ;_ 结束while
    ) ;_ 结束progn
  ) ;_ 结束if
  (restore)
  (princ)
) ;_ 结束defun

点评

有样条曲线的不好用  发表于 2012-4-22 21:49

评分

参与人数 1金钱 +5 收起 理由
仲文玉 + 5 淡定

查看全部评分

发表于 2006-1-26 18:21:00 | 显示全部楼层

见下图,直接重新创建边界即可

本帖子中包含更多资源

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

x
 楼主| 发表于 2006-1-27 12:44:00 | 显示全部楼层
谢谢asdf159!!!因为我公司用的是cad2002,所以没有CAD2006的新功能!谢谢liusz111
发表于 2006-1-30 16:48:00 | 显示全部楼层

也许是边界被盖掉所以看不见了。果真如此可以:

DRAWORDER→选取hatch→ENTER

发表于 2006-2-6 18:07:00 | 显示全部楼层
为什么我的 是灰色不可选??

本帖子中包含更多资源

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

x
发表于 2006-2-6 22:45:00 | 显示全部楼层

先要没了边界才可以重新生成边界呀。双击填充图案按钮就会变亮了。

发表于 2009-6-26 18:55:00 | 显示全部楼层
用编辑器生成的编辑都是一段段的,不连续!还是asdf159的LISP程序好!太棒了!非常感谢!
发表于 2012-3-4 16:08:36 | 显示全部楼层
asdf159 发表于 2006-1-26 17:58
;;; 11 功能:通过选定的阴影图案生成边界线=================================(defun c:hb () (c:hatchb)) ...

找了很久啊 非常感谢啊
发表于 2012-3-30 09:58:14 | 显示全部楼层
非常感谢楼主,楼主威武
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-1-11 00:21 , Processed in 0.226245 second(s), 34 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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