PLM之家精品课程培训,联系电话:18301858168 QQ: 939801026

  • NX二次开培训

    NX二次开培训

    适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术对于老鸟也值得借鉴!.

    NX CAM二次开发培训报名 NX二次开发基础培训报名
  • PLM之家Catia CAA二次开发培训

    Catia二次开发培训

    Catia二次开发的市场大,这方面开发人才少,难度大。所以只要你掌握了开发,那么潜力巨大,随着时间的积累,你必将有所用武之地!

  • PLM之Teamcenter最佳学习方案

    Teamcenter培训

    用户应用基础培训,管理员基础培训,管理员高级培训,二次开发培训应有尽有,只要你感兴趣肯学习,专业多年经验大师级打造!

  • PLM之Tecnomatix制造领域培训

    Tecnomatix培训

    想了解制造领域数字化吗?想了解工厂,生产线设计吗?数字化双胞胎,工业4.0吗?我们的课程虚位以待!

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

[已解决] NX Open C++自动化装配约束求解正确但是显示不正确

  [复制链接]

2014-5-6 20:11:05 4292 2

小新 发表于 2014-4-28 11:53:40 |阅读模式

小新 楼主

2014-4-28 11:53:40

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

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

x
QQ截图20140428114628.png - j, P) G' S9 ^
这个是两个正方体进行装配。有三个约束条件,分别是三个面对齐。但是加载DLL后,RT所示,对其约束信息框中约束求解正确,没有出错。所对齐的面也和代码中设定的一致。但是实际窗口中两个面却没有对齐啊。其余两个约束也是同样状况。5 S7 M$ M; W) V" }
主要代码:, q' X2 d& Q% H+ b  L! S9 V; P
  1. //Face *face1(dynamic_cast<Face *>(component2->FindObject("PROTO#.Features|BLOCK(1)|FACE 2 {(250,0,50) BLOCK(1)}")));
    - C, R# @: W8 ?5 h
  2.         Face *face1=findface(component2,"FACE4");
    & U- x& D: M: V* W2 S
  3.     Positioning::ConstraintReference *constraintReference1;" }; e; r8 a3 |/ g/ N9 w- y+ P
  4.     constraintReference1 = componenTConstraint1->CreateConstraintReference(component2, face1, false, false, false);
    5 w, M1 l/ x/ ]
  5.     5 a0 f3 u9 }) t7 C2 P# e
  6.     Point3d helpPoint1(151.841109777454, 1.38777878078145e-014, 70.5813805572551);
    ! @* l/ f( B6 x
  7.     constraintReference1->SetHelpPoint(helpPoint1);
    - V3 {# n5 }5 ^% `& F/ S
  8.    
    / Y- \" S; \) }4 }( k
  9.     //Face *face2(dynamic_cast<Face *>(component1->FindObject("PROTO#.Features|BLOCK(1)|FACE 2 {(50,0,50) BLOCK(1)}")));  Q& {# T" c( Z& E% W
  10.         Face *face2=findface(component1,"FACE1");: z! t; g9 T) F' q; X" ?
  11.     Positioning::ConstraintReference *constraintReference2;
    % O8 ]5 c) l; g) ~& {" b2 m7 X, I
  12.     constraintReference2 = componentConstraint1->CreateConstraintReference(component1, face2, false, false, false);
复制代码
上面被注释的两行是通过JA录制产生的。我没用用的自己写的findface函数,代码如下:( E7 ^; [7 U# S2 V4 f, b4 V
  1. Face * findface(Assemblies::Component *component,const char *c)6 U! o0 i, s- {. p8 e: k: _' [
  2. {! z+ p) L# z& U' w2 l( Y5 o& E' |
  3.         Part * component_part=(dynamic_cast<Part *>(component->Prototype()));5 m# s4 K% e) U
  4.         BodyCollection *bc=component_part->Bodies();
    1 l6 ]* H1 Q2 j) k
  5.         Face *face;
    3 S& c5 K/ V( M1 O6 H" J
  6.                 9 p% b" B' a4 M7 `. p, [% v( t: z
  7.         for(BodyCollection::iterator it = bc->begin();it!=bc->end();it++)
    : q" f3 y! C: t0 x
  8.         {8 ~- g0 Z. t4 j3 w2 X. j
  9.                 Body *body = (*it);6 B2 f" e" Z7 t# H! ?' G/ S, M, F
  10.                 std::vector<Face*> faces = body->GetFaces();0 y, E9 A" l( o9 D- x
  11.                 unsigned int k=faces.size();( s) g* \3 d* B3 a* D3 ~
  12.                 for(unsigned int j=0;j<faces.size();j++): W( S5 c9 k7 a4 j
  13.                 {
    ( K6 S+ y4 z& e  C
  14.                         const char *c1=faces[j]->Name().GetText();       
    . K* i  a- w: `6 `) d
  15.                         if (!strcmp(c,c1))# ~9 E8 s' }+ D" D7 I
  16.                                 {/ [( L: r' G9 C6 i$ R1 ^
  17.                                         face=faces[j];
    " q" }+ U! U# X5 H- r7 Q
  18.                                         return(face);5 C3 R$ w  w. o( @) i9 c
  19.                                 }
    3 [3 E* T* o2 f+ p7 g# }
  20.                 }
    ! K2 D* n. Q0 E: n* Q' e
  21.         }
    ) `: N$ `9 v, Z+ n0 I
  22.        
    0 h; x7 E2 I9 e% W  V, K
  23. }
复制代码

5 \3 F' Z) i) E$ ]( _. r5 I$ }* t9 E& }- M
- w0 G0 k; J) w+ K" N. u9 j: W
5 S) ^0 n' s" B5 Z
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复2

admin 发表于 2014-4-28 12:51:25

admin 沙发

2014-4-28 12:51:25

你找到的面是 部件原型的面
$ I; F# j) h+ X) k! P7 v, n  n. d. R/ n5 W
装配里面需要的面是 occurrence实例对象的面 , 所以结算结果不对
. \/ A3 i3 O7 j; I
- P) ?! X2 a) H+ o这个地方使用 ufun的  ' R9 q5 \9 b* O8 G) m8 h% k

9 e( P4 N% G: f) ?0 x/ Y1 C: rUF_OBJ_cycle_by_name    去找 就可以了
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

小新 发表于 2014-5-6 20:11:05

小新 板凳

2014-5-6 20:11:05

admin 发表于 2014-4-28 12:510 K* b; K) w1 P; i8 W+ Z2 P
你找到的面是 部件原型的面
4 t6 ~" Z/ O- n. B6 q2 P: H* r; K$ n  e+ I
装配里面需要的面是 occurrence实例对象的面 , 所以结算结果不对

, e2 E3 r- T: e5 }0 z( E" U但是CreateConstraintReference()方法中第二个参数没有要求用的是occurrenc的面啊?在NX C++中好像也没有关于occurrence和instancen的相关类
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

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

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

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

    我知道了