PLM之家精品课程培训

PLM之家精品课程培训

联系电话:18301858168   |   QQ咨询:939801026
NX二次开发培训

NX二次开发培训

UFUN/NXOpen C++和实战案例

适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术。
公众号二维码

关注公众号

点击扫描二维码免费在线高清教程

课程详情
Catia二次开发培训

Catia二次开发培训

市场需求大,掌握核心技术前景广阔

Catia二次开发的市场需求大,人才稀缺。掌握开发技能潜力巨大,随着经验积累将在汽车、航空等领域有所作为。
B站二维码

在线原创B站视频

点击关注工业软件传道士主页

课程详情
Teamcenter培训

Teamcenter培训

全方位培训,从基础应用到高级开发全覆盖

涵盖用户应用基础培训、管理员基础培训、管理员高级培训及二次开发培训等全方位内容,由多年经验讲师打造。
QQ群二维码

加入同行交流

点击扫描二维码加入QQ群

课程详情
×

PLM之家plmhome公众号

课程涵盖: PLM之家所有原创视频

×

关注B站视频

所有高清视频一览无余,全部在线播放学习

×

加入PLM之家QQ群

同行交流,疑问解答,更多互助

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

[二次开发源码] UG NX二次开发源码分享: NX Open C++ 创建投影曲线 project curves

  [复制链接]

2019-4-25 18:47:55 9015 3

PLM之家NX 发表于 2014-5-5 22:45:05 |阅读模式

PLM之家NX 楼主

2014-5-5 22:45:05

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

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

x
, J  ~3 m# w! d3 f* i6 f! b9 `  s
$ [8 Z* v2 I' J* [  g

* S5 ]8 \2 y' G* n' k3 D) x6 f3 _UG NX二次开发源码分享: NX Open C++ 创建投影曲线 project curves
$ {" t: I9 i1 f1 J0 M, d
' A, V: M+ @/ o+ B此处使用的是 通过面的法向创建投影曲线,可以参考下!
/ P9 A" K9 V( u+ ?: N1 S- ~  c0 W! a2 w: G3 l( l4 f$ V" y
. P6 M$ [" e' h$ z
: g$ A! ]9 C) p1 p8 J% b4 M2 r
. g3 o: v4 e4 |4 e

8 s7 s8 N6 y, J8 L- D
1 F) h: o% f4 o+ T4 ~! k& C7 w4 m6 Z9 W  b

NX Open C++ 创建投影曲线 project curves

 NX Open C++ 创建投影曲线 project curves

# m5 g- i% Y. K8 v1 G
+ r: ~$ @1 V; [7 v3 C/ H1 G5 N2 n+ `! B  ?5 d' n. t* G1 i  A
  1. ; |+ X3 i# U( Y0 V9 Q7 c, G3 m
  2. int trimSteels::project_curves(vector<TaggedObject *>inputObjects,Plane *plane1)
    ; T- ]; W6 U$ |9 k( p. e
  3. {
    , x" R" r6 a" l' H( w/ s
  4.         int errorCode = 0;
    / m# e6 M* C/ o* B* s9 s* y, B; D! B
  5.         try+ j* S! W) F3 N- p8 }5 _; ?
  6.         {
    4 F  H0 {1 L# y. _
  7.                 // createProject curves
    ) W! @# @. q% r' a* f

  8. : E% A; D' M  ^
  9.                 Features::Feature *nullFeatures_Feature(NULL);0 `8 _2 ]7 K# [
  10. 3 V$ X! M' W6 t! r
  11.                 Features::ProjecTCurveBuilder *projectCurveBuilder1;+ ^0 J/ t0 r0 T) B
  12. 5 U5 ^" L2 L% C4 x
  13.                 projectCurveBuilder1 = workPart->Features()->CreateProjectCurveBuilder(nullFeatures_Feature);
      x+ k( K0 I" W* r9 _. J

  14. * @# b. C" a8 O+ S, X5 O8 c% o( p+ m' y
  15.                 projectCurveBuilder1->SectionToProject()->SetDistanceTolerance(DISTANCETOLERANCE);6 ~, Z. d) J; G, i5 e& ^: l3 Y

  16. ' T; a+ x& u' K8 h4 j* o8 U" B
  17.                 projectCurveBuilder1->SectionToProject()->SetChainingTolerance(CHAININGTOLERANCE);
    6 a- _8 i0 P, O, e$ J6 `
  18. $ \- a) }; W2 s3 h# S- O
  19.                 projectCurveBuilder1->SectionToProject()->SetAngleTolerance(ANGLETOLERANCE);
    $ p$ p6 R. f! I- [6 D7 ?  [$ R
  20. , g' ^: H: D( A0 Q8 j1 M4 }
  21.                 projectCurveBuilder1->SectionToProject()->SetAllowedEntityTypes(Section::AllowTypesOnlyCurves);
    ( e# g5 o. x1 r' ^' m: t0 A8 j' w

  22. ; P; d$ H7 F: n2 v
  23.                 projectCurveBuilder1->CurveFitData()->SetTolerance(DISTANCETOLERANCE);
    & U6 i1 X* k5 u9 X

  24.   l5 e: Q# b3 {; H4 A, K' N4 V/ A  V
  25.                 projectCurveBuilder1->CurveFitData()->SetAngleTolerance(ANGLETOLERANCE);9 ^6 F2 x$ \+ S
  26. , q( z3 P/ M1 s& r4 p0 I
  27.                 int size = (int)inputObjects.size();4 f8 u/ f* ?: V6 e, L( j5 k6 c
  28.                 std::vector<IBaseCurve *> curves1;
    4 u! q4 s5 R( e. y' }
  29.                 for (int ii = 0 ; ii < size; ++ii)0 V* g2 C  D' a. ~  B' t. u
  30.                 {9 p6 y. `& O+ M, G" V
  31.                         curves1.push_back(dynamic_cast<IBaseCurve*>(inputObjects[ii]));
    - y1 t9 H" w; i$ M7 z) M/ p
  32.                 }$ P2 y. q, x) R+ @7 s

  33. : E8 w9 V; \0 n
  34.                 NXOpen::CurveDumbRule *curveDumbRule1;
    4 R( s2 f# b: B6 A' w. |* J

  35. , L* R/ u' K+ t4 {+ v8 s# y: B
  36.                 curveDumbRule1 = workPart->ScRuleFactory()->CreateRuleBaseCurveDumb(curves1);1 q, g: K- E+ {" K4 w
  37. / u1 {. d. Y  z! f5 T8 b
  38.                 projectCurveBuilder1->SectionToProject()->AllowSelfIntersection(true);) X( O) @7 F8 \' o8 c  E' d4 Z
  39. 3 Z8 Z1 H6 G& ~( y
  40.                 std::vector<SelectionIntentRule *> rules1(1);$ y1 }$ d7 B5 K1 C, {, e: a. Z
  41.                 rules1[0] = curveDumbRule1;9 `, u4 w% u5 K# N
  42.                 NXObject *nullNXObject(NULL);
    , [$ ^3 _: t  h2 ?) R0 n
  43.                 Point3d helpPoint1(0, 0, 0);& [4 f+ n$ h7 i
  44.                 projectCurveBuilder1->SectionToProject()->AddToSection(rules1, nullNXObject, nullNXObject, nullNXObject, helpPoint1, Section::ModeCreate, false);. i' C3 H: A* o$ ]$ p  h; L& M
  45. 7 P# {+ H6 x0 x1 ]- _
  46.                 plane1->Evaluate();3 _: Z9 Q. c9 F) Q
  47. & v. ^; L6 \* V- N6 G% x; H
  48.                 projectCurveBuilder1->SetPlaneToProjectTo(plane1);1 F6 c# L) p: I5 q0 C& O

  49. / f6 V& g+ q. B
  50.                 projectCurveBuilder1->SetGapOption(true);8 O8 m( g" m  A4 ], _

  51. 0 Z  f% s& j0 ]7 d1 g2 m5 Z! }
  52.                 projectCurveBuilder1->CurveFitData()->SetCurveJoinMethod(GeometricUtilities::CurveFitData::JoinGeneral);9 P" y* g  O/ Y4 h& e( M* `
  53. * ]. [# R. u0 K
  54.                 NXObject *nXObject1;! V/ S) m! w+ P1 V" U( l
  55.                 nXObject1 = projectCurveBuilder1->Commit();* x) x( e1 q" O; X6 b5 Z2 T

  56. * B* f) L3 R) Q! c
  57.                 projectCurveBuilder1->SectionToProject()->CleanMappingData();- R" X8 v+ N2 A$ p6 B8 y" ~$ i/ ?7 `
  58. , X6 ^. c% p3 {0 V# U1 z$ w
  59.                 projectCurveBuilder1->Destroy();7 ^3 Q$ ^: K- J8 W2 X
  60. 8 W5 S1 u% `4 q2 O* f" t+ o, y
  61.         }7 }3 }/ w2 J' E/ R
  62.         catch(exception& ex)
    4 J, S4 ^) r) ^- j2 r8 D4 R* i
  63.         {
    " g4 s  d' `- F# h( u, @2 L  M
  64.                 //---- Enter your exception handling code here -----
    / o9 U6 o8 g) [' \# g3 Y
  65.                 errorCode = 1;' f2 Y8 u4 x. d  E0 d
  66.                 trimSteels::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeError, ex.what());
    % M6 }! s* b: q3 J8 I% g1 |$ t' o# k
  67.         }* R! }: Q) }, T' ~* u, g+ p# A: M* `

  68. ) g& c$ O0 ^* B  V$ u& u% _! ^  P) s
  69.         return errorCode;
    ' `+ t- k9 b" J5 L! `' \
  70. }, S9 |0 u$ D9 \) P+ N
复制代码

" `4 j0 M: `! z' t/ p0 _6 C1 R1 q' C% Y3 C9 d3 ]) a
5 z  o+ l& a" c) Y. i  t
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复3

希水长流 发表于 2014-5-15 17:18:05

希水长流 沙发

2014-5-15 17:18:05

创建完投影之后 如何能够获取投影曲线的指针呢?
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

希水长流 发表于 2014-5-15 17:54:14

希水长流 板凳

2014-5-15 17:54:14

版主 我找到接口了
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

593232280 发表于 2019-4-25 18:47:55

593232280 地板

2019-4-25 18:47:55

学习了,高手
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了