PLM之家PLMHome-国产软件践行者

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

[复制链接]

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

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

小新 楼主

2014-5-8 15:55:39

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

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

x
本帖最后由 小新 于 2014-5-8 16:10 编辑 % g# W" _7 T& }4 ?  \2 P
' D8 X1 x; ]7 z2 Z& I
录制装配过程的JA,经过对录制的代码进行简化删减后,如下,经编译后能够实现自动化装配。
  1. Session *theSession = Session::GetSession();8 ]6 l- `5 h. G  k/ j' R) ~- ^1 y* ~
  2.     Part *workPart(theSession->Parts()->Work());
    3 R- S2 X  g( p& @- ^5 ^* `  e1 \
  3.     Part *displayPart(theSession->Parts()->Display());
    3 ~, v6 y1 W8 w/ ~: S
  4.             / ?1 J; p9 ~7 ]: [
  5.     BasePart *basePart1;
    : X5 L0 o7 z/ s5 N, y; J
  6.     PartLoadStatus *partLoadStatus1;
    0 b- J+ Q, d/ w4 v' m6 \4 C2 o
  7.     basePart1 = theSession->Parts()->OpenBase("D:\\sy\\model4.prt", &partLoadStatus1);
      X$ k2 a9 H$ n
  8.     delete partLoadStatus1;
    7 u& p& f& g/ i6 |  R' e
  9.    
    0 Y! m( Z1 z$ g$ D7 D$ S6 H% O
  10.     Point3d basePoint1(0.0, 0.0, 0.0);
    ' |; {0 }; g1 p2 h; ^
  11.     Matrix3x3 orientation1;
    ; @8 Z( i4 m! {; b' ^, v
  12.     orientation1.Xx = 1.0;    orientation1.Xy = 0.0;    orientation1.Xz = 0.0;  c8 `7 z9 @6 V# ^0 r
  13.     orientation1.Yx = 0.0;    orientation1.Yy = 1.0;    orientation1.Yz = 0.0;( I; N) |4 I8 X# F5 [/ r( p
  14.     orientation1.Zx = 0.0;    orientation1.Zy = 0.0;    orientation1.Zz = 1.0;4 p( t  u" P" V6 C$ j. j1 @" Q
  15.     PartLoadStatus *partLoadStatus2;7 X$ Q' Z1 J% Z
  16.     Assemblies::Component *component1;$ ~- H; v. @" s6 \  A, o
  17.     component1 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model4.prt", "MODEL", "MODEL4", basePoint1, orientation1, -1, &partLoadStatus2, true);//添加组件
    " |7 y+ n8 [) V
  18.    delete partLoadStatus2;  
    5 I( j( r' p- {  U+ M+ Y* T4 Q1 P. A$ o
  19.    
    , ~2 t) k. Z) R( V5 V& ]4 S
  20.     BasePart *basePart2;! @/ X9 s' w! Q4 U6 }
  21.     PartLoadStatus *partLoadStatus3;
    4 S5 I: }9 Q; k/ n
  22.     basePart2 = theSession->Parts()->OpenBase("D:\\sy\\model5.prt", &partLoadStatus3);   
    6 B& K, @+ U: ]8 g! P' K& v$ q
  23.     delete partLoadStatus3;   
    $ R6 }3 _0 N5 M
  24.     4 a2 w3 V3 V; h3 X
  25.     Point3d basePoint2(0.0, 0.0, 0.0);
    + ^2 K+ c( w! p
  26.     Matrix3x3 orientation2;
    ! Q" y* p4 V1 [0 o; K6 C1 H
  27.     orientation2.Xx = 1.0;    orientation2.Xy = 0.0;    orientation2.Xz = 0.0;
    3 O* B1 W6 R' N4 h
  28.     orientation2.Yx = 0.0;    orientation2.Yy = 1.0;    orientation2.Yz = 0.0;+ p* x3 p6 N! c! g9 X! Z
  29.     orientation2.Zx = 0.0;    orientation2.Zy = 0.0;    orientation2.Zz = 1.0;
    , L/ a3 ^# l8 Z! S3 V  J
  30.     PartLoadStatus *partLoadStatus4;9 J( A4 V  o- ?5 G
  31.     Assemblies::Component *component2;
    0 k) w) |2 W" Z* z" {* B8 `! p! R
  32.     component2 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model5.prt", "MODEL", "MODEL5", basePoint2, orientation2, -1, &partLoadStatus4, true);//添加组件
    # n8 I( a  ~" J5 @( U
  33.    delete partLoadStatus4;  
    ' F* W& C/ o; H3 ^
  34.    
    . |. O/ e  |  ]8 e" B
  35.     Positioning::ComponentPositioner *componentPositioner1;' I/ v6 n; g8 H& G
  36.     componentPositioner1 = workPart->ComponentAssembly()->Positioner();     1 }& v$ n& `4 @  X
  37.     componentPositioner1->BeginAssemblyConstraints();      2 s. @3 {( I7 k7 |1 ]4 |+ [3 w- v
  38.     - N, z' \2 c. a& s
  39.     Positioning::Network *network1;% c' w, i, R) |3 Z! }3 d
  40.     network1 = componentPositioner1->EstablishNetwork();    ; G- i0 _' d, G, _
  41.     Positioning::ComponentNetwork *componentNetwork1(dynamic_cast<Positioning::ComponentNetwork *>(network1));( U9 j5 _5 i/ d6 o4 |8 v8 u
  42.     componentNetwork1->SetMoveObjectsState(true);              + x: h$ r" l& v
  43.     ( @4 Z  C/ H$ `8 w1 h" z
  44.     Positioning::Constraint *constraint1;
    ' D/ V8 B! I: N7 `5 x
  45.     constraint1 = componentPositioner1->CreateConstraint(true);
    & x8 q; Q. I. a+ C
  46.    
    4 W, n. c3 X, ?. P, v4 f5 M4 p
  47.     Positioning::ComponenTConstraint *componentConstraint1(dynamic_cast<Positioning::ComponentConstraint *>(constraint1));3 g! S6 E0 J" @
  48.     componentConstraint1->SetConstraintAlignment(Positioning::Constraint::AlignmentContraAlign);   
    ' u3 _* E1 t/ }) |/ ~2 A
  49.     componentConstraint1->SetConstraintType(Positioning::Constraint::TypeTouch);
    % _$ W+ R% U- e% W. O  ^
  50.     / A0 ?6 E& N3 c% q  s( m
  51.     Face *face1(dynamic_cast<Face *>(component2->FindObject("PROTO#.Features|BLOCK(1)|FACE 6 {(500,25,25) BLOCK(1)}")));        
    9 o; j, a4 n/ h
  52.     Positioning::ConstraintReference *constraintReference1;
复制代码
但是出现了一个问题,在上述代码中,进行装配的面是通过FindObject来找到的,不是我想要的那个面,而且FindObject函数参数是一个JA标识符,我无法给某个面定义JA标示符。如果我在建立模型时,我给某个面命名为FACE1。那么我如何找到我想要的面FACE1,然后用于代码8 b) O  }/ E; w
  1. constraintReference1 = componentConstraint1->CreateConstraintReference(component2, face1, false, false, false);
复制代码
其中上述代码中第二参数类型是NXObject *,也无法通过Ufun函数的UF_OBJ_cycle_by_name找到,因为该函数找到是FACE1面的tag,返回的类型不是NXObject *。
: ^7 ^8 o: \5 R0 I/ h4 ^3 I2 p问题:( t' h' Z' b$ v" P% e
1)C++中是否有某个方法通过某个对象的tag返回其NXObject *类型8 ]  O- F6 }; y* q8 C& i$ f. `# Y
2)C++是否有某个类中的方法可以找到occurrence中的面(CreateConstraintReference需要的是occurrence的对象),而且返回的是NXObject *类型对象,可以直接用于CreateConstraintReference()方法。
. L( F4 ?6 I  k. S$ ?7 S. `
& B' }4 I& Q+ O6 \& N
上海点团信息科技有限公司,承接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* ]! R+ ^1 @0 d

2 {+ _. o8 D9 L3 ~4 Q/ U
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了