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

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

[复制链接]

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

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

小新 楼主

2014-5-8 15:55:39

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

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

x
本帖最后由 小新 于 2014-5-8 16:10 编辑
+ s9 g. C; b" x# s# ]& m- s! z0 W8 b% Z/ y
录制装配过程的JA,经过对录制的代码进行简化删减后,如下,经编译后能够实现自动化装配。
  1. Session *theSession = Session::GetSession();
    0 i3 J( `8 C3 @/ _! _( {) X
  2.     Part *workPart(theSession->Parts()->Work());) i; [! P7 F3 J2 h  Y: m5 j# T
  3.     Part *displayPart(theSession->Parts()->Display());
    0 S' J8 O+ t( h8 ]/ n, G
  4.             4 ]% @9 c. K) o' S5 ~. }+ k% c
  5.     BasePart *basePart1;) `) M- m! ~/ Q% @/ m
  6.     PartLoadStatus *partLoadStatus1;% Q- y. @$ P+ \3 t6 s( ?
  7.     basePart1 = theSession->Parts()->OpenBase("D:\\sy\\model4.prt", &partLoadStatus1);2 C8 n, }2 d* U7 I% K
  8.     delete partLoadStatus1;8 ^9 v+ L5 D' R# ]
  9.     3 {% U: }5 V" C$ Y: E, r! u+ {# ]
  10.     Point3d basePoint1(0.0, 0.0, 0.0);
    % S- I5 B& I* G- o9 R
  11.     Matrix3x3 orientation1;
    ' X5 v8 t/ L, \2 |. U7 v0 c
  12.     orientation1.Xx = 1.0;    orientation1.Xy = 0.0;    orientation1.Xz = 0.0;$ g7 m5 d6 `: i) V1 X% T/ O
  13.     orientation1.Yx = 0.0;    orientation1.Yy = 1.0;    orientation1.Yz = 0.0;
    : b# J/ y  s$ G- y$ W+ w2 u. H9 n
  14.     orientation1.Zx = 0.0;    orientation1.Zy = 0.0;    orientation1.Zz = 1.0;+ L/ Y9 h; d* @
  15.     PartLoadStatus *partLoadStatus2;0 E6 [1 |! [3 T8 E/ M
  16.     Assemblies::Component *component1;6 F, {; l: K0 z$ ~, Z
  17.     component1 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model4.prt", "MODEL", "MODEL4", basePoint1, orientation1, -1, &partLoadStatus2, true);//添加组件/ A; t  R/ M% ~  M" x
  18.    delete partLoadStatus2;  ! {* `: J0 P* {/ @4 u% ~" ^) |- \
  19.     . M5 ?) V4 b5 p/ r# m2 ^2 ]0 h
  20.     BasePart *basePart2;, R8 a/ K+ ]6 J  k( r4 s1 r
  21.     PartLoadStatus *partLoadStatus3;/ |+ A- Z) J  X: X3 c; N
  22.     basePart2 = theSession->Parts()->OpenBase("D:\\sy\\model5.prt", &partLoadStatus3);   
    % N4 F7 N2 [; Y: t$ T1 p
  23.     delete partLoadStatus3;   
    8 p+ ]. \* T1 D) C) y9 @0 ^
  24.     # \2 `! r( g) X5 ^5 X
  25.     Point3d basePoint2(0.0, 0.0, 0.0);6 K) C* v' A0 \8 k! A: H
  26.     Matrix3x3 orientation2;: X. \- ?4 I! p
  27.     orientation2.Xx = 1.0;    orientation2.Xy = 0.0;    orientation2.Xz = 0.0;
    ( l8 A, S0 U9 `/ N) d6 M
  28.     orientation2.Yx = 0.0;    orientation2.Yy = 1.0;    orientation2.Yz = 0.0;" h' I1 O' n: s
  29.     orientation2.Zx = 0.0;    orientation2.Zy = 0.0;    orientation2.Zz = 1.0;
      N% p& S2 M% A) ~4 K. a
  30.     PartLoadStatus *partLoadStatus4;! q1 B6 N- N- X7 w' E8 V
  31.     Assemblies::Component *component2;
    / l5 ]( b: M3 n2 O, l  A6 B$ T
  32.     component2 = workPart->ComponentAssembly()->AddComponent("D:\\sy\\model5.prt", "MODEL", "MODEL5", basePoint2, orientation2, -1, &partLoadStatus4, true);//添加组件. C7 a, \6 M. b: j0 R0 [
  33.    delete partLoadStatus4;  
    * y- I: c/ s0 ?( X
  34.     / `: O3 v+ j' j, \" R8 |2 L
  35.     Positioning::ComponentPositioner *componentPositioner1;
    / M( ~$ P$ K7 \9 w- E
  36.     componentPositioner1 = workPart->ComponentAssembly()->Positioner();     / t: e) }- u' T9 {; U, v
  37.     componentPositioner1->BeginAssemblyConstraints();      9 R+ `/ b( j: N* o6 f, S$ a
  38.     4 x4 ~, L6 X+ s. |+ S
  39.     Positioning::Network *network1;1 \! W, j: B) d" s. ~
  40.     network1 = componentPositioner1->EstablishNetwork();    % W: R2 z1 h) U. r9 [
  41.     Positioning::ComponentNetwork *componentNetwork1(dynamic_cast<Positioning::ComponentNetwork *>(network1));
    0 g1 i) m; f( ~7 u
  42.     componentNetwork1->SetMoveObjectsState(true);              4 L$ u+ _; c6 i) R5 [4 R+ e
  43.     ! L1 }* y# d$ }/ w9 B- \- E
  44.     Positioning::Constraint *constraint1;
    : h( p7 P! E! r  ~7 ^
  45.     constraint1 = componentPositioner1->CreateConstraint(true);% u/ p; B% Y9 Z0 g
  46.     + _2 Y& M$ X5 x" f6 r- G! P
  47.     Positioning::ComponenTConstraint *componentConstraint1(dynamic_cast<Positioning::ComponentConstraint *>(constraint1));* @7 b' \/ `& J% @0 t1 w
  48.     componentConstraint1->SetConstraintAlignment(Positioning::Constraint::AlignmentContraAlign);    2 h% x7 M" N% K
  49.     componentConstraint1->SetConstraintType(Positioning::Constraint::TypeTouch);. f% `5 c7 s  t/ b* i
  50.     ' R' A8 q  m4 L2 H6 G$ R( v
  51.     Face *face1(dynamic_cast<Face *>(component2->FindObject("PROTO#.Features|BLOCK(1)|FACE 6 {(500,25,25) BLOCK(1)}")));        2 b: h, y% p0 P* N
  52.     Positioning::ConstraintReference *constraintReference1;
复制代码
但是出现了一个问题,在上述代码中,进行装配的面是通过FindObject来找到的,不是我想要的那个面,而且FindObject函数参数是一个JA标识符,我无法给某个面定义JA标示符。如果我在建立模型时,我给某个面命名为FACE1。那么我如何找到我想要的面FACE1,然后用于代码  m+ b  D" G) H8 w3 \. E' q
  1. constraintReference1 = componentConstraint1->CreateConstraintReference(component2, face1, false, false, false);
复制代码
其中上述代码中第二参数类型是NXObject *,也无法通过Ufun函数的UF_OBJ_cycle_by_name找到,因为该函数找到是FACE1面的tag,返回的类型不是NXObject *。
4 q' q/ J% z: R3 }4 T& t. b0 g% ~问题:/ e4 U! x* u3 \8 |
1)C++中是否有某个方法通过某个对象的tag返回其NXObject *类型9 s" D" ^$ @1 V, e
2)C++是否有某个类中的方法可以找到occurrence中的面(CreateConstraintReference需要的是occurrence的对象),而且返回的是NXObject *类型对象,可以直接用于CreateConstraintReference()方法。
8 ?1 g" q: c2 F& G: \& p! |: i8 X% w! G# E+ _  x
上海点团信息科技有限公司,承接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
' R6 q- _- Q. A7 N
: d5 b7 h0 ^2 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二次开发专题模块培训报名开始啦

    我知道了