乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 67|回复: 2

怎么求两条样条曲线或是求样条曲线与直线的交点?

[复制链接]

10

主题

17

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
57
发表于 2003-1-17 23:37:00 | 显示全部楼层 |阅读模式
我从CAD帮助文件中看到:可以用 ill 函数来求两直线的交点,可是如果是求两条样条曲线或是求样条曲线与直线的交点该怎么办呢?
回复

使用道具 举报

16

主题

909

帖子

8

银币

中流砥柱

Rank: 25

铜币
973
发表于 2003-1-20 10:52:00 | 显示全部楼层
I remember Long Long Zai pasted this routine months ago, probably it might help you.[br];;-----------------------------------------------
;; 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 (vla-object AOBJ1)
  N2 (1+ N1)
    ) ;index for inner loop
;;; Inner loop, go through remaining objects
    (while (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)
)
回复

使用道具 举报

29

主题

1152

帖子

10

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1268
发表于 2003-1-20 10:59:00 | 显示全部楼层
http://www.mjtd.com/bbs/dispbbs.asp?boardID=3&RootID=9982&ID=9993
http://www.mjtd.com/bbs/dispbbs.asp?boardID=3&RootID=12521&ID=12698
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-5-31 14:17 , Processed in 0.302944 second(s), 58 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表