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

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

[复制链接]

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

小新 发表于 2014-5-8 15:55:39 |阅读模式

小新 楼主

2014-5-8 15:55:39

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

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

x
本帖最后由 小新 于 2014-5-8 16:10 编辑
- p! N! o' B; _+ @  x7 X3 ~7 m
- R6 s0 R3 b2 d, `# ^& d录制装配过程的JA,经过对录制的代码进行简化删减后,如下,经编译后能够实现自动化装配。
  1. Session *theSession = Session::GetSession();7 P5 Z/ n2 H" U6 j9 e
  2.     Part *workPart(theSession->Parts()->Work());8 F4 R5 C( Y* I( P9 a
  3.     Part *displayPart(theSession->Parts()->Display());  m+ k% L) B# p5 R& O, l6 o
  4.             
    # \6 o! d" J' ~' A
  5.     BasePart *basePart1;
    6 ]5 U# J! H8 }: Z7 c9 \
  6.     PartLoadStatus *partLoadStatus1;! x. \, q$ u5 E. f1 n2 }
  7.     basePart1 = theSession->Parts()->OpenBase("D:\\sy\\model4.prt", &partLoadStatus1);
    4 T' a) Q# i  |% u
  8.     delete partLoadStatus1;
    8 q5 V' {5 m8 l0 r6 B
  9.    
    $ t% }. d, h8 R
  10.     Point3d basePoint1(0.0, 0.0, 0.0);
    1 S, R) O+ n+ [7 m( {/ d
  11.     Matrix3x3 orientation1;
    # x) N# q. U) l/ D4 @% y2 \- N, q
  12.     orientation1.Xx = 1.0;    orientation1.Xy = 0.0;    orientation1.Xz = 0.0;- B3 n' X# s, [" f3 {
  13.     orientation1.Yx = 0.0;    orientation1.Yy = 1.0;    orientation1.Yz = 0.0;
    * N  o3 v5 A$ B7 S0 c
  14.     orientation1.Zx = 0.0;    orientation1.Zy = 0.0;    orientation1.Zz = 1.0;% o$ o6 o8 a, `) w2 I
  15.     PartLoadStatus *partLoadStatus2;
    3 N$ i4 ]2 c  D
  16.     Assemblies::Component *component1;
    0 f- z7 Z  h' m& G* V. `# B
  17.     component1 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model4.prt", "MODEL", "MODEL4", basePoint1, orientation1, -1, &partLoadStatus2, true);//添加组件2 Z1 I7 `# `3 [8 c* O! J
  18.    delete partLoadStatus2;  
      }3 W: i6 u; o& }. k" v2 X
  19.     4 e5 z7 Z& {. N1 m7 [) w4 u3 F, T7 s5 O
  20.     BasePart *basePart2;
    2 X- Z6 W; J. Q  l4 U
  21.     PartLoadStatus *partLoadStatus3;
    ; Q$ Y3 q5 ^& G2 J3 K
  22.     basePart2 = theSession->Parts()->OpenBase("D:\\sy\\model5.prt", &partLoadStatus3);    * T/ U& l9 V, N
  23.     delete partLoadStatus3;    % L" _% l3 {7 g# l
  24.    
    / h) \/ x! n9 ^& ~0 V
  25.     Point3d basePoint2(0.0, 0.0, 0.0);2 o/ f3 n* i& W% ]
  26.     Matrix3x3 orientation2;
    0 M% e- a& v# A0 p4 x) i
  27.     orientation2.Xx = 1.0;    orientation2.Xy = 0.0;    orientation2.Xz = 0.0;' `' Z: F# C" A4 r7 Y% r9 a
  28.     orientation2.Yx = 0.0;    orientation2.Yy = 1.0;    orientation2.Yz = 0.0;
    : u& c3 x8 E4 C$ j6 n" T# o8 O0 R
  29.     orientation2.Zx = 0.0;    orientation2.Zy = 0.0;    orientation2.Zz = 1.0;, b# o. v; W/ ]
  30.     PartLoadStatus *partLoadStatus4;
    1 a5 Y& V8 r8 n! l) r
  31.     Assemblies::Component *component2;5 C/ t8 n& }7 d& h! X5 \# r
  32.     component2 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model5.prt", "MODEL", "MODEL5", basePoint2, orientation2, -1, &partLoadStatus4, true);//添加组件
    ; u0 o. i( I# _, r
  33.    delete partLoadStatus4;  ! I! E% v% N  K; {
  34.     / F, T2 b2 I$ ]6 `' Q
  35.     Positioning::ComponentPositioner *componentPositioner1;. ^' o; x' T4 \) J, @2 @
  36.     componentPositioner1 = workPart->ComponentAssembly()->Positioner();     , z6 w) [# F/ I: a: ]1 \6 T0 R
  37.     componentPositioner1->BeginAssemblyConstraints();      
    8 g) Z" E3 C+ u! a+ O. ^- L
  38.    
    / \7 v" t1 R9 ]4 I( I1 j! O
  39.     Positioning::Network *network1;
    ' `$ J) z2 Z- l6 m
  40.     network1 = componentPositioner1->EstablishNetwork();   
    ) R; V' D  Y& H& F5 h" A5 ~) J' r
  41.     Positioning::ComponentNetwork *componentNetwork1(dynamic_cast<Positioning::ComponentNetwork *>(network1));
    & F" C  ?+ a+ S3 q5 z2 g* A1 a
  42.     componentNetwork1->SetMoveObjectsState(true);              
    0 h' c# B; y$ y" f) n% K/ a
  43.     3 S" W- X& u  i1 Q/ r! I* d
  44.     Positioning::Constraint *constraint1;
    2 D3 i& W) H4 H
  45.     constraint1 = componentPositioner1->CreateConstraint(true);
    5 L% b4 ?, V$ s4 P) Y$ q0 t
  46.     * {7 W, y5 K7 j+ k& i) O# G
  47.     Positioning::ComponenTConstraint *componentConstraint1(dynamic_cast<Positioning::ComponentConstraint *>(constraint1));  q. F7 }. I. K& i+ |; \4 R! I
  48.     componentConstraint1->SetConstraintAlignment(Positioning::Constraint::AlignmentContraAlign);    ; N' w) d$ O2 g
  49.     componentConstraint1->SetConstraintType(Positioning::Constraint::TypeTouch);" t2 T$ @) }$ @" y/ e8 O
  50.     ' F3 N+ P  Y. U( c+ U' ^
  51.     Face *face1(dynamic_cast<Face *>(component2->FindObject("PROTO#.Features|BLOCK(1)|FACE 6 {(500,25,25) BLOCK(1)}")));        9 o3 x; q  |4 s& u  v
  52.     Positioning::ConstraintReference *constraintReference1;
复制代码
但是出现了一个问题,在上述代码中,进行装配的面是通过FindObject来找到的,不是我想要的那个面,而且FindObject函数参数是一个JA标识符,我无法给某个面定义JA标示符。如果我在建立模型时,我给某个面命名为FACE1。那么我如何找到我想要的面FACE1,然后用于代码- [* F! M0 Q2 b4 y
  1. constraintReference1 = componentConstraint1->CreateConstraintReference(component2, face1, false, false, false);
复制代码
其中上述代码中第二参数类型是NXObject *,也无法通过Ufun函数的UF_OBJ_cycle_by_name找到,因为该函数找到是FACE1面的tag,返回的类型不是NXObject *。
- q, z( k# K; t5 }问题:4 `" E+ i" Y6 l( J
1)C++中是否有某个方法通过某个对象的tag返回其NXObject *类型4 C# t9 Z7 s, h* x
2)C++是否有某个类中的方法可以找到occurrence中的面(CreateConstraintReference需要的是occurrence的对象),而且返回的是NXObject *类型对象,可以直接用于CreateConstraintReference()方法。
- U6 A8 f/ l, g  n7 P9 D/ @9 i! i" q! t- m( [2 K% U0 R$ H
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复1

admin 发表于 2014-5-9 10:26:29

admin 沙发

2014-5-9 10:26:29

tag 可以通过 NXObjectManager 返回 NXobject) [  n& X  \& u- O

, x' o; ]  a! ^# k  ^
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了