PLM之家PLMHome-工业软件践行者

[已解决] 如何查找一个部件对应的occurrence的面

[复制链接]

2014-5-9 10:26:29 3561 1

7

主题

28

回帖

173

积分

注册会员

积分
173
发表于 2014-5-8 15:55:39 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 小新 于 2014-5-8 16:10 编辑
) F9 Z/ R* o. c/ J1 ]6 @6 |
$ c& C: I+ b0 o: D2 o# C8 y录制装配过程的JA,经过对录制的代码进行简化删减后,如下,经编译后能够实现自动化装配。
  1. Session *theSession = Session::GetSession();" H! b, N; r: y
  2.     Part *workPart(theSession->Parts()->Work());1 n1 u5 P, O2 S! c
  3.     Part *displayPart(theSession->Parts()->Display());, c/ K# D6 g- a9 I0 k  A% i6 W
  4.             
    # e- y5 n3 Y4 L5 ]; g
  5.     BasePart *basePart1;
    # P+ c7 v' G( s$ q$ A% K
  6.     PartLoadStatus *partLoadStatus1;& o% E% S' b& H' F; `) D  i! q
  7.     basePart1 = theSession->Parts()->OpenBase("D:\\sy\\model4.prt", &partLoadStatus1);
    " q; K( d' P- o8 P0 @, }
  8.     delete partLoadStatus1;
    : F7 \9 `: g1 |! b
  9.     ; y9 t( M, w( W% D" H* \
  10.     Point3d basePoint1(0.0, 0.0, 0.0);
    % T, \2 h/ a3 O0 c
  11.     Matrix3x3 orientation1;
    ' C/ v: ^# B# p5 ?" `0 Z9 y9 o6 y
  12.     orientation1.Xx = 1.0;    orientation1.Xy = 0.0;    orientation1.Xz = 0.0;
    * c6 i: e' T* g' N. X0 @% `
  13.     orientation1.Yx = 0.0;    orientation1.Yy = 1.0;    orientation1.Yz = 0.0;# h4 r" O( `5 R  s# P
  14.     orientation1.Zx = 0.0;    orientation1.Zy = 0.0;    orientation1.Zz = 1.0;
    ; q4 J% q8 ?! d8 j
  15.     PartLoadStatus *partLoadStatus2;
    : U) J% _$ K1 g- S1 U% ?) B
  16.     Assemblies::Component *component1;1 T0 ~4 Y4 L* g3 ?+ e% o" V& n
  17.     component1 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model4.prt", "MODEL", "MODEL4", basePoint1, orientation1, -1, &partLoadStatus2, true);//添加组件+ F7 j+ }4 S+ R! s6 Y2 x$ V2 R
  18.    delete partLoadStatus2;  
    ( i) v- m0 r! Q3 K& c
  19.     ; o$ T7 c0 R( h9 C  w, g: B4 k! B' V
  20.     BasePart *basePart2;8 F2 ]0 m* P: f9 z: N) w9 ^! D/ Q6 p
  21.     PartLoadStatus *partLoadStatus3;
    7 S7 Q6 M4 \% S1 ?* Y
  22.     basePart2 = theSession->Parts()->OpenBase("D:\\sy\\model5.prt", &partLoadStatus3);   
    $ P+ E1 M8 c. C/ y+ l, w
  23.     delete partLoadStatus3;   
    5 o1 [) D/ j; y5 p7 C6 r
  24.    
    ( }/ ?4 C9 b8 b) G' ~" ~# z% g7 g
  25.     Point3d basePoint2(0.0, 0.0, 0.0);
    , s8 w% f9 l+ R: n
  26.     Matrix3x3 orientation2;
    7 z2 q2 [& _. X
  27.     orientation2.Xx = 1.0;    orientation2.Xy = 0.0;    orientation2.Xz = 0.0;
    4 y. Y9 r, r& k- C: }
  28.     orientation2.Yx = 0.0;    orientation2.Yy = 1.0;    orientation2.Yz = 0.0;
    $ Y  y1 z- [/ R! _6 o# t1 @% N
  29.     orientation2.Zx = 0.0;    orientation2.Zy = 0.0;    orientation2.Zz = 1.0;& \1 ]$ G' G' C. B, U" a4 i
  30.     PartLoadStatus *partLoadStatus4;0 V7 X% ^% c! T' J! e. {- j; ]1 L
  31.     Assemblies::Component *component2;
    8 t; n' h7 b+ ?
  32.     component2 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model5.prt", "MODEL", "MODEL5", basePoint2, orientation2, -1, &partLoadStatus4, true);//添加组件, s! K, p) k5 s, q
  33.    delete partLoadStatus4;  1 U4 c1 y1 a1 P& s
  34.    
    1 M% K; K: V5 h( |# l$ j
  35.     Positioning::ComponentPositioner *componentPositioner1;
    - r+ u( R! G2 P6 B" m- F$ O
  36.     componentPositioner1 = workPart->ComponentAssembly()->Positioner();     4 Z# _9 j) R7 A; F4 N& _
  37.     componentPositioner1->BeginAssemblyConstraints();      3 N. A6 [( l  _* m1 z8 e
  38.       H& ?$ F7 E( e( y1 u' x% Z" M% W
  39.     Positioning::Network *network1;5 B# y- x& h+ V: M6 }0 S8 x
  40.     network1 = componentPositioner1->EstablishNetwork();    7 ^* K4 b( V' c1 P
  41.     Positioning::ComponentNetwork *componentNetwork1(dynamic_cast<Positioning::ComponentNetwork *>(network1));
    1 ~/ L' q8 g5 s2 o( ]+ S
  42.     componentNetwork1->SetMoveObjectsState(true);              ; W4 ]1 h$ c) A/ b8 o  H4 P% ~
  43.    
    " \. a& _' g! [$ k, `$ C
  44.     Positioning::Constraint *constraint1;
    ! {( ^2 }& Y) ~+ J
  45.     constraint1 = componentPositioner1->CreateConstraint(true);% }0 V; H! a4 G# _9 h0 H) Y
  46.     : s  L$ G  k7 e5 m: W; y
  47.     Positioning::ComponenTConstraint *componentConstraint1(dynamic_cast<Positioning::ComponentConstraint *>(constraint1));/ p- f1 Z$ Z  Z' _$ h; C
  48.     componentConstraint1->SetConstraintAlignment(Positioning::Constraint::AlignmentContraAlign);   
    4 o! N5 K7 E) S# ^' a: B- p% v
  49.     componentConstraint1->SetConstraintType(Positioning::Constraint::TypeTouch);
    ) m) Q$ Y+ `# p  W
  50.    
    / q+ s6 o  [0 R" B& X0 T: ~
  51.     Face *face1(dynamic_cast<Face *>(component2->FindObject("PROTO#.Features|BLOCK(1)|FACE 6 {(500,25,25) BLOCK(1)}")));        
    - `5 k" P. }! c( @+ E/ U4 _/ m% z
  52.     Positioning::ConstraintReference *constraintReference1;
复制代码
但是出现了一个问题,在上述代码中,进行装配的面是通过FindObject来找到的,不是我想要的那个面,而且FindObject函数参数是一个JA标识符,我无法给某个面定义JA标示符。如果我在建立模型时,我给某个面命名为FACE1。那么我如何找到我想要的面FACE1,然后用于代码& @+ q" t" a3 E
  1. constraintReference1 = componentConstraint1->CreateConstraintReference(component2, face1, false, false, false);
复制代码
其中上述代码中第二参数类型是NXObject *,也无法通过Ufun函数的UF_OBJ_cycle_by_name找到,因为该函数找到是FACE1面的tag,返回的类型不是NXObject *。- z/ {$ [( \) r4 _6 P; v$ w  x2 T6 \
问题:/ b! w& X% J3 Y2 a; a' n
1)C++中是否有某个方法通过某个对象的tag返回其NXObject *类型  j1 Q. w9 p* R# [0 H! n. U. G0 z
2)C++是否有某个类中的方法可以找到occurrence中的面(CreateConstraintReference需要的是occurrence的对象),而且返回的是NXObject *类型对象,可以直接用于CreateConstraintReference()方法。
0 a7 d* ]1 T+ \/ y4 P
0 X- R+ l  t8 K
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.doteam.tech
回复

使用道具 举报

全部回复1

2470

主题

1275

回帖

8万

积分

管理员

PLM之家站长

积分
82162
QQ
发表于 2014-5-9 10:26:29 | 显示全部楼层
tag 可以通过 NXObjectManager 返回 NXobject
1 U# S0 O# O# }1 C' J5 r0 F3 a% ^
; l  f. Z7 W  }' K+ ]# f
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复 支持 反对

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

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

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

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

    我知道了