|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
/*********************************************************/+ e) {7 L9 w* X) g+ R
#include <stdio.h>
4 B2 l$ p8 R" v7 j3 A: t#include <stdlib.h>
. Z. _7 M6 O+ I3 z#include <uf.h>) A6 }& v$ L! A
#include <uf_attr.h>
( l0 S# Z7 T( ]$ s. q4 i' o#include <uf_cfi.h>( x" }" v7 r5 |5 j E& b3 l; ]( b& [
#include <uf_curve.h>$ @8 J2 Z" E8 A. ~
#include <uf_ui.h>- a5 x) p$ Q; s& B t) z9 h. U
#include <uf_modl.h>
( P3 l9 P' z( `1 }6 K( o
5 e( s5 v+ g$ l$ x/************* unload alloc mem *************************/
6 S1 c! j& p4 `6 |& q/* UF_UNLOAD_SEL_DIALOG _UG_TERMINATE _IMMEDIATELY */' q- i' [( z5 b7 E8 Y; k3 B# h
5 V0 a# z6 B. s& b |7 V$ \extern void ufusr( char *param, int *reTCod, int param_len )
6 t k6 }8 j+ C* |9 o, Q{
" S; U. ?7 T# T1 G: U UF_initialize();% l9 T/ P4 z" E+ v& Y( w6 l
9 f) U; B. ~0 E7 P3 j8 z6 r3 R
) w6 F9 l. H9 b' J: V8 U$ M double coner[3]={0,0,0};8 S* a. k% ~* M Y/ ?% u7 S
char *edge[3] = {"10","50","20"};
4 r& [9 B. q: t tag_t blk_tag;
+ h7 q& j8 r, B- \/ J! @' A1 } UF_MODL_create_block1(UF_NULLSIGN,coner,edge,&blk_tag);, W ? r" f& q7 y& n5 V: c$ k
& J7 y% ^, X( }; y7 s9 ^0 [9 R) ]( s- `" y: G1 _! i
UF_MODL_ask_feat_body(blk_tag,&blk_tag);
1 F# a6 E! o& }! ~ uf_list_p_t end_list;3 L: o- w/ N7 Q l
UF_MODL_create_list(&end_list);
* Q9 \3 ^2 i! n- h& @4 d S UF_MODL_ask_body_edges(blk_tag,&end_list);
' h- ^9 ~5 h: i* e3 Q: g. k int num;
! `2 _) o! x4 k0 j4 N2 R UF_MODL_ask_list_count(end_list,&num);
; z" E+ m1 V( f4 W7 g6 {3 L# b( {$ t6 M- d
char *radius ="2";: ~1 D2 z% t! b0 n3 X$ q# n
int smooth_overflow = 0;$ U% v1 @/ [) U
int cliff_overflow = 0;
) h3 ~0 Q9 S* j! z+ y7 s: _ int notch_overflow = 0;
2 U& F( p' \( p, ?" P; B double vrb_tool = 0;- I9 Q- S! q) H" _
tag_t feature_obj_id ;
$ S) I5 g* x7 h1 q% K uf_list_p_t end_list2;
/ l# t* ^( T' m! Z6 g3 ? UF_MODL_create_list(&end_list2);
! v* A, ~ l8 D# ? for (int i = 0; i < num ; i++)
- s) l8 ]4 j9 j s. p" Y1 U* I# A3 r {6 u1 Y- P* H/ m: E# S1 G# Q
tag_t tt,curve1;) Q6 H" z5 c2 {2 w+ |; A
UF_MODL_ask_list_item(end_list,i,&tt);% @+ n% E g: s( ]* A
UF_MODL_create_curve_from_edge(tt,&curve1); //抽取曲线
( M c7 F/ c7 S/ m7 U: l double point1 [ 3 ] ;
: H' L: N3 A( y; } double point2 [ 3 ] ;
% L/ a2 h/ b, J8 R, m# x& s, | int vertex_count;
9 p! }4 x _+ w0 ~0 D UF_MODL_ask_edge_verts(tt,point1,point2,&vertex_count);. ^. c: y, S2 Z9 ]% x/ M- A
if ((point1[0]==point2[0])&(point1[1]==point2[1]))% M: Z k1 w, u3 @
{
4 {! \) Z, `5 q! k; z UF_MODL_put_list_item(end_list2,tt);
1 [. V' Z, M& N; P: J6 [, n }
# H3 [, x V( W! ~8 a }- r* D# a! C- [! Z
UF_MODL_create_blend(radius,end_list2,smooth_overflow,cliff_overflow,notch_overflow,vrb_tool,&feature_obj_id);
0 U/ k+ w; |( `$ q% f* S UF_MODL_delete_list(&end_list);
9 I: h- d7 R" h" P5 m0 M8 g; \
, H6 N/ u% _, n. b* Z UF_terminate();
- p- Y6 k& q! q$ d1 v* E& j return;4 p# {' T) n6 v( A
}1 Q& u& o' v+ w" ~% B/ J2 G
) i/ l' q0 L' N I8 ~extern int ufusr_ask_unload()/ y9 f& _6 L, F/ A* v
{
5 |* j/ n3 f1 y* i& S' ~& W1 Z return UF_UNLOAD_IMMEDIATELY;
|) n1 s! A+ F+ M) H- ~( V6 ^% k}
, ]1 L$ s6 T2 a4 M4 w
0 k4 U2 P/ O/ A; l+ [/ T |
-
评分
-
查看全部评分
|