PLM之家精品课程培训

PLM之家精品课程培训

联系电话:18301858168   |   QQ咨询:939801026
NX二次开发培训

NX二次开发培训

UFUN/NXOpen C++和实战案例

适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术。
公众号二维码

关注公众号

点击扫描二维码免费在线高清教程

课程详情
Catia二次开发培训

Catia二次开发培训

市场需求大,掌握核心技术前景广阔

Catia二次开发的市场需求大,人才稀缺。掌握开发技能潜力巨大,随着经验积累将在汽车、航空等领域有所作为。
B站二维码

在线原创B站视频

点击关注工业软件传道士主页

课程详情
Teamcenter培训

Teamcenter培训

全方位培训,从基础应用到高级开发全覆盖

涵盖用户应用基础培训、管理员基础培训、管理员高级培训及二次开发培训等全方位内容,由多年经验讲师打造。
QQ群二维码

加入同行交流

点击扫描二维码加入QQ群

课程详情
×

PLM之家plmhome公众号

课程涵盖: PLM之家所有原创视频

×

关注B站视频

所有高清视频一览无余,全部在线播放学习

×

加入PLM之家QQ群

同行交流,疑问解答,更多互助

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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
  M- p. T- L# }- s2 H$ t% N, |" G
NX二次开发源码分享:判断选择的面是否相切, M* G, p6 x, U2 ?. P/ w0 N6 j

) p+ w6 b: C! B$ n7 B- A2 ?3 m  \  P2 s. k6 i- O) {+ y

$ M* l5 }7 T8 h. ^7 r) C* m
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
7 N! B; C! `9 m% i
: l. [& R3 d8 z) @8 Q: N5 b2 A- g
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter2 J6 N# c. }1 Z/ B5 G
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
- t4 {+ n* k! f* t. _: r
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    : E: A+ q7 y3 `; }( w
, Y4 n' p% Q( }/ u1 s
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    5 I. ]. B7 B# r- `" z9 [2 u& s

    $ ~) V5 i5 q, I% [, c& M0 I                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    9 m' s/ r3 l# Q0 G6 v, ]/ ^

    8 {) t3 o8 C& E; Q                               
    登录/注册后可看大图
    , W8 e' _! H* }- b- M

. H, C$ I+ @) z7 n, B6 ]' _
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮, i/ Y+ `9 x4 H
) i7 c8 X5 @+ S3 d! c* M7 H
                               
登录/注册后可看大图
1 I4 {" k/ T* w  U
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
6 _  P. [0 v- |7 g4 q  d
$ C8 z( y% L9 T9 ?, Y+ z
                               
登录/注册后可看大图

. x$ p: F7 I, b! x( `8 h                               
登录/注册后可看大图
/ F/ ]0 i0 f( I4 \5 v
                               
登录/注册后可看大图

1 ~# b# P, p, [- y: E                               
登录/注册后可看大图
, n4 F1 @6 T9 O3 P$ k
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。' {) p' t* r7 `& l

8 E7 [$ j9 |, T+ k, R
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
3 W/ p- h) v# ]; i' Y: g5 x( ]
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;
                                }
                        }
                }
/ E# x/ A8 @0 Z
        }
        UF_terminate();       
        return isTangent;
}

, `+ h( j: ?6 p# ~" v6 t% k7 U, Q: A5 Z7 o$ Z& `5 v

+ j3 H& h( v; b+ g" V% r; H" `$ s  K6 V3 Q  _2 h9 `. I
- o% _4 a: @& D. }% R  G
                               
登录/注册后可看大图

0 z. W$ c4 b; A2 h9 n9 h
) Y. p% ^# n3 I/ @
                               
登录/注册后可看大图
END
PLM之家plmhome
7 h. u3 E0 ^$ s+ v  w9 f' b+ y
                               
登录/注册后可看大图

" U# v& E/ D( W4 ^▲长按二维码“识别”关注

9 I5 x8 t- B! D. M# Z* o1 F/ N
; h  ]: J  L4 H" {[mw_shl_code=cpp,true]9 F9 @! D- z  ?) s! A
& A. x: P( s% w& F

" H3 F" O- ^  s$ Z- `* obool CheckDTS::isTangentFaces(Face *face1 , Face *face2)/ E3 ^7 h2 n  l
{* l7 P& |: _2 ]( B# S+ Q  K

# N! L0 x( L2 D; n' H        bool isTangent = false;
8 }* ^  Y, r8 k* T2 c        int count = 0;) c. v# ^$ G/ o7 V. D6 E9 d
        std::vector<Face *> boundaryFaces1(0);
1 G1 W) R9 e5 [, `# z, W# ]        FaceTangentRule *faceTangentRule1;. A4 ^. C  G" k- K6 u
        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
9 m3 t1 p: x) r+ l3 Y! a        ScCollector *scCollector1;" i" v2 {4 f, B* J3 m) K& k* g
        scCollector1 = workPart->ScCollectors()->CreateCollector();8 b. p# ?" C: \1 R6 r# m5 ]5 O
        std::vector<SelectionIntentRule *> rules1(1);2 t4 i0 Y* v/ l; U3 `0 ?
        rules1[0] = faceTangentRule1;9 y1 x7 E; l& _9 y$ d$ y
        scCollector1->ReplaceRules(rules1, false);
5 ?9 j3 r6 Q  `9 K+ q6 ?8 Z" X. d        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();( O# W, k8 e- k1 k  |. k
        delete faceTangentRule1;2 q  h. |+ S" x3 x: x
        
0 a6 x1 O# d. `. M, m6 X7 [' N        if (theFaces.empty())
* V# l' [9 A9 W        {
! Z  D0 Y$ w$ {7 L5 ^+ Y% |2 f                isTangent = false;
! ?0 ^) ?# P( j! x        }: R/ \; M4 y- W4 c( B
        else' C9 O6 Q6 t: }! \0 [- N2 e$ I1 q
        {
6 a: N& |9 ^$ V/ y                for (int i  =0 ; i < theFaces.size();i++)
# x' T5 N5 }  [& W% d2 t& M                {' w* m% d3 K9 j: ]4 Q
                        if (face2 == theFaces.at(i))
! f% ?2 g' s* V0 D+ t& D                        {
) ?& t! j6 ]# y) g. x: w: u                                isTangent = true;4 \  I( v# u, ]9 q; Z7 O7 I3 F' a
                                break;4 a, \$ J6 c  B  _% b) F
                        }" s3 Z, L. ]" X( k) l, X+ @
                }2 x& Y1 V( D5 b! V" H
2 T' g+ g% v% E2 ?/ b: o4 I
        }/ h2 s. N/ U0 \7 l6 ?; g
        
* i& q% m/ P2 x; \% j9 o- c        return isTangent;
* s2 H% m# I! T1 [/ a9 z3 g0 ~- k2 d* ~; Q* @
}[/mw_shl_code]
9 I3 D3 G9 z0 c* g  X& e& `5 @8 v, F4 ~
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了