PLM之家精品课程培训,联系电话:18301858168 QQ: 939801026

  • NX二次开培训

    NX二次开培训

    适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术对于老鸟也值得借鉴!.

    NX CAM二次开发培训报名 NX二次开发基础培训报名
  • PLM之家Catia CAA二次开发培训

    Catia二次开发培训

    Catia二次开发的市场大,这方面开发人才少,难度大。所以只要你掌握了开发,那么潜力巨大,随着时间的积累,你必将有所用武之地!

  • PLM之Teamcenter最佳学习方案

    Teamcenter培训

    用户应用基础培训,管理员基础培训,管理员高级培训,二次开发培训应有尽有,只要你感兴趣肯学习,专业多年经验大师级打造!

  • PLM之Tecnomatix制造领域培训

    Tecnomatix培训

    想了解制造领域数字化吗?想了解工厂,生产线设计吗?数字化双胞胎,工业4.0吗?我们的课程虚位以待!

PLM之家PLMHome-国产软件践行者

[二次开发源码] NX二次开发源码分享:判断选择的面是否相切

[复制链接]

2019-12-24 19:06:37 2274 1

admin 发表于 2019-9-15 08:38:30 |阅读模式

admin 楼主

2019-9-15 08:38:30

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

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

x
) Y( i8 n7 J8 r. z
NX二次开发源码分享:判断选择的面是否相切
- U" _! \# l5 p; Z5 `0 U, n. _: O3 M4 N/ I$ H
) d  l) ^  K; _' v  x2 v7 P
0 [$ g4 E" I0 `3 [  y% B
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。  J( v  O7 X" n3 X7 l2 ?
" E" D3 D: i: L% w/ x$ w! T5 p% z
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter' O# T( @6 B* C) W) Z; H! o/ l
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
' u4 D+ {- F! v  R( A
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    1 {' \2 w( T/ u5 }

3 j5 {" E4 M) B! s! j& s1 t                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    7 i9 {+ N! _, c! j# f

      i' X' Q! ?3 j' g* G                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    # t; m3 K3 K! B7 A" F

    0 b+ p! v/ l" y                               
    登录/注册后可看大图

    7 O5 ]" C8 o8 D; a

8 z: t7 m+ \* f: `! \% k6 u9 z, Z
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
! j7 u6 s. I4 H3 S

( `  m  ^) K" D2 [, n                               
登录/注册后可看大图

2 o8 i7 @' g9 b5 X  V5 R                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
1 w2 K" L% ]) _0 K  D  ?: i# `5 f

! S' L. [4 h  K+ l& @) i! z, P                               
登录/注册后可看大图

* A/ ?" L2 b) E4 c* Y/ p                               
登录/注册后可看大图
' M3 r! L0 ^( t% c* h5 _
                               
登录/注册后可看大图

  `3 W; v1 V; X, K" A2 `3 \                               
登录/注册后可看大图

, R7 H, ?0 Z9 P$ s& q0 ~                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
0 J& H9 b% w  g. ^

+ Q4 |+ q3 O! Q8 d' s" K
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

; I2 U  J2 s' K$ @% U
bool isTangentFaces(Face *face1 , Face *face2)
{
        UF_initialize();
        bool isTangent = false;
        int count = 0;
        int edgeCount = 0 ;
        std::vector<Face *> boundaryFaces1(0);
        FaceTangentRule *faceTangentRule1;
        ScCollector *scCollector1;
        std::vector<SelectionIntentRule *> rules1(1);
        uf_list_p_t sharedEdges = NULL;
        faceTangentRule1=workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
        scCollector1 = workPart->ScCollectors()->CreateCollector();
        rules1[0] = faceTangentRule1;
        scCollector1->ReplaceRules(rules1, false);
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
        delete faceTangentRule1;
        if (theFaces.empty())
        {
                isTangent = false;
        }
        else
        {
                for (int i  =0 ; i < theFaces.size();i++)
                {
                        if (face2 == theFaces.at(i)) //checked face in the tangent faces list
                        {
                                UF_MODL_ask_shared_edges(face1->Tag(),face2->Tag(),&sharedEdges);
                                if (sharedEdges != NULL)  //confirm has shared edges
                                {
                                        UF_MODL_delete_list(&sharedEdges); //free the memory
                                        isTangent = true;
                                        break;
                                }
                        }
                }

; p# i) r; m* z. i* o) C6 m
        }
        UF_terminate();       
        return isTangent;
}

( n/ k+ x$ l- j& _4 k' m
2 R7 c* b* L+ z. T9 w) X
, m# T% B( w  X% ~0 i' ?4 D% @
5 l4 M. l1 h8 e+ F
' C6 b) Y9 L" Z! r+ Q# g
                               
登录/注册后可看大图

+ C; O! J2 F7 p3 z

# L' Q8 v# R6 u  X% |3 E6 }( t                               
登录/注册后可看大图
END
PLM之家plmhome

3 d0 x) X3 F' i; E% D# p2 R                               
登录/注册后可看大图
# A  N2 |7 d/ F! ~  ?
▲长按二维码“识别”关注
7 G& e) t3 ], b9 ?, Z, G

- S, ^7 L3 l# b[mw_shl_code=cpp,true]
: f: \( M+ O3 J" U6 |  q& O7 Q8 n7 ?/ K* ?# q* m5 [

$ k! A7 R& w8 X- y. Y$ `# P  ^5 lbool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
+ d# V, T* p6 a% y# }{
2 G6 ^9 B# w6 t' j& Z
* Y' J2 [; O7 k* [* W: b* B- l& ]# g        bool isTangent = false;
, |9 p+ {. ~$ X; A' S0 ?        int count = 0;) T$ A+ l( R) h8 l# G! R3 ~
        std::vector<Face *> boundaryFaces1(0);
9 `) t% Z# Q# C        FaceTangentRule *faceTangentRule1;* ]4 y2 v: W9 v9 v0 |% f
        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);4 _2 {' X( N" L+ R9 D. s
        ScCollector *scCollector1;
3 q  c! i3 w; p" G) m! C        scCollector1 = workPart->ScCollectors()->CreateCollector();! W% ]0 }: L! C) K% k# @2 U  {
        std::vector<SelectionIntentRule *> rules1(1);  r& |2 u0 |3 W8 Q% \- A4 t- P
        rules1[0] = faceTangentRule1;
9 ~) `- }  i+ c2 w. J' L        scCollector1->ReplaceRules(rules1, false);  Z9 s+ [% x+ w/ J7 w, c
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();0 G; z/ i9 C4 T
        delete faceTangentRule1;5 {, K8 I0 `( g& Z
        
) G5 v/ R" E- p- ~0 R, G, R        if (theFaces.empty())% i7 U+ F3 [5 l- ^( `$ X( o2 o
        {
3 Y0 c) Q4 v) S6 Y/ q/ D0 t                isTangent = false;
8 B+ _2 i" H7 ^) p% m! w: F        }
5 s4 n6 E1 {) `- P# T        else/ |! s2 e' r3 y9 {& `) S
        {' t; h5 @4 n8 d
                for (int i  =0 ; i < theFaces.size();i++)$ z& [/ D6 d" }7 |* d
                {
6 Q; t1 {. d- ~2 r                        if (face2 == theFaces.at(i))
3 v- A  Z" ~0 y, i' A. Y                        {0 V9 q% g: O" b: {8 }
                                isTangent = true;
. h- ]# p  a8 x+ l4 y8 x/ e                                break;* e- n3 j% L) g( L) ^5 d% O& w, X
                        }; X/ l5 z$ |2 R- J, q* W8 v* A
                }
. K# u/ ~8 N. R/ G) X, g: r/ {4 m1 V# `) U: N. a8 j" T
        }( I5 h1 g. Q4 F2 A' F) w9 p% y! b# B
        6 o/ M( U2 P; u: h4 b' L( j( e2 O
        return isTangent;
8 `! ?% U- R  y+ j5 j* c- N
! [8 A; [' m! H( X8 s/ [" B}[/mw_shl_code]
! Z6 n' ]/ d" e& ]7 z: w. x- |- V! I! B. y. [
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复1

licxsw 发表于 2019-12-24 19:06:37

licxsw 沙发

2019-12-24 19:06:37

学习了  谢谢 分享
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了