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 3693 0

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

admin 楼主

2015-4-28 13:17:38

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

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

x

4 y1 f/ f" Q/ A6 ?, k/ p 可能大家用的到,选择一条曲线,通过输入的公差,自动创建一些列的点集!4 r5 _1 l; K+ W1 s( S& x7 {! {
$ y) A4 D5 S' S3 J2 A

- ~) x6 c# x' f  ?$ xvoid testSimulation::do_it()
' Z2 Y/ V" |/ o, V8 _{
2 D$ l. v7 o) N- [         //TaggedObject* toolbody = select_by_mask();
1 x& }  `* a0 a- u( s' U        TaggedObject* pathCurve = select_by_type();( @3 h0 C8 f6 Q2 h& `8 I2 T. S
        //std::vector< NXOpen::TaggedObject * > any_objs = select_any_objects();/ Q9 J" Z( q, u& D; C( s
        // get the path point ) F+ y$ S8 G) l' I/ v0 V
        double ctol = 0.0;
! c' t9 ~9 J6 |8 T! F- H    double atol = 0.0;
0 g1 k( h+ b$ B; A2 l0 z        double stol = 10.0;
5 y5 c8 G8 z3 {6 H0 m         double *pts;4 h  j! z- o8 p' L- s; W0 I2 B2 ^! u+ N
         int num =0;
( M- O5 b" J+ ~5 d8 W         char msg[256];5 A  x& l" u9 f( f  v7 g6 U
         int error =0;- g6 J2 w1 h4 L/ ?* k  \. R- }
         double (*points)[3];6 F. y% x; R% ?: T0 W0 L' w
         tag_t pointTag;
# s+ X9 k; d/ d! g1 m; A" Z7 d4 ^       
8 i5 N5 ?1 t% o+ B
( N$ p4 O* q, m0 |3 p        UF_initialize();
% L1 H% G% O3 n0 C$ B
8 r/ J$ V0 ]& N7 P$ w5 E% f; ]+ Q& e        UF_MODL_ask_curve_points(pathCurve->Tag(),ctol,atol,stol,&num,&pts);
: c% V0 r! \" c, K  j  H" q* N        sprintf(msg,"the number of points:%d",num);3 }$ m' ^8 ~) R1 w& l/ R2 g
        print(msg);
/ W* l  `) V5 Q  s3 T8 a- {4 `9 U3 N+ W* q. A6 S
        points = (double(*)[3])(UF_allocate_memory(num*sizeof(double[3]),&error));6 ^3 X1 S6 @, C; P+ W2 v+ S% S, ^
6 {# s; s( z, ~' z6 U5 w" b  }
        for(int i =0 ; i < 3*num;++i)
* U$ |0 R3 _( |        {; c4 g. M# ^+ ?3 |2 U- v
                sprintf(msg,"The points are: %f\n",pts[i]);+ D9 I) E; [, Q6 C" S6 a& p
                print(msg);
3 T. B$ J% i# Q. a  ]' ~; r4 G               
  s9 `  g6 p6 @# M  ]. m        }
. K. D7 `6 e- x' N7 X$ d        for (int j = 0; j < num; j++)- s/ z& i' V- \, l, {- z* k) Y
        {
& E: @) N+ U, u                points[j][0] = pts[j*3];
) V% J$ \- `9 b1 l2 f9 u" V9 Y                points[j][1] = pts[j*3+1];
  B, U  ~$ q$ F  p  e                points[j][2] = pts[j*3+2];
& W) R. X1 V/ w6 y                UF_CURVE_create_point(points[j],&pointTag);8 P2 `0 R. c6 i& e* r" M
        }
% H0 M( K4 ^! X6 {& |8 a+ f6 ~/ j* a5 J- X* N! p9 T
        UF_free(points);
6 b& D7 ]0 t2 W) h        UF_free(pts);. d- u5 a" ]6 e! ~3 t* l
        UF_terminate();7 x; E8 b% n, j" j+ ^7 ~
; S& U9 E% y1 H
        // TODO: add your code here4 \) r' V4 R$ d$ l' S2 Q/ W
       
& J5 H: N- P- T5 A! L2 O8 Q* j# F}2 d9 K: ^! d. y; n2 Z

) W2 e  K. b2 j7 r$ ^- w: @
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了