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 2221 1

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

admin 楼主

2019-9-15 08:38:30

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

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

x
  e1 X; f  |8 m+ t6 k
NX二次开发源码分享:判断选择的面是否相切+ q8 F1 e" l2 M9 K  l5 ]
& _# a; t) x5 N1 Q: k- V

# n. b" K! ^$ w3 R/ k6 u: U

) W, i6 I, s* e: w3 Z3 W, o9 R- m
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
$ m1 O! b: ?& W$ W. N# V

; @* x2 y3 o8 `2 u: @3 v' g
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter& v6 w* t! M- N3 x7 o8 X, d6 U
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
/ M, t, `  p# e
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择

    , C: V* L* @' a2 \3 s8 q
- s' I" z% F+ H, s' f7 C' r5 J
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    * o; j- ]2 V9 M0 y' a
    4 e  C" r) C2 p8 N
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    0 g7 Q# x( U+ E

    : X( F; N8 |( f9 H                               
    登录/注册后可看大图
    2 z+ U/ q' J1 E2 w1 y. |
5 z5 B& B3 H0 h
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮6 z4 P" w' I. {$ J2 N2 [. h* P

2 j0 V6 m0 p2 Q1 `& ]                               
登录/注册后可看大图
& f9 |9 k4 t1 ~9 X0 J! C3 d
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。# I( O& A+ @4 I( w1 G

; {/ l2 w' g* T1 s" D' r                               
登录/注册后可看大图

' x5 c: B9 z# N$ b" U                               
登录/注册后可看大图
" ~0 `! n: Y, H. ^
                               
登录/注册后可看大图
  o- E% {- E4 g" T. o3 _2 I$ @& Q
                               
登录/注册后可看大图
$ q# `4 l' [* [0 U
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。- M3 _  \0 A( k# S
# X5 r) u- q2 }0 b$ Z1 m
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

7 m8 ?/ N4 Z' s$ T
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;
                                }
                        }
                }
. q" D: w- A- j# _2 V8 F5 J
        }
        UF_terminate();       
        return isTangent;
}

8 S. _. L5 @6 M1 S  a6 p( }: s
9 \1 ^4 c, i) J6 \* k; t
. ]/ u6 n8 A- i3 \) L2 b# O& s  U; r. {" b9 @

) y! i* B, Q4 j" ]# W+ h                               
登录/注册后可看大图
3 n# h1 j/ X; I1 c6 G# R
$ Y3 U& a6 k# O' m# `# _$ L
                               
登录/注册后可看大图
END
PLM之家plmhome
) D( V5 r. s$ M
                               
登录/注册后可看大图
' y; ^; a' `$ \9 r' r0 L
▲长按二维码“识别”关注
. H% t$ V, R' y# \4 k9 F. i

0 R) b9 p: O) S! W8 d* C5 c[mw_shl_code=cpp,true]
. t! \9 R& a$ P7 G# f% ?
, y* O6 y7 y$ r  a, F" X( Q7 Y; T$ C0 O/ t! p
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)* V  D0 v) M1 s9 |  }
{  n( }7 @/ r9 m( D* c
$ S6 w2 I; e2 Q- {  M, \4 R
        bool isTangent = false;
2 X& d; s' w, P* h. }3 u  |        int count = 0;& i& L$ C* {5 V  `; w& j
        std::vector<Face *> boundaryFaces1(0);
; f+ x# t7 U7 e0 P1 b5 o. s/ N        FaceTangentRule *faceTangentRule1;
/ h3 V: h2 y- ^7 \7 o7 h        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
* Q3 \1 z  \, \        ScCollector *scCollector1;
. I, n' c- ?. P3 t        scCollector1 = workPart->ScCollectors()->CreateCollector();
- _0 D* [! }* s9 x" p: U" |        std::vector<SelectionIntentRule *> rules1(1);/ C4 c4 _" a: E
        rules1[0] = faceTangentRule1;/ X( q) M! s) U) o% n) s; A
        scCollector1->ReplaceRules(rules1, false);) I) e7 Y- F' Z& f
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();, Y; v4 Q5 s$ l
        delete faceTangentRule1;
0 j2 v2 s; E5 f; S        / N6 R1 _) P; Y$ h& z( ^
        if (theFaces.empty())' j: h- o7 k7 o3 `; `, l0 r
        {9 Y; k5 ^2 {; h
                isTangent = false;
& J# P( P" D" B9 i        }
, C& z+ v  j0 X' |        else
5 E' e- v. C% V8 V* P4 E        {
/ Z) @, O' V1 \1 U9 O/ g4 j                for (int i  =0 ; i < theFaces.size();i++)
* V7 R& B! c6 ]% y5 G6 J* }                {' k% t) O* _9 I" q
                        if (face2 == theFaces.at(i))
( M* X+ m8 h, F1 K) D                        {
/ o. }: B1 T/ v. X5 D0 V5 q2 \& w                                isTangent = true;% K% q4 D: L% Y
                                break;! l7 K% ?% P/ j& ^
                        }
& @8 C6 \1 k- B; C, p/ P                }
4 \; N; v' o7 ~0 {+ ~; r* ~/ e. d! |$ {0 B9 S3 T
        }
& ]6 V# y/ `. M% e          N. O/ R3 f6 ?" R( i
        return isTangent;
; M2 s3 I; I) A* O$ S
5 T- D# c" `, t' R, Y}[/mw_shl_code]
$ h" N" o# m" s- Z3 I
9 {3 O" [" j3 q& @0 p; G/ N* {
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了