获取中心点排序的一些疑问获取所有的交点了已经排序好了 怎么让他实现分组呢?
[*](defun c:tt ()
[*](if (setq ss (ssget '((0 . "line,pline"))))
[*] (progn
[*] (setq i -1
[*] tmp '()
[*] )
[*] (while (setq s1 (ssname ss (setq i (1+ i))))
[*] (setq o1 (vlax-ename->vla-object s1))
[*] (setq j i)
[*] (while (setq s2 (ssname ss (setq j (1+ j))))
[*] (setq o2 (vlax-ename->vla-object s2))
[*] (if (setq pt (vlax-invoke o1 'intersectwith o2 0))
[*] (setq tmp (cons pt tmp))
[*]
[*]
[*] )
[*] )
[*] )
[*]
[*]
[*](setq pts (vl-sort tmp
[*] '(lambda (p1 p2)
[*] (cond ((> (cadr p1) (cadr p2)) T )
[*]
[*] ((and (equal (cadr p1) (cadr p2) 0.01)
[*] (< (car p1) (car p2))
[*] )
[*] T
[*] )
[*] (T nil)
[*] )
[*] )
[*]))
[*](foreach p pts (getpoint p ))
[*] )
[*])
[*])
[*]
[*]
[*]
y坐标多大范围你自己决定 最好结合具体的图形数据 并以文字说明让人明白 是啥分组 总表 ((1668.45 869.589 0.0) (1918.3 869.589 0.0) (1457.04 804.82 0.0) (1668.45
804.82 0.0) (1918.3 804.82 0.0) (2242.62 804.82 0.0) (1356.14 663.287 0.0)
(1457.04 663.287 0.0) (1668.45 663.287 0.0) (1918.3 663.287 0.0) (2242.62
663.287 0.0) (2446.82 663.287 0.0) (1356.14 519.355 0.0) (1457.04 519.355 0.0)
(1668.45 519.355 0.0) (1918.3 519.355 0.0) (2242.62 519.355 0.0) (2446.82
519.355 0.0) (1457.04 404.209 0.0) (1668.45 404.209 0.0) (1918.3 404.209 0.0)
(2242.62 404.209 0.0) (1668.45 346.636 0.0) (1918.3 346.636 0.0))
第一组((1668.45 869.589 0.0) (1918.3 869.589 0.0) (1457.04 804.82 0.0) (1668.45
804.82 0.0) (1918.3 804.82 0.0)(2242.62 804.82 0.0)
第2组 (1356.14 663.287 0.0)
(1457.04 663.287 0.0) (1668.45 663.287 0.0) (1918.3 663.287 0.0) (2242.62
663.287 0.0) (2446.82 663.287 0.0)
第三组 (1356.14 519.355 0.0) (1457.04 519.355 0.0)
(1668.45 519.355 0.0) (1918.3 519.355 0.0) (2242.62 519.355 0.0) (2446.82
519.355 0.0)
第四组(1457.04 404.209 0.0) (1668.45 404.209 0.0) (1918.3 404.209 0.0)
(2242.62 404.209 0.0)
第五组(1668.45 346.636 0.0) (1918.3 346.636 0.0)) 总表((1668.45 869.589 0.0) (1918.3 869.589 0.0) (1457.04 804.82 0.0) (1668.45
804.82 0.0) (1918.3 804.82 0.0) (2242.62 804.82 0.0) (1356.14 663.287 0.0)
(1457.04 663.287 0.0) (1668.45 663.287 0.0) (1918.3 663.287 0.0) (2242.62
663.287 0.0) (2446.82 663.287 0.0) (1356.14 519.355 0.0) (1457.04 519.355 0.0)
(1668.45 519.355 0.0) (1918.3 519.355 0.0) (2242.62 519.355 0.0) (2446.82
519.355 0.0) (1457.04 404.209 0.0) (1668.45 404.209 0.0) (1918.3 404.209 0.0)
(2242.62 404.209 0.0) (1668.45 346.636 0.0) (1918.3 346.636 0.0))
第一组((1668.45 869.589 0.0) (1918.3 869.589 0.0) (1457.04 804.82 0.0) (1668.45
804.82 0.0) (1918.3 804.82 0.0) (2242.62 804.82 0.0)
第二组(1356.14 663.287 0.0)
(1457.04 663.287 0.0) (1668.45 663.287 0.0) (1918.3 663.287 0.0) (2242.62
663.287 0.0) (2446.82 663.287 0.0)
第三组(1356.14 519.355 0.0) (1457.04 519.355 0.0)
(1668.45 519.355 0.0) (1918.3 519.355 0.0) (2242.62 519.355 0.0) (2446.82
519.355 0.0)
第四组 (1457.04 404.209 0.0) (1668.45 404.209 0.0) (1918.3 404.209 0.0)
(2242.62 404.209 0.0)
第五组 (1668.45 346.636 0.0) (1918.3 346.636 0.0)) 你这个按照y坐标 分组即可
按 Y 坐标对二维点表排序:
(vl-sort '((1 3) (2 2) (3 1))
(function (lambda (e1 e2)
(< (cadr e1) (cadr e2)) ) ) ) 我的想法是获取他们的形心 然后形心排序 在形心排序之前线去重 不知道是不是这样
页:
[1]