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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

  U0 F: L# l, U& k+ ?! gNX二次开发源码分享:判断选择的面是否相切
+ U$ a" u' v, L
, o" |" L; A1 i: _: T3 O0 T; t* A" ~
% ^. `$ V; P( ~- q  E
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。7 {9 L: [5 G1 Y9 p% _/ s

6 O$ R( o3 x8 ^" V, T* Z- G
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
0 t* ?" k1 `8 ]: w
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。8 [( V  v3 ?2 A7 s
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    . k% A7 s* {# I7 O* w0 z; o& w7 _

' W! _$ S, L8 h2 \  _                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    ( y+ ?  Z- `! p9 {" o# b

    , B' f5 N) l6 I$ ~7 ^, V5 ?                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    % K  t* S# _9 C; Z

    ' P; B( U% d5 ^$ N4 Z                               
    登录/注册后可看大图
    ( [4 g) T4 Z  Z' e5 y  l2 F

+ d- x: _6 z3 l9 j
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮- }' I( b9 w. ]5 y4 ?. A# q

5 S" o+ t, q# [2 G. {( w) M. @                               
登录/注册后可看大图

6 R/ ]+ c! w' b" U                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。+ G; p; n' c9 H' E1 |
, p, X0 t+ O' J- N
                               
登录/注册后可看大图

2 |+ l+ p7 F( z$ a" }9 ^& R                               
登录/注册后可看大图

& k* W8 w( B1 N8 Y- z, k3 W% W                               
登录/注册后可看大图
6 z, b5 j: p  Z5 A2 j
                               
登录/注册后可看大图
$ i; v$ ?# i2 g2 U% J) T" K
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
% L% z5 |  J, o" w

# m" K  j  Z4 B, B6 a
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

+ u+ O6 \3 p( M  y: a8 o
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;
                                }
                        }
                }
' {) Z# \1 s% f
        }
        UF_terminate();       
        return isTangent;
}
# v- p0 P5 e. K/ e
/ ?5 R, o/ n1 o

, n2 ^/ h$ O0 T/ B: {; f
( v# L7 u0 R2 l9 g

( u2 U" j  P  u7 k; s; l1 u- [                               
登录/注册后可看大图
" x3 T% L( ?. X& O* x6 i6 j

" N. t; f" ^3 y0 ^. _                               
登录/注册后可看大图
END
PLM之家plmhome
$ B% R  ^0 h  b: l3 R7 D# D: g, ]
                               
登录/注册后可看大图
5 z5 k9 A! n2 a% `! ^2 `- i
▲长按二维码“识别”关注

) E, B, V3 G1 z6 o$ K0 t4 i" p5 c+ `+ W
[mw_shl_code=cpp,true]
0 v# T! y* h1 N8 G) z& h, Y8 N# @3 O6 ^; |2 I. M5 A( h

; n$ Q' g; [+ l( u1 @, [bool CheckDTS::isTangentFaces(Face *face1 , Face *face2), t" R1 ]. ]# g# [
{" m, W& O0 U# r2 O
, L0 w, ]' \: s* R
        bool isTangent = false;. r; D4 ^) t( O) {, F/ {& W, r
        int count = 0;" p  @% n# L8 h; E) S8 U
        std::vector<Face *> boundaryFaces1(0);% ?! n. g% h* ]9 a& F  C2 G6 y
        FaceTangentRule *faceTangentRule1;4 c- y; P% ~/ v, r
        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);/ S3 V: [: K+ i
        ScCollector *scCollector1;1 ~  C) G$ ]: N7 N6 y8 d
        scCollector1 = workPart->ScCollectors()->CreateCollector();
; f0 Y, Q1 W$ y* ^: `        std::vector<SelectionIntentRule *> rules1(1);
5 b3 n* [+ T& t" ^  B        rules1[0] = faceTangentRule1;" E  l! o  |0 N# e4 ~
        scCollector1->ReplaceRules(rules1, false);
& q+ j# R# T# F; G3 e/ u3 }        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
1 d5 j7 F' a1 X$ [* ?6 J        delete faceTangentRule1;
/ h0 _; Z% q9 x& g& D        
. H: z: I+ k) V' e5 _2 J/ M        if (theFaces.empty())
) }. z' e" C- |1 B6 l8 v1 x: b        {
( h+ _/ r! i, r" U8 _! A: U% b7 k3 P, W                isTangent = false;
0 @) v3 L' w/ h: z- H        }
  M2 H% r/ W& `4 A4 c        else' s3 b5 N$ v9 o( F# T
        {
; M5 A9 c/ B5 j+ G: B2 t                for (int i  =0 ; i < theFaces.size();i++)
& p3 z& z, }& M5 f7 S                {
/ T% K, e2 _1 [+ E) {5 H; H1 m                        if (face2 == theFaces.at(i))4 e# I" c, _, n4 s
                        {
% ]' o0 L; x( b) T                                isTangent = true;, D& k" n) {* s/ O3 t
                                break;* W% C9 \5 X9 h& h$ o6 m* Z9 g
                        }
7 B& m" H! }3 s& h. d7 w5 i8 |4 O6 _                }
  o8 Z( U% u- c) L* `' i+ t" z( E/ X/ B% p: @
        }
* {# e6 L, n4 X  [. X! N7 M8 J        : T% ~. T7 g! r' R3 u
        return isTangent;
+ u+ R: P% K1 e$ F$ Y! C/ a4 k) M* T9 ?. L5 r' H: S" U
}[/mw_shl_code]
% G+ `4 h: {1 {% w4 }) i! |& D! L3 o* K: {( l( F4 H
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了