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-国产软件践行者

[二次开发源码] UG NX 二次开发源码分享:遍历所有的实体得到边面特征信息

[复制链接]

2013-11-4 16:53:51 6144 0

admin 发表于 2013-11-4 16:53:51 |阅读模式

admin 楼主

2013-11-4 16:53:51

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

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

x
UG NX 二次开发源码分享:遍历所有的实体得到边面特征信息
$ s3 w% Q! U( G0 \' W
; v$ C2 g+ S5 ~
1 |" s+ J) ^; |* l- m  theSession->ListingWindow()->Open();3 G" q4 Z0 P% T$ @. |
  theSession->ListingWindow()->WriteLine("Get information from all bodies\n");
& c* }  p6 b- J7 D' f' ?+ F  A( K     std::vector<Body *> bodies;5 ]3 H9 ?9 d4 f
  BodyCollection *bodyColl = workPart->Bodies();2 u$ _2 N, k$ b5 h) i# V! g9 x! b
  for(it = bodyColl->begin();it!=bodyColl->end();++it)8 |! g7 k9 i% W) |% o1 I
  {
& d. f5 [$ F5 m7 ~( n   bodies.push_back(*it);
+ D$ p* t% a% r: t% q1 m  }7 w. z) u& H7 H" l3 K
  ss <<"Bodies count = " << bodies.size()<< "\n";2 i1 q; k3 J, ?% `
   std::vector <Edge *> edges;9 Z  r- F% L1 q) \/ `9 ?
   std::vector <Edge *> totalEdges;
" H3 q2 Y6 E4 S  b, Y   std::vector <Face *> faces;
0 w' H2 K2 h* M   std::vector <Face *> totalfaces;/ k$ c0 U4 v% e1 u
   std::vector <Features::Feature *> Features;- i5 }0 W6 k7 Z8 t+ k, h
   std::vector <Features::Feature *> totalFeature;
7 ~& J' ~  U& Z8 e   Point3d vertex1,vertex2;
( A$ I7 }  c3 `( ]* }- x   for (unsigned int i = 0; i< bodies.size();++i); J6 `- R$ `6 ~0 r$ e
   {
* C% c6 a; f$ t  A1 h2 y    edges = bodies->GetEdges();( n) h+ q/ a$ C9 D: U& n6 |, z
    faces = bodies->GetFaces();
( a$ P! w2 h4 f, i1 r* U' a7 ~" t    Features = bodies->GetFeatures();
9 P. H9 t% x/ e" @/ T' S     for(unsigned int j =0;j < edges.size(); j++)
+ \1 P9 Y; ^7 s" k* \     {5 ^+ D2 e- J& X# _1 ~
     totalEdges.push_back(edges[j]);
( y0 u% f6 y4 V# I     }
& d5 I/ h* z! k+ l- l     for(unsigned int j =0;j < faces.size(); j++)0 N# p) c/ e+ T* b5 `  R  g
     {
; u& }/ c$ h: I  }. a# D9 w- v7 c     totalfaces.push_back(faces[j]);! \& Y/ t7 |2 X
     }; e$ b1 Z  Q. A1 [" H" {
      for(unsigned int j =0;j < Features.size(); j++)& d7 n$ e# i! u
     {
9 `, i; w% M) N7 M5 Q     totalFeature.push_back(Features[j]);' y% t" D7 x' T  k3 ?3 @
     }
# r" Y. B2 D- s" l. R      
% F& B# U: C' o3 L, u1 p9 q0 ]   }
  k" ?8 J3 X& F. K# J1 J7 f    ss <<"edges count = " << totalEdges.size()<< "\n";) z1 O+ \- T. N- E
   for(unsigned int j =0;j < totalEdges.size(); j++)
& a$ t. N; x$ x. ?; f) V     {   
; O* G* Z0 l! Q( h0 X$ ^+ R1 b  A      totalEdges[j]->GetVertices(&vertex1,&vertex2);
2 c6 y0 I2 T$ u$ |0 m9 y       ss <<"edges tag: " <<  totalEdges[j]->GetBody()->GetTag()<<"\t";. ]9 V/ w8 U) B  b
       ss <<"edges vertex 1: "<<"("<<vertex1.X<<","<<vertex1.Y<<","<<vertex1.Z<<")"<<"\t";
$ U2 s6 }" m( {  i       ss <<"edges vertex 2: "<<"("<<vertex2.X<<","<<vertex2.Y<<","<<vertex2.Z<<")"<<"\n";
+ z9 P" i3 L( [  M     }+ L& k' Y6 y1 ^! |% M6 U- P  U
   ss <<"faces count = " << totalfaces.size()<< "\n";
2 U( q! s' L  m! k" a    for(unsigned int j =0;j < totalfaces.size(); j++); w: b( e# R+ d7 W6 `, n% A. d
    {  
. S% }# x+ k" j- u2 [# s$ I% h     ss <<"Face tag: " << totalfaces[j]->Tag()<<"\t";) r( i! x" y% H; F0 @* S& u
     ss <<"Face Type: " << totalfaces[j]->SolidFaceType()<<"\t";3 m# z! F: m* T( c0 e" b
     ss <<"Face Name: " <<totalfaces[j]->Name().GetUTF8Text()<<"\n";
1 D$ K/ N* @9 c; i2 U# A' y    }7 m- O0 x$ h, \3 t3 [1 t
   ss <<"Features count = " << totalFeature.size()<< "\n";
9 h: o+ `. i* ~8 q/ J* _     for(unsigned int j =0;j < totalFeature.size(); j++)
5 S+ D% L: A1 A    {  . a8 I) [6 E* J( D" y1 y  e
     ss <<"features tag : " << totalFeature[j]->Tag()<<"\t";
4 e; d1 ]) [8 ?$ p9 A; Z: w9 I$ }     ss <<"features Type: " << totalFeature[j]->FeatureType().GetUTF8Text()<<"\t";9 |. j/ K  |* P: C/ a' l
     ss <<"features Name: " <<totalFeature[j]->GetFeatureName().GetUTF8Text()<<"\n";% l. ]+ @2 k4 l5 u% w; z8 V5 a
    }& Q/ ?- }( F4 e" T
  theSession->ListingWindow()->WriteLine(ss.str());
% K5 K3 x& Z, p! u# X5 y
6 A. V4 h5 V; _5 k" E1 M1 J. }; E
查询结果如下:
0 ^* q0 U- q6 N9 N* r" [; H' k  }) A) p& T2 c1 ?! y' Z# K
( n: Y" Y+ @9 ?! t
Get information from all bodies- L4 o/ L3 ]7 s1 H8 z+ a
CYLINDERBodies count = 7/ _# l8 j; j/ ]& z4 v
edges count = 22
8 c1 t* g* ~  Eedges tag: 41404 edges vertex 1: (100,0,0) edges vertex 2: (100,0,100); d! s$ U% Q# z2 z# Z" K& s! N8 q
edges tag: 41404 edges vertex 1: (100,0,0) edges vertex 2: (100,100,0)
7 ~- k$ A) j! o  uedges tag: 41404 edges vertex 1: (0,100,0) edges vertex 2: (0,100,100)
+ [' I6 E# o8 E/ R- a. j& U2 Jedges tag: 41404 edges vertex 1: (100,100,0) edges vertex 2: (0,100,0)
( y8 f4 w! y* \* a! Q) |2 wedges tag: 41404 edges vertex 1: (100,0,100) edges vertex 2: (0,0,100)+ i! X- _! k* R& p  F6 h6 o; }
edges tag: 41404 edges vertex 1: (0,0,0) edges vertex 2: (100,0,0)3 ]: R  z5 \% _# ]
edges tag: 41404 edges vertex 1: (100,100,0) edges vertex 2: (100,100,100)
6 X' L/ G: r/ Z5 i9 Oedges tag: 41404 edges vertex 1: (0,100,100) edges vertex 2: (100,100,100)
. P4 Z: \4 X8 O7 c; ^edges tag: 41404 edges vertex 1: (0,0,100) edges vertex 2: (0,100,100)0 h1 k1 U2 P" d( i
edges tag: 41404 edges vertex 1: (100,100,100) edges vertex 2: (100,0,100)
2 H+ E) z: q& H, Cedges tag: 41404 edges vertex 1: (0,0,0) edges vertex 2: (0,0,100)1 Y+ h+ V& Y8 M6 \$ o
edges tag: 41404 edges vertex 1: (0,100,0) edges vertex 2: (0,0,0), v" T7 W  a( L% z
edges tag: 40966 edges vertex 1: (50,0,100) edges vertex 2: (50,0,100); C& Z8 O' k8 T/ A
edges tag: 40966 edges vertex 1: (50,0,200) edges vertex 2: (50,0,200)$ ?7 W* [8 ~% f! d7 ~+ ]7 Y
edges tag: 40977 edges vertex 1: (50,0,200) edges vertex 2: (50,0,200)
* Y5 P8 y0 l  [2 fedges tag: 40977 edges vertex 1: (50,0,300) edges vertex 2: (50,0,300)0 h2 h9 S0 d5 V+ b, z
edges tag: 37824 edges vertex 1: (50,0,300) edges vertex 2: (50,0,300)
$ m' f/ I! X4 b3 a6 g: ^$ cedges tag: 37824 edges vertex 1: (50,0,400) edges vertex 2: (50,0,400)
' V& ]0 _( _& A% K+ c2 @7 jedges tag: 41200 edges vertex 1: (50,0,400) edges vertex 2: (50,0,400)! H" ?7 R3 M" [5 V" T  [- _4 K
edges tag: 41200 edges vertex 1: (50,0,500) edges vertex 2: (50,0,500)
/ b/ x" Q1 d! V$ jedges tag: 41357 edges vertex 1: (150,100,200) edges vertex 2: (150,100,200)' U; @4 p0 j. j- B9 Q) p  U) z: A
edges tag: 41357 edges vertex 1: (150,100,100) edges vertex 2: (150,100,100)
0 {) {+ f: \- Lfaces count = 225 z+ s5 o1 A# q$ ~5 l' F6 A$ Q
Face tag: 41407 Face Type: 4 Face Name:
9 t3 h% w  S# J# y5 E1 Y. h3 UFace tag: 41398 Face Type: 1 Face Name: & L5 R1 r+ d. I7 h9 @1 z
Face tag: 41376 Face Type: 1 Face Name:
1 h) l# X1 j! UFace tag: 41391 Face Type: 1 Face Name:
6 ?9 M" p# l' ^0 f6 r) kFace tag: 41380 Face Type: 1 Face Name: # r+ k- J7 P7 H" t* {
Face tag: 41396 Face Type: 1 Face Name:
6 n- C. d! V" EFace tag: 41397 Face Type: 1 Face Name:
# A$ V% G0 @( K4 z# f; IFace tag: 40995 Face Type: 2 Face Name: ( f& j! g9 u; u, [: M* l
Face tag: 40965 Face Type: 1 Face Name: 8 w( K6 W/ F0 y9 {3 r4 ~
Face tag: 40997 Face Type: 1 Face Name:
) l9 C* w6 ~  G3 I' lFace tag: 41351 Face Type: 1 Face Name: - q) q" m6 D- j7 t* z
Face tag: 41352 Face Type: 1 Face Name:
& E+ L1 j+ O5 z8 xFace tag: 41353 Face Type: 2 Face Name: 2 P- C6 ~$ _9 ~9 c
Face tag: 38479 Face Type: 1 Face Name:
7 w) [5 G" [" [& l. HFace tag: 38480 Face Type: 1 Face Name: ; @# M4 _! m( d" W
Face tag: 38481 Face Type: 2 Face Name:
, N; F4 _/ p9 E  `Face tag: 41207 Face Type: 1 Face Name: - T- I( g: z# O# o- d
Face tag: 41203 Face Type: 1 Face Name: 9 b  o' I: }+ X# q2 B" o
Face tag: 41158 Face Type: 2 Face Name: - w3 `2 V& Y, X
Face tag: 40987 Face Type: 2 Face Name:
) E0 |+ m3 T3 t% `8 }) ]Face tag: 41010 Face Type: 1 Face Name: 9 y  O' Z- H- }. H# S2 Q1 [/ S
Face tag: 41001 Face Type: 1 Face Name: " @  }6 W, i" }7 o
Features count = 70 @4 ^- s' X! X" J1 b' R5 J
features tag : 41280 features Type: SPHERE features Name: Sphere(17)
- F" m5 x+ l$ ]% ]features tag : 41281 features Type: BLOCK features Name: Block(18)4 \6 @6 A) |9 S4 e# E0 Z5 p7 [: o
features tag : 41307 features Type: CYLINDER features Name: Cylinder(19)
3 ^: [% M0 G/ zfeatures tag : 41314 features Type: CYLINDER features Name: Cylinder(20)
1 b/ W! r4 w- ffeatures tag : 41322 features Type: CYLINDER features Name: Cylinder(21)
" F3 y" h5 ]+ d7 j; `features tag : 41330 features Type: CYLINDER features Name: Cylinder(22)
: i: C9 B0 |" g& @9 G4 s5 pfeatures tag : 41338 features Type: CYLINDER features Name: Cylinder(23)- L5 L1 u) a( E) s3 P
. d8 y; V5 E1 i# |+ C/ d8 p6 w8 ~
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了