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-国产软件践行者

[二次开发源码] 【NX二次开发源码分享】通过弦长,角度 公差创建曲线上点

[复制链接]

2015-4-28 13:17:38 3697 0

admin 发表于 2015-4-28 13:17:38 |阅读模式

admin 楼主

2015-4-28 13:17:38

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

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

x
' ~2 o" O7 J, Q! [) M6 ^9 E7 k! p
可能大家用的到,选择一条曲线,通过输入的公差,自动创建一些列的点集!
6 Q; S7 u. z9 ^4 W
5 A' v) x7 Z  C( r' T3 y8 p
% ]4 F4 y, w  v( Nvoid testSimulation::do_it()) I  s7 K4 p- d1 R8 w
{! k, l% Z9 A' I" k) M
         //TaggedObject* toolbody = select_by_mask();
# W5 [* _; i" C( G        TaggedObject* pathCurve = select_by_type();
7 m' C2 [$ j7 ^3 |/ g. L        //std::vector< NXOpen::TaggedObject * > any_objs = select_any_objects();
$ C9 N$ x+ A2 }! ]% Y' `        // get the path point 5 m" [" b# ?: ^
        double ctol = 0.0;( t8 W- D, V6 o& E1 g
    double atol = 0.0;6 d8 o  L0 S+ A. d! P# V
        double stol = 10.0;
/ h3 _: V5 A# j         double *pts;  b5 P# z3 \- a8 h2 J6 [% c
         int num =0;
9 ~! P; P; s/ [% _2 ]. y         char msg[256];$ k& `8 f/ |$ _" h
         int error =0;
8 M4 k1 o$ W- p  x0 T+ _         double (*points)[3];
1 j! s0 z* I1 T5 _0 t         tag_t pointTag;
! d* K* |; m4 P: {       
4 ]1 G; O3 x  ]7 u* J% {+ o" Y% M+ u
        UF_initialize();
0 `9 n; a! F& m: \" B( u
. x0 g4 d! [; L1 |9 O3 z. A) o        UF_MODL_ask_curve_points(pathCurve->Tag(),ctol,atol,stol,&num,&pts);
. x7 O5 O7 W  x3 ^& a/ y4 g        sprintf(msg,"the number of points:%d",num);) \8 N1 u0 P9 \; A0 D% F
        print(msg);
0 \* N' \0 O3 ~1 Q: {8 c7 f8 e, A! W6 ^! E. _
        points = (double(*)[3])(UF_allocate_memory(num*sizeof(double[3]),&error));
1 s) i' d+ T' Q3 d! }
% l' E' j) ?: @9 E+ {+ m6 I( H        for(int i =0 ; i < 3*num;++i)
7 U7 t4 U! B) G. a8 W- O        {9 n2 }& f7 m2 d4 e3 W7 I
                sprintf(msg,"The points are: %f\n",pts[i]);
# P* w# L3 u/ R; l, S! F5 n6 a( U) @                print(msg);6 a& \3 u0 w+ K/ K& v
                0 V, D8 z& Y' @8 i5 n
        }1 h* p  @! j" h. Z
        for (int j = 0; j < num; j++)
5 a. d/ x7 o1 q- {& e% s  U% I        {2 l  u0 k9 B+ p* b( o7 `
                points[j][0] = pts[j*3];1 M3 V6 z$ t# e1 @
                points[j][1] = pts[j*3+1];
8 E) f8 A$ ~3 a8 |4 ]# b# S& m" ~- G1 Y                points[j][2] = pts[j*3+2];
1 @/ ]) w/ p1 g2 j7 ]' O; S8 o                UF_CURVE_create_point(points[j],&pointTag);
! |# u- E4 {; i4 M, t8 s  t        }# g) t/ P( n( z1 G. b/ n- W
6 }& U6 ~5 p5 z; M
        UF_free(points);3 k8 p6 U' g$ ?3 p3 p
        UF_free(pts);) z+ W+ d( [+ ^2 k
        UF_terminate();
& H0 d3 j3 C/ M: F' U) P" v9 p  P+ y5 j: w% z3 b. E
        // TODO: add your code here6 J! \# v% {+ {& A4 l; d. E
        0 R# d$ e% O2 n$ b! O
}: q' ?9 O1 w& y8 @( P
8 |) R; z  V1 O# W0 u5 V8 C( H5 v
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了