明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3534|回复: 9

那位大虾能给帮忙编一个提取二维平面图形中所有实交点坐标的程序?急用!!

[复制链接]
发表于 2002-9-26 10:26:00 | 显示全部楼层 |阅读模式
那位大虾能给帮忙编一个提取二维平面图形中所有实交点坐标的程序?
发表于 2002-9-26 12:09:00 | 显示全部楼层

我也想要!

发表于 2002-9-26 12:34:00 | 显示全部楼层

Find all intersections between objects

;;-----------------------------------------------
;; CDNC5-02.LSP
;; Bill Kramer
;; Find all intersections between objects in
;; the selection set SS.
;; Process - Create drawing with intersecting lines and lwpolylines.
;;           Load function set
;;           Run command function INTLINES
;;           Intersections are marked with POINT objects on current layer
(defun C:INTLINES (/ SSL                ;length of SS
                   PTS                        ;returning list
                   AOBJ1                ;Object 1
                   AOBJ2                ;Object 2
                   N1                        ;Loop counter
                   N2                        ;Loop counter
                   IPTS                        ;intersects
                   A N NN HOLDOSMODE
                  )
  (vl-load-com)
  (command "_.UNDO" "_GROUP")
  (setq HOLDOSMODE (getvar "OSMODE"))
  (setvar "OSMODE" 0)
  (setq SS (ssget '((0 . "*LINE,ARC,CIRCLE,ELLIPSE"))))
  (setq        N1  0                                ;index for outer loop
        SSL (sslength SS)
  )                                        ; Outer loop, first through second to last
  (while (< N1 (1- SSL))                ; Get object 1, convert to VLA object type
    (setq AOBJ1        (ssname SS N1)
          AOBJ1        (vlax-ename->vla-object AOBJ1)
          N2        (1+ N1)
    )                                        ;index for inner loop
;;; Inner loop, go through remaining objects
    (while (< N2 SSL)                        ; Get object 2, convert to VLA object
      (setq AOBJ2 (ssname SS N2)
            AOBJ2 (vlax-ename->vla-object AOBJ2)
;;;Find intersections of Objects
            IPTS  (vla-intersectwith
                    AOBJ1
                    AOBJ2
                    0
                  )                        ; variant result
            IPTS  (vlax-variant-value IPTS)
      )
;;;Variant array has values?
      (if (> (vlax-safearray-get-u-bound IPTS 1) 0)
        (progn                                ;array holds values, convert it
          (setq        IPTS                        ;to a list.
                 (vlax-safearray->list IPTS)
          )
;;;Loop through list constructing points
          (while (> (length IPTS) 0)
            (setq PTS  (cons (list (car IPTS)
                                   (cadr IPTS)
                                   (caddr IPTS)
                             )
                             PTS
                       )
                  IPTS (cdddr IPTS)
            )
          )
        )
      )
      (setq N2 (1+ N2))
    )                                        ;inner loop end
    (setq N1 (1+ N1))
  )                                        ;outer loop end
  (print PTS)
  (setvar "OSMODE" HOLDOSMODE)
  (command "_.UNDO" "_END")
  (princ)
)
 楼主| 发表于 2002-9-26 13:39:00 | 显示全部楼层

多谢,多谢!

多谢,多谢!以后还望多多指教!能不能告所我你的e-mail我得
lohelen2001◎163.com
还有一个问题,能不能把坐标输入dat一个文件中,并按坐标排序!!
是不是有点过分!!
看来,不学lisp是不行了,请给指教一本教材吧?
 楼主| 发表于 2002-9-26 13:42:00 | 显示全部楼层

还有个问题????

能不能把坐标输入dat文件并排序?
发表于 2002-9-26 17:02:00 | 显示全部楼层

请说清楚坐标排序及坐标输入dat的方式!!

 楼主| 发表于 2002-9-26 20:52:00 | 显示全部楼层

多谢多谢!!!我有来了!!请多指教!

我想先以x坐标排序,再以y,最后以z
输出的dat文件
最好是每个点x,y,z在一行
但x,y,z的位置最好是都在一列上,这样可以方便的列选
发表于 2002-9-26 21:20:00 | 显示全部楼层

Sort_and_Write_pList :见附件

本帖最后由 作者 于 2002-9-26 21:20:21 编辑

(defun Sort_and_Write_pList (fname plist / fp pt)
  ;; sort plist first
  (setq        plist (vl-sort plist
                       '(lambda        (p1 p2)
                          (cond        ((< (car p1) (car p2)) T)
                                ((and (= (car p1) (car p2))
                                      (< (cadr p1) (cadr p2))
                                 )
                                 T
                                )
                                ((and (= (car p1) (car p2))
                                      (= (cadr p1) (cadr p2))
                                      (< (caddr p1) (caddr p2))
                                 )
                                 T
                                )
                                (T nil)
                          )
                        )
              )
  )
  ;; write plist then
  (setq fp (open fname "w"))
  (foreach pt plist (princ pt fp) (princ "\n" fp))
  (close fp)
)

;;; 测试上述函数
(Sort_and_Write_pList
  "c:/test.txt"
  '((1 3 4)
    (2 4 5)
    (3 4 5)
    (1 3 2)
    (3 5 2)
    (2 4 0)
    (1 2 3)
    (1 2 0)
    (1 1 0)
   )
)
下载:

运行结果:c:\test.txt中内容
(1 1 0)
(1 2 0)
(1 2 3)
(1 3 2)
(1 3 4)
(2 4 0)
(2 4 5)
(3 4 5)
(3 5 2)

本帖子中包含更多资源

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

x
 楼主| 发表于 2002-9-27 08:32:00 | 显示全部楼层

非常感谢

得各位大虾指点,小弟受益匪浅!不胜感激
发表于 2010-10-11 12:21:00 | 显示全部楼层

谢谢楼上的分享,参考下,很感激

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

本版积分规则

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

GMT+8, 2024-10-2 12:25 , Processed in 0.175083 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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