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

[交作业] lesson3_CreateBlock

[复制链接]

2015-4-22 11:09:58 3140 1

文星和合 发表于 2015-4-21 21:23:10 |阅读模式

文星和合 楼主

2015-4-21 21:23:10

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

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

x
/* Include files */) Q' X! r9 G& r4 {
#include <stdio.h>
$ s/ `! ?; _; J, T#include <uf.h>
; M5 z) @) _7 I$ Q#include <uf_ui.h>! E) t1 S" k+ \5 [" B, E
#include <uf_part.h>
) C8 k/ k0 b& e1 I#include <uf_modl.h>. ?0 R# g% }# I# S( E
#include <uf_obj.h>
8 E5 G6 ^7 [3 Z3 F$ N4 S#include <uf_disp.h>7 n9 y2 d- S5 A* K# H% x& Q
#define UF_CALL(X) (report_error( __FILE__, __LINE__, #X, (X)))
# F4 m: s# m1 N/ ?- }' s& B* ostatic int report_error( char *file, int line, char *call, int irc)
* d* ^- x4 r* j, @) L) O{
. s, Q- f9 I% i+ s  d& W    if (irc)! o" ?& Z% v# e: @% y
    {
: p: w4 O3 r8 E4 A) Z        char err[133],
  n  l" {+ K" c( ~% E% ^  z             msg[133];
: A+ h" ?7 q" }; {7 E+ M) F        sprintf(msg, "*** ERROR code %d at line %d in %s:\n+++ ",: T$ B, y4 d2 B
            irc, line, file);
8 w' ?' G& p& ~2 Q        UF_get_fail_message(irc, err);
$ N# T0 H: V. h5 f9 o% }/ ^* M        UF_print_syslog(msg, FALSE);
) j4 `% H1 x$ ^2 x! Q. e2 w) B        UF_print_syslog(err, FALSE);
! y' c! ^$ N) t% d        UF_print_syslog("\n", FALSE);
6 g6 w, {5 p0 D# \& h+ i        UF_print_syslog(call, FALSE);6 _( ?" K5 x, Y; J) J: }
        UF_print_syslog(";\n", FALSE);
1 k/ H6 h. a3 Y6 N* i        if (!UF_UI_open_listing_window())9 F6 U8 p" R: e: V# K
        {
* |% _' G8 y% v2 k            UF_UI_write_listing_window(msg);' F# f7 I2 \$ @1 E
            UF_UI_write_listing_window(err);
, C( l; n6 j- G            UF_UI_write_listing_window("\n");
& [. k7 o" W6 b9 f- v0 |            UF_UI_write_listing_window(call);
% z" k) y$ _& }2 o1 Z" E; D9 z            UF_UI_write_listing_window(";\n");/ P3 E( T0 D# V- L0 M5 Y
        }0 ?3 z4 ~; M: c2 J# A
    }
4 z0 x( e' z3 i! l& _    return(irc);
2 ~% u' L, Y! y9 j}/ q) r7 Q! z+ ^5 N  U; G  N1 F

- L' a# {% k* P. O# X$ N& w0 Q/*****************************************************************************  S/ A3 U5 S, [6 u% Y' L# p; S: K
**  Activation Methods# h2 N' v7 {8 m
*****************************************************************************/
) Y) f2 M& X7 \6 I3 B/*  Explicit Activation4 [$ X9 ]0 X! t- X; P
**      This entry point is used to activate the application explicitly, as in9 A- b3 d6 S2 q' W) D' P- A0 [
**      "File->Execute UG/Open->User Function..." */
4 z) _& M# N! X- L( S; Lextern DllExport void ufusr( char *parm, int *returnCode, int rlen )" y3 q' x  \' [& p
{6 o6 [6 C/ I0 O* N1 z
    /* Initialize the API environment */7 M, _; k5 f1 x: s# l- h. g& A
tag_t partTag = NULL_TAG;9 @" u6 x# T( o( }, e* v/ ~
double coner[3] = {0,0,0};/ E2 [. q4 W0 s6 m1 z+ |( E6 E
char *edges[3] = {"length=100","width=40","height=50"};
: ]5 `* O3 {' V+ L# s) u: C tag_t blockTag = NULL_TAG;
: ^, G; _0 S2 G( | const char * radius ="10";
, q6 E! G* B1 [; C6 y8 I1 e4 R int smooth_overflow = 0; 4 \6 @( M; I0 i+ X6 M
int cliff_overflow = 0;
+ Y9 X3 C8 b/ D7 L' V+ o int noTCh_overflow = 0;9 s# d4 j0 Z9 h$ `5 G
double vrb_tool = 0.01;2 R- W& w8 M* b) o! s
tag_t blendfeatureTag =NULL_TAG;
% m: a4 A9 B) H7 m: H- f uf_list_p_t vertical_edges_list;( V  P" W; I1 I9 J' U; j/ h
uf_list_p_t edgeslist;
- E3 K5 }% Y: t/ i5 @ tag_t blockbodyTag;' `) \* r5 ^, z! w% ]
double firstpoint[3],endpoint[3];
3 l2 N; C" c2 z+ u3 D4 ?' a6 L3 Q int vertixCount;
8 b. i2 q" y$ m, ^  t tag_t edge;
9 H* F& c$ a6 i int edgesCount;) l" `% D% v, v* w  \0 ^
int i;
/ D. S! p# R2 j$ d$ I char mymsg[256];) u- E5 b( [* o; U$ b
int vertical_edges_Count;( J) a( I- @( z3 ]% U
UF_ATTR_value_t myattrvalue;
0 s; s; A4 h' O; A& T" I. Y7 x2 g0 @7 Z6 u
    if( UF_CALL(UF_initialize()) )
* C" |! W# ^8 |9 q' t2 v) b0 q    {
9 G8 U: A5 b( Y* |# B: b        /* Failed to initialize */
, ^' v" `% ~- K2 w( s$ w) H4 n2 E        return;
! |$ ]7 e+ a$ E4 `+ }, S' }# t    }) J& M% d, v" @: C7 H6 e
    6 ~# \+ ?( `+ g, z: b
    /* TODO: Add your application code here */: D) R, Z2 I4 o% X# S) [
UF_UI_open_listing_window();
  ~* }" Q* Z; ]$ R* T2 t% s9 M //new part+ C- z2 v' G0 y; e
UF_CALL(UF_PART_new("E:\\NX\\lesson3.prt",1,&partTag));
, z" W- D2 T& ], | //new block
, D3 o; [+ p2 I UF_CALL(UF_MODL_create_block1(UF_NULLSIGN,coner,edges,&blockTag));//得到block特征的tag:blockTag6 g0 E" z$ @- O0 r: {
//create vertical list
" O7 a& X# R( K# E  e) \ UF_MODL_create_list(&vertical_edges_list);//create list
4 w3 D: x$ F- v5 b/ u //feature -> body -> edge -> vertical edge- _) J' O) }8 ^$ r1 s9 s; h/ Z
// 1 feature -> body
2 q! z4 R! Q$ `7 P UF_MODL_ask_feat_body(blockTag,&blockbodyTag);! x% k, F! [% @9 s
//2 body -> edge
( ~, V$ b  e6 ~! B9 w9 U4 O UF_MODL_ask_body_edges(blockbodyTag,&edgeslist);. x8 V( O9 I' B
//UF_MODL_ask_feat_edges(blockTag,&edgeslist);//feature->edge是可以的
8 z! }$ [1 z! ]# Q UF_MODL_ask_list_count(edgeslist,&edgesCount);* e8 s- {) K" U" [& i4 i6 C" j
sprintf(mymsg,"edge count:%d\n",edgesCount);5 z0 i7 f) m/ y1 w* w- d) O6 ?
UF_UI_write_listing_window(mymsg);
% r0 v/ [; Q3 f2 {; _6 \# u //edge -> vertical edge
( _5 `( F: d. O  @& Z+ Z for (i = 0; i < edgesCount; i++)
" S6 [( Z$ T) w. u; P4 } {$ c8 v9 g1 v/ O& O; v
  UF_MODL_ask_list_item(edgeslist,i,&edge);9 D% R$ G% p8 b& P
  UF_MODL_ask_edge_verts(edge,firstpoint,endpoint,&vertixCount);4 n; D/ W3 F$ d9 C+ T4 P9 _4 W
  if ((firstpoint[0]==endpoint[0])&&(firstpoint[1]==endpoint[1])&&(firstpoint[2]!=endpoint[2]))/ F. Q  e. w- H, |' T: a6 E
  {
+ q" K6 V9 U1 L   UF_MODL_put_list_item(vertical_edges_list,edge);, R- d) }' _+ ^, n: Z# r( v
   //add arrtibute
. c( p! e5 R8 |' k& q   myattrvalue.type = UF_ATTR_real;
) C' G8 T' X( ?: K   myattrvalue.value.real = 10;0 C( ?, l! a: J. |3 R
   UF_ATTR_assign(edge,"blendradius",myattrvalue);
0 M6 z. i1 a3 h& K/ x/ _- a* k  }
4 O% m9 B$ m% j1 @7 `' q/ Q }
, ]! g, m; \5 j$ v( d% `5 ^. } UF_MODL_ask_list_count(vertical_edges_list,&vertical_edges_Count);
6 N$ ~% l, |" D2 e+ _9 ?% u% `) G sprintf(mymsg,"vertical_edges_Count:%d\n",vertical_edges_Count);6 j7 f8 F9 z* u! a
UF_UI_write_listing_window(mymsg);
0 E  n2 A  R- f/ k
% B7 D- ?* p1 [- O //create blend(倒圆角)/ U" F5 y( ~* J4 m  E) _
UF_CALL(UF_MODL_create_blend(radius,vertical_edges_list,smooth_overflow,cliff_overflow,notch_overflow,vrb_tool,&blendfeatureTag));
: I3 g6 m( a5 b( j: A UF_MODL_delete_list(&vertical_edges_list);
' I* k( G9 f. _' D; u2 n1 W* m //change body color、translucency
* p% i( E" u1 p  Q6 ?$ I UF_OBJ_set_color(blockbodyTag,21);//186红;21白: S" R1 S+ Z! N
UF_OBJ_set_translucency(blockbodyTag,50);7 [! n; @1 i  ~) y3 u; o0 n
    /* Terminate the API environment */& N: y/ t+ O3 t* c
    UF_CALL(UF_terminate());' d" T  V5 g5 F8 L
}1 x3 h* _& L5 Q, B- n7 A
/*****************************************************************************
# G! a' D: k' M  z4 z" b4 l( X**  Utilities7 N9 x! r, H8 c- [
*****************************************************************************/
9 M9 b) z, N5 H/* Unload Handler. `) L9 H* {6 I0 Q
**     This function specifies when to unload your application from Unigraphics.' a6 N* `! Y, x: d1 K( Q
**     If your application registers a callback (from a MenuScript item or a! p& L5 i) M" H
**     User Defined Object for example), this function MUST return
) s4 ?0 J+ P% M8 ]**     "UF_UNLOAD_UG_TERMINATE". */
2 c) v9 Z# k: ^2 c& m! l- i3 |extern int ufusr_ask_unload( void )
" {  i3 [; S) R2 \# j! {! {{
  g& x) b6 h" b3 Z( C. j* C$ }3 R    return( UF_UNLOAD_IMMEDIATELY );* A: t" Z# f2 t$ u) `% x
}
( h$ U) S- [, n& q( e9 w! X, x/ F" [& z& _5 M$ b- E' ~% i: ~- b
无标题.png

评分

参与人数 1PLM币 +5 收起 理由
admin + 5

查看全部评分

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

使用道具 举报

全部回复1

admin 发表于 2015-4-22 11:09:58

admin 沙发

2015-4-22 11:09:58

你做的很好!
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了