PLM之家PLMHome-工业软件与AI结合践行者

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

[复制链接]

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

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

小新 楼主

2014-5-8 15:55:39

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

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

x
本帖最后由 小新 于 2014-5-8 16:10 编辑 5 [& M* J- p5 @9 ]" [

  c# x9 C0 M- u/ [) L8 l录制装配过程的JA,经过对录制的代码进行简化删减后,如下,经编译后能够实现自动化装配。
  1. Session *theSession = Session::GetSession();: b6 Q5 w/ A* d' d" o) G
  2.     Part *workPart(theSession->Parts()->Work());; L  ]1 ?" o$ W1 w* g7 \& n
  3.     Part *displayPart(theSession->Parts()->Display());
    $ I4 a7 \) ^, f9 T
  4.             
    ; S& z; f  l5 ^0 k
  5.     BasePart *basePart1;
    7 p) Z) z; M1 H0 ^* m
  6.     PartLoadStatus *partLoadStatus1;
    9 X% V+ A& H, P3 U
  7.     basePart1 = theSession->Parts()->OpenBase("D:\\sy\\model4.prt", &partLoadStatus1);
    ' a" A3 j3 V+ z8 v  R  Q; l
  8.     delete partLoadStatus1;
    6 w: b1 r5 [; y4 C* Q
  9.     6 {9 d' C! \0 q( C& J
  10.     Point3d basePoint1(0.0, 0.0, 0.0);9 `: Q- J( D% s  B5 J
  11.     Matrix3x3 orientation1;
    & j2 N1 H* e$ ~5 U1 g1 y. e
  12.     orientation1.Xx = 1.0;    orientation1.Xy = 0.0;    orientation1.Xz = 0.0;2 y" ?7 }' @* [" N6 r* l
  13.     orientation1.Yx = 0.0;    orientation1.Yy = 1.0;    orientation1.Yz = 0.0;) B( _" ?, W' [- M
  14.     orientation1.Zx = 0.0;    orientation1.Zy = 0.0;    orientation1.Zz = 1.0;
    ! F6 P" m% p, C& M7 a
  15.     PartLoadStatus *partLoadStatus2;6 ~+ m) U) E$ O5 ?
  16.     Assemblies::Component *component1;& n* M9 D8 D* q+ y) y9 c5 f, G: j
  17.     component1 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model4.prt", "MODEL", "MODEL4", basePoint1, orientation1, -1, &partLoadStatus2, true);//添加组件  Z: A3 @0 W- X& y! _
  18.    delete partLoadStatus2;  ) @) Z4 a% A$ G. Q4 {
  19.     " Y4 y2 ]! p1 }. \
  20.     BasePart *basePart2;! H8 z# ]0 f& s& b8 I
  21.     PartLoadStatus *partLoadStatus3;4 t0 E! N( A3 ^1 m9 A* w
  22.     basePart2 = theSession->Parts()->OpenBase("D:\\sy\\model5.prt", &partLoadStatus3);   
    / S0 z  f) b" j8 Y0 v5 ~
  23.     delete partLoadStatus3;   
    ' G6 ]; c1 e8 V" m2 ^
  24.    
    : G% v+ k3 i; m/ q9 f# Y
  25.     Point3d basePoint2(0.0, 0.0, 0.0);! }0 q; `: i8 D, [& f6 e6 x
  26.     Matrix3x3 orientation2;
    1 N2 x. d* E5 S! o4 k
  27.     orientation2.Xx = 1.0;    orientation2.Xy = 0.0;    orientation2.Xz = 0.0;
    0 H. {7 A6 G2 |0 _# P; c! H
  28.     orientation2.Yx = 0.0;    orientation2.Yy = 1.0;    orientation2.Yz = 0.0;0 K: h# J4 i: m/ T6 I' D
  29.     orientation2.Zx = 0.0;    orientation2.Zy = 0.0;    orientation2.Zz = 1.0;
    9 J) h2 g6 B( k' d
  30.     PartLoadStatus *partLoadStatus4;
    9 K; A* C1 l* }9 b8 G# G
  31.     Assemblies::Component *component2;+ R5 F. U# p8 n
  32.     component2 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model5.prt", "MODEL", "MODEL5", basePoint2, orientation2, -1, &partLoadStatus4, true);//添加组件% \: C! j2 B4 y$ O4 D
  33.    delete partLoadStatus4;  1 U: E  U* L" j7 |! k7 m. j
  34.     : k, g3 R# V+ c; H, T
  35.     Positioning::ComponentPositioner *componentPositioner1;) g6 l+ i+ ~6 G1 r; [6 O' Q
  36.     componentPositioner1 = workPart->ComponentAssembly()->Positioner();     
    / \8 ]% {0 i+ x) _. ?+ X6 J( X
  37.     componentPositioner1->BeginAssemblyConstraints();      
    & C/ f5 c0 Y, X2 E/ }+ p6 t
  38.    
    6 ~3 V( ~% L: }" e
  39.     Positioning::Network *network1;- P, c; L# P) o7 n+ J' v  t
  40.     network1 = componentPositioner1->EstablishNetwork();   
    4 ^! y- b& `/ _
  41.     Positioning::ComponentNetwork *componentNetwork1(dynamic_cast<Positioning::ComponentNetwork *>(network1));& Z3 Q% Q- P) v! g: |
  42.     componentNetwork1->SetMoveObjectsState(true);              
    : `) }! a' t2 v7 C( P* q+ X
  43.     + ^8 b% M; {. S: N% x8 j
  44.     Positioning::Constraint *constraint1;2 U. d. L- c) i2 y& z6 u% L+ b- W
  45.     constraint1 = componentPositioner1->CreateConstraint(true);* H; Y+ u8 a0 u1 Z8 Z2 v- D
  46.     : @6 d: `& }, b+ h
  47.     Positioning::ComponenTConstraint *componentConstraint1(dynamic_cast<Positioning::ComponentConstraint *>(constraint1));4 J, |1 ]4 M; t+ H6 [5 n
  48.     componentConstraint1->SetConstraintAlignment(Positioning::Constraint::AlignmentContraAlign);    * _% v' r4 y" \( @+ F( j
  49.     componentConstraint1->SetConstraintType(Positioning::Constraint::TypeTouch);( {  H0 y+ ^$ E/ |
  50.    
    , X. E+ s7 t5 r
  51.     Face *face1(dynamic_cast<Face *>(component2->FindObject("PROTO#.Features|BLOCK(1)|FACE 6 {(500,25,25) BLOCK(1)}")));        4 b- ?# w0 D( \" B" Y2 [  q# C; u
  52.     Positioning::ConstraintReference *constraintReference1;
复制代码
但是出现了一个问题,在上述代码中,进行装配的面是通过FindObject来找到的,不是我想要的那个面,而且FindObject函数参数是一个JA标识符,我无法给某个面定义JA标示符。如果我在建立模型时,我给某个面命名为FACE1。那么我如何找到我想要的面FACE1,然后用于代码/ z/ o! b7 ?' t5 ^! z/ E
  1. constraintReference1 = componentConstraint1->CreateConstraintReference(component2, face1, false, false, false);
复制代码
其中上述代码中第二参数类型是NXObject *,也无法通过Ufun函数的UF_OBJ_cycle_by_name找到,因为该函数找到是FACE1面的tag,返回的类型不是NXObject *。* s8 @9 o( X; r9 ?5 P) S2 |( |
问题:9 X: H2 w4 R' z' O5 K! q
1)C++中是否有某个方法通过某个对象的tag返回其NXObject *类型2 r# j4 T5 Y" b9 T( h
2)C++是否有某个类中的方法可以找到occurrence中的面(CreateConstraintReference需要的是occurrence的对象),而且返回的是NXObject *类型对象,可以直接用于CreateConstraintReference()方法。5 P8 t( J( h9 S9 D) |: ?7 H
/ S3 S/ o  X" @& |  C" }! k1 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 返回 NXobject6 u" H, H# |) @$ \' E
! Y% `8 |( p* W! B3 n+ D6 t
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了