找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 3017|回复: 22

[编程申请] 三角网的改进

[复制链接]

已领礼包: 19个

财富等级: 恭喜发财

发表于 2014-12-9 20:25:52 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
今天看了老大的三角网的帖子,http://bbs.xdcad.net/thread-678045-1-1.html试验了下 函数:  xdrx_points_Delaunay 好像是所有点都连城三角网了,如果下面这样的图


QQ截图20141209202433.png

下面那个是函数生成的三角网,好像函数只支持凸的多边形,另外好像不支持中间有空洞的,怎么才能生成右边那样的三角网呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 40个

财富等级: 招财进宝

发表于 2014-12-9 21:16:02 | 显示全部楼层
应该不难,在最外面多边形外面生成的3DFACE删除掉,在内部封闭多边形内部的3DFACE删除掉。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-9 22:02:14 来自手机 | 显示全部楼层
保存边界 收缩点用f选择后删除

点评

大师,不会误伤吗?帮写一吧。  详情 回复 发表于 2014-12-9 22:36
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 19个

财富等级: 恭喜发财

 楼主| 发表于 2014-12-9 22:36:32 | 显示全部楼层
st788796 发表于 2014-12-9 22:02
保存边界 收缩点用f选择后删除

大师,不会误伤吗?帮写一吧。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 08:35:27 | 显示全部楼层
Lisphk 发表于 2014-12-9 22:36
大师,不会误伤吗?帮写一吧。

简单写了一个,尚需优化
  1. (defun c:tt (/ ss lst alst pts mPnts d cpnts s css)
  2.   (if (setq ss (ssget '((0 . "*polyline"))))
  3.     (progn
  4.       (setq lst         (mapcar '(lambda (x)
  5.                             (xdrx_getpropertyvalue x "area" "vertices")
  6.                           )
  7.                          (xdrx_pickset->ents ss)
  8.                  )
  9.             alst (vl-sort lst '(lambda (x1 x2) (> (car x1) (car x2))))
  10.             pts         (apply 'append (mapcar 'cadr lst))
  11.       )
  12.       (setq css (xdrx_points_delaunay pts t))
  13.       (setq mPnts (cadar alst)
  14.             d          (if (minusp (apply 'xdrx_points_area mPnts))
  15.                     -10
  16.                     10;_可调数据
  17.                   )
  18.             cPnts (apply 'xdrx_points_offset
  19.                          (cons d
  20.                                (xd::pnts:close mPnts)
  21.                          )
  22.                   )
  23.       )
  24.       (xdrx_object_regen);_速度太快,可能 3dface 还没有显示,不生成后面无法选择到
  25.       (if (setq ss (ssget "F" cpnts '((0 . "3dface"))))
  26.         (xdrx_entity_delete ss)
  27.       )
  28.       (if (setq ss (ssget "WP" mPnts '((0 . "*Polyline"))))
  29.         (progn
  30.           (setq        iLst
  31.                  (mapcar '(lambda (x / cpts)
  32.                             (setq
  33.                               cpts (if (xdrx_curve_direction x)
  34.                                      (xdrx_getpropertyvalue x "vertices")
  35.                                      (reverse
  36.                                        (xdrx_getpropertyvalue x "vertices")
  37.                                      )
  38.                                    )
  39.                             )
  40.                             (apply 'xdrx_points_offset
  41.                                    (cons -1 (xd::pnts:close cpts))
  42.                             )
  43.                           )
  44.                          (xdrx_pickset->ents ss)
  45.                  )
  46.           )
  47.           (foreach x iLst
  48.             (if        (setq s (ssget "F" x '((0 . "3dface"))))
  49.               (xdrx_entity_delete s)
  50.             )
  51.           )
  52.         )
  53.       )
  54.     )
  55.   )
  56.   (princ)
  57. )

点评

大师,看图,好像删除的多了,还有没删除掉的。 [attachimg]11986[/attachimg]  详情 回复 发表于 2014-12-10 08:58
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 19个

财富等级: 恭喜发财

 楼主| 发表于 2014-12-10 08:58:09 | 显示全部楼层
st788796 发表于 2014-12-10 08:35
简单写了一个,尚需优化

大师,看图,好像删除的多了,还有没删除掉的。
QQ截图20141210085649.png

点评

试试这个,如果有漏网或者误杀的再修改。 [attachimg]11999[/attachimg]  详情 回复 发表于 2014-12-10 16:19
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 09:33:47 来自手机 | 显示全部楼层
Lisphk 发表于 2014-12-10 08:58
大师,看图,好像删除的多了,还有没删除掉的。

wp选择时应该将点表内偏或者去掉面积最大的,外侧漏掉的应该是外偏距离过大了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 11:37:15 | 显示全部楼层
Lisphk 发表于 2014-12-10 08:58
大师,看图,好像删除的多了,还有没删除掉的。

再试试这个
  1. (defun c:tt (/ ss lst alst pts mPnts d cpnts s css mind hpnts tf)
  2.   (defun _Pnts:Offset (pts mod / area lpts mind cpts)
  3.     (setq area (apply 'xdrx_points_area pts)
  4.           cpts (xd::pnts:close pts)
  5.           lpts (xd::list:snakepair cpts)
  6.           mind (car
  7.                  (vl-sort (mapcar '(lambda (x) (apply 'distance x)) lpts)
  8.                           '<
  9.                  )
  10.                )
  11.     )
  12.     (if        mod ;_outside
  13.       (if (minusp area)
  14.         (apply 'xdrx_points_offset (cons (- (/ mind 10.0)) cpts))
  15.         (apply 'xdrx_points_offset (cons (/ mind 10.0) cpts))
  16.       )
  17.       (if (minusp area)
  18.         (apply 'xdrx_points_offset (cons (/ mind 10.0) cpts))
  19.         (apply 'xdrx_points_offset (cons (- (/ mind 10.0)) cpts))
  20.       )
  21.     )
  22.   )
  23.   (if (setq ss (ssget '((0 . "*polyline"))))
  24.     (progn
  25.       (setq lst         (mapcar '(lambda (x)
  26.                             (xdrx_getpropertyvalue x "area" "vertices")
  27.                           )
  28.                          (setq plst (xdrx_pickset->ents ss))
  29.                  )
  30.             alst (vl-sort lst '(lambda (x1 x2) (> (car x1) (car x2))))
  31.             pts         (apply 'append (mapcar 'cadr lst))
  32.       )
  33.       (setq css (xdrx_points_delaunay pts t))
  34.       (setq mPnts (cadar alst)
  35.             hPnts (xdrx_points_ghull mPnts)
  36.       )
  37.       (if (< (apply 'xdrx_points_area mPnts)
  38.              (apply 'xdrx_points_area hPnts)
  39.           )
  40.         (progn
  41.           (xdrx_sysvar_push '("osmode" 0))
  42.           (xdrx_object_regen) ;_速度太快,可能 3dface 还没有显示,不生成后面无法选择到
  43.           (if
  44.             (setq
  45.               ss1 (ssget "F" (_Pnts:Offset mpnts t) '((0 . "3dface")))
  46.             )
  47.              (xdrx_entity_delete ss1)
  48.           )
  49.         )
  50.       )
  51.       (if (> (length plst) 1)
  52.         (progn
  53.           (setq        plst (cdr (vl-sort plst
  54.                                    '(lambda (x1 x2)
  55.                                       (> (car (xdrx_getarea x1))
  56.                                          (car (xdrx_getarea x2))
  57.                                       )
  58.                                     )
  59.                           )
  60.                      )
  61.           )

  62.           (if (not tf)
  63.             (xdrx_object_regen)
  64.           )
  65.           (foreach x plst
  66.             (setq iLst (xdrx_getpropertyvalue x "vertices"))
  67.             (if        (setq s        (ssget "F"
  68.                                (_Pnts:Offset iLst nil)
  69.                                '((0 . "3dface"))
  70.                         )
  71.                 )
  72.               (xdrx_entity_delete s)
  73.             )
  74.           )
  75.         )
  76.       )
  77.     )
  78.   )
  79.   (xdrx_sysvar_pop)
  80.   (princ)
  81. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 12:15:23 来自手机 | 显示全部楼层
还是啰嗦了,用选集的交并差即可
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 14:38:41 | 显示全部楼层
newer 发表于 2014-12-9 21:16
应该不难,在最外面多边形外面生成的3DFACE删除掉,在内部封闭多边形内部的3DFACE删除掉。

又试了一次,不是删除那么简单,这种是有约束边的三角网,有越界的三角!
  1. (defun c:tt (/ ss lst alst pts s1 s2)
  2.   (defun _Pnts:Offset (pts mod / area lpts mind cpts)
  3.     (setq area (apply 'xdrx_points_area pts)
  4.           cpts (xd::pnts:close pts)
  5.           lpts (xd::list:snakepair cpts)
  6.           mind (car
  7.                  (vl-sort (mapcar '(lambda (x) (apply 'distance x)) lpts)
  8.                           '<
  9.                  )
  10.                )
  11.     )
  12.     (if        mod ;_outside
  13.       (if (minusp area)
  14.         (apply 'xdrx_points_offset (cons (- (/ mind 10.0)) cpts))
  15.         (apply 'xdrx_points_offset (cons (/ mind 10.0) cpts))
  16.       )
  17.       (if (minusp area)
  18.         (apply 'xdrx_points_offset (cons (/ mind 10.0) cpts))
  19.         (apply 'xdrx_points_offset (cons (- (/ mind 10.0)) cpts))
  20.       )
  21.     )
  22.   )

  23.   (if (setq ss (ssget '((0 . "*polyline"))))
  24.     (progn
  25.       (setq lst         (mapcar '(lambda (x)
  26.                             (xdrx_getpropertyvalue x "area" "vertices")
  27.                           )
  28.                          (setq plst (xdrx_pickset->ents ss))
  29.                  )
  30.             alst (vl-sort lst '(lambda (x1 x2) (> (car x1) (car x2))))
  31.             pts         (apply 'append (mapcar 'cadr lst))
  32.       )
  33.       (xdrx_setmark)
  34.       (xdrx_points_delaunay pts t)
  35.       (xdrx_entity_setcolor (xdrx_getss) 9)
  36.       (xdrx_object_regen)
  37.       (if (setq        s1 (xdrx_pickset_subtract
  38.                      (xdrx_getss)
  39.                      (ssget "CP"
  40.                             (_Pnts:Offset (cadar alst) nil)
  41.                             '((0 . "3dface"))
  42.                      )
  43.                    )
  44.           )
  45.         (xdrx_entity_delete s1)
  46.       )
  47.       (if (cdr alst)
  48.         (progn
  49.           (foreach x (mapcar 'cadr (cdr alst))
  50.             (if
  51.               (setq
  52.                 s2 (ssget "CP" (_Pnts:Offset x nil) '((0 . "3dface")))
  53.               )
  54.                (xdrx_entity_delete s2)
  55.             )
  56.           )
  57.         )
  58.       )
  59.       (xdrx_draworder->top ss)
  60.     )
  61.     (xdrx_sysvar_pop)
  62.   )
  63.   (princ)
  64. )
20141210143718.png

点评

什么是越界的三角形?  详情 回复 发表于 2014-12-10 15:48
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 19个

财富等级: 恭喜发财

 楼主| 发表于 2014-12-10 15:48:06 | 显示全部楼层
st788796 发表于 2014-12-10 14:38
又试了一次,不是删除那么简单,这种是有约束边的三角网,有越界的三角!

{:soso_e114:}什么是越界的三角形?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 16:02:41 来自手机 | 显示全部楼层
有约束边了就要进行局部优化,如图示两个红色三角
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

发表于 2014-12-10 16:19:44 | 显示全部楼层
Lisphk 发表于 2014-12-10 08:58
大师,看图,好像删除的多了,还有没删除掉的。

试试这个,如果有漏网或者误杀的再修改。


xdrx_trinet.gif

  1. (defun c:tt (/ )
  2.   (if (setq ss (ssget '((0 . "*polyline") (70 . 1))))
  3.     (progn
  4.       (xdrx_begin)
  5.       (setq lst (mapcar
  6.                   '(lambda (x)
  7.                      (xdrx_getpropertyvalue x "area" "vertices")
  8.                      (list (xdrx_getpropertyvalue x "area") x (xdrx_getpropertyvalue x "vertices"))
  9.                    )
  10.                   (setq ents(xdrx_pickset->ents ss))
  11.                 )
  12.             lst (vl-sort lst '(lambda (x1 x2)
  13.                                  (> (car x1) (car x2))
  14.                                )
  15.                  )
  16.             alst (vl-sort lst '(lambda (x1 x2)
  17.                                  (> (car x1) (car x2))
  18.                                )
  19.                  )
  20.             maxent (cadar alst)
  21.             ents1 (XD::List:RemoveE maxent ents t)
  22.             pts (apply
  23.                   'append
  24.                   (mapcar
  25.                     'last
  26.                     lst
  27.                   )
  28.                 )
  29.       )
  30.       (setq css (xdrx_points_delaunay pts t))
  31.       (mapcar
  32.         '(lambda (x)
  33.            (setq vertices (xdrx_getpropertyvalue x "vertices")
  34.                  heartpnt (XD::Geom:Triangleheart (car vertices)(cadr vertices)(caddr vertices))
  35.            )
  36.            (if (> (length(xdrx_entity_intersectwith x maxent)) 2)
  37.              (progn
  38.               (entdel x)
  39.              )
  40.            )
  41.            (mapcar '(lambda(y)(if (> (length(xdrx_entity_intersectwith y x)) 2)(entdel x)))ents1)           
  42.          )
  43.         (xdrx_pickset->ents css)
  44.       )
  45.       (xdrx_end)
  46.     )

  47.   )
  48.   (princ)
  49. )



论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-10 16:46:48 来自手机 | 显示全部楼层
newer 发表于 2014-12-10 16:19
试试这个,如果有漏网或者误杀的再修改。

改过了?我用的 css 是返回 T,不是selectionset

点评

提建议,老大今天修改的,我这是新的。 [attachimg]12001[/attachimg] 上面是凸多边形的,我认为还是限制下只凸的,凹的情况很多要判断处理。ST你接着研究下带凹的吧。  详情 回复 发表于 2014-12-10 16:52
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

发表于 2014-12-10 16:52:01 | 显示全部楼层
st788796 发表于 2014-12-10 16:46
改过了?我用的 css 是返回 T,不是selectionset

提建议,老大今天修改的,我这是新的。

QQ截图20141210164921.png


上面是凸多边形的,我认为还是限制下只凸的,凹的情况很多要判断处理。ST你接着研究下带凹的吧。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-4-24 22:55 , Processed in 0.355909 second(s), 59 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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