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

[二次开发源码] NX二次开发-关于body,feature,face,edge 之间的访问源码分享

[复制链接]

2013-11-27 14:02:41 4460 0

admin 发表于 2013-11-27 14:02:41 |阅读模式

admin 楼主

2013-11-27 14:02:41

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

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

x
0 P6 Z; L4 @# W! c- N9 E* d
NX二次开发-关于body,feature,face,edge 之间的访问源码分享! ?4 r+ K; d2 O2 q

; R' M" v. m+ C* f8 b也有创建孔,创建阵列的测试哦!
. j- X. U0 K  J/ X- b! f) ?" F/ ?0 f7 i7 Y2 w
  1. 1 Q) }2 G! }1 L* n: f8 T; c' o
  2. <p>static void do_UGopenApi(void)* S# G: I4 @( a! h
  3. {: M( }# Z8 |0 _% i( \
  4. //create a block
    9 x: Q( j, J$ ]! i% J0 ?4 J  m
  5. double coner[3]={0,0,0};
      L# ~( W: _8 [$ d8 F
  6. char *edge[3] = {"100","60","40"};" w6 h8 t, Y8 X" _7 U- {
  7. tag_t blk_tag;
    ( M0 n6 g) U' H9 j0 o/ q( b. [" B  c  g
  8. UF_MODL_create_block1(UF_NULLSIGN,coner,edge,&blk_tag);
    7 m; b0 a/ r3 l- M
  9. //create a blend start( a: f& Y! S% [  a6 T0 [( F
  10.     char *radius = "20";
    , {4 p& I; u$ Z& B
  11. uf_list_p_t blend_list,face_list,edge_list;- x6 q% m2 c, S' f: O' V
  12. tag_t body_tag,tem_face,tem_edge,faces[6],edges[12],blend_feature;+ ~: z8 p7 l3 l7 t& {# o( ?8 l7 {7 A
  13. int face_count,edge_count;
    ' ]% L1 j+ g% u' s, {+ @: D! ?
  14. // get faces
    * e! x+ b! r+ B# A
  15. UF_MODL_create_list(&face_list);# z2 n/ y2 I  q- B+ J" \
  16. UF_MODL_ask_feat_body(blk_tag,&body_tag);
    / w5 f! j' V0 Q" E& F8 V
  17. UF_MODL_ask_body_faces(body_tag,&face_list);) ^$ H0 ^3 z+ n; m/ c. \
  18. UF_MODL_ask_list_count(face_list,&face_count);
    9 s' Q4 u3 N. k5 B( W; p  b
  19. for(int i =0 ;i <face_count;i++)
    % y  }8 N$ P5 b! |1 u
  20. {  * j! n* r3 f" U
  21.   UF_MODL_ask_list_item(face_list,i,&tem_face);8 [3 c& h- D1 A3 U9 w) t" W4 F. `
  22.   faces[i]=tem_face;
    - P" @; Q8 `- P8 v2 o
  23. }
    7 M7 }6 N( s* {# k3 |5 e8 c8 w
  24. UF_MODL_delete_list(&face_list);1 D- m  P5 }2 t% s6 G
  25. //get edges
    ; Y5 N9 z, _# ]+ z+ ?- W2 \& H
  26. UF_MODL_create_list(&edge_list);
    6 @+ _& q3 j+ A# j
  27. UF_MODL_ask_body_edges(body_tag,&edge_list);
    & h0 w0 z8 `- p7 }, J6 i4 C, E
  28. UF_MODL_ask_list_count(edge_list,&edge_count);2 C" Q* H( M' k, L: B+ K
  29. for(int j = 0 ; j < edge_count;j++)
    . y8 d9 ?& i; R$ M. ~  j
  30. {' G/ q# L- {8 ]& {$ a' H, A6 A/ p0 @* k
  31.   UF_MODL_ask_list_item(edge_list,j,&tem_edge);
    * i9 }" H4 \$ X/ f% g* h/ P( p8 }4 p
  32.   edges[j]=tem_edge;
    $ W; m( ^7 R# }# N
  33. }
    ' A3 k9 G$ \6 k' x; w
  34. UF_MODL_delete_list(&edge_list);" y& v8 W9 K8 k: _/ |6 D
  35. // create the blend+ |6 E+ J8 P$ q
  36. UF_MODL_create_list(&blend_list);
    $ q2 G" [3 T8 E# J/ [
  37. UF_MODL_put_list_item(blend_list,edges[6]);4 p: _. R9 r+ ]' P
  38. UF_MODL_create_blend(radius,blend_list,0,0,0,0.5,&blend_feature);( n. S7 j) ^) x
  39. UF_MODL_delete_list(&blend_list);</p><p> // create hole* \$ ~1 q% N8 A( a  u
  40. double  location[3]={80,40,40};
    " j+ B6 q! u: U
  41. double  direction[3]={0,0,-1};: d. ~4 F! M) j" m% x
  42.     const char * diame="15";5 S' X1 P  _  p6 S7 H9 V
  43. const char * depth="5";% j$ U' I+ E; R6 N2 C, ]
  44. const char * angle="0";% `( i% c; _( `
  45. tag_t hole_id; / Z5 E* {0 o) }4 k
  46. UF_MODL_create_simple_hole(location,direction,diame,depth,angle,faces[0],faces[1],&hole_id);</p><p> // create instance
    ( ]& B" a9 Z& U
  47. double origin[3]={10,10,0};
    5 K. R2 g3 X1 U# i4 W
  48. double dir[3]={0,0,1};9 Q0 d+ Y1 }' X7 l, z. K- l
  49. tag_t cyl_tag;" \6 {# h; }. v/ Z) t& e
  50. UF_MODL_create_cyl1(UF_NEGATIVE,origin,"20","10",dir,&cyl_tag);      
    ; D+ C3 s6 L9 Q  k" `' V" a) c
  51. char * number_in_x="2";2 _  e+ H0 m* w
  52. char * distance_x ="30";
    # ~& e! `% X: E1 O/ l
  53. char * number_in_y="2";
    # R& o  o/ B+ u; ?! u$ h
  54. char * distance_y ="30";  F+ q8 w7 \" `6 }2 d
  55. tag_t  feature_obj_id;
    1 |1 `. ~' m! B- X8 ]
  56. uf_list_p_t feature_list;' ~$ _+ x  O! ^$ U/ R* [5 k
  57. UF_MODL_create_list(&feature_list);, ]0 H/ R' P" X7 _
  58. UF_MODL_put_list_item(feature_list,cyl_tag);" F2 q' G7 ?" e% i8 P- g
  59. UF_MODL_create_linear_iset(0,number_in_x,distance_x,number_in_y,distance_y,feature_list,&feature_obj_id);
    $ ~0 w+ ^4 `6 j3 M
  60. UF_MODL_delete_list(&feature_list);
    : h/ F4 ~4 G/ G' |1 D% r. Y% R; g" a
  61. }</p>
复制代码
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了