|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
tag_t partTag = NULL_TAG;* T O9 B" }& n4 M w" k
double origin[3] = {0,0,0};, r4 b8 [9 H ]. e3 X+ p
char *height = "50";
: u! h; z3 {% n8 Dchar *diam = "10";
6 V6 `" f$ m/ e1 R3 O# ]double direction[3] = {0,0,1};
6 T3 W* i6 h9 S5 C$ }& Ptag_t cylTag = NULL_TAG;
, _$ h9 R6 J$ suf_list_p_t eageList = NULL_TAG;' U# A& Y, F3 e
int count = 0;
& c6 l0 G0 y- @' Wchar msg[256];" K' n/ ~2 X: X# p+ v! m5 f
int i;
9 {* T1 Y* }" f1 W- btag_t eageTag = NULL_TAG;
" B! m) e" P7 J8 l' V8 ndouble centroid[2][3];3 b: u5 K* x {2 ]+ ]
UF_CURVE_line_t line_coords;
7 D. |1 y4 i; A- g2 ctag_t lineTag = NULL_TAG;
& \4 T8 P) O, q& B& L6 }9 j- D& X6 | O- L+ ?
extern DllExport void ufusr( char *parm, int *returnCode, int rlen )
2 i* f) @2 O; P{
0 u4 A0 s4 M/ N9 }, Z, ^9 R' c /* Initialize the API environment */' _# ?/ Q% u4 C2 i# D- j2 x
if( UF_CALL(UF_initialize()) )
5 S9 E C$ x: ^' E& X {
2 H8 I2 f6 ~: T2 z /* Failed to initialize */
4 d% \4 m& p" Y! P4 L2 q. O return; x# j( w C t* X" F/ T% t$ `$ J0 T
}1 J9 e4 G; @# C
* z7 z$ l+ f5 P y" i3 g3 k
/* TODO: Add your application code here */
8 C& @8 x @+ u( k) T8 n& {& ]0 ^& |
- T+ ]* K, D6 h* g0 N UF_PART_new("D:\\part.prt", 1, &partTag);( B/ D! c ]6 q
0 p0 x3 b2 d( y5 S" e1 p
UF_MODL_create_cyl1(UF_NULLSIGN, origin, height, diam, direction, &cylTag);# P8 [7 i! |5 a9 n$ x
UF_MODL_ask_feat_edges(cylTag, &eageList);
' O& F: P% d- H1 b0 l UF_MODL_ask_list_count(eageList, &count);0 T6 ~( y. X3 P6 P8 V' a- y7 ^$ f
sprintf(msg,"count number: %d",count);2 Z7 q1 P* ~ R* T6 u7 \) y
uc1601(msg,1);/ v1 X# S7 P9 ~6 p7 J
9 B& E% n: B) d/ w& ?: R0 H5 E. D9 _
for ( i = 0; i < count; i++)
$ U/ s) M/ J0 V+ z5 k {
: Q5 N2 D+ q7 `4 }3 H UF_MODL_ask_list_item(eageList, i, &eageTag);//将对应边保存+ v' r! _/ X/ U5 h7 R9 X
- B( `" {$ A7 T) q
UF_CURVE_ask_centroid(eageTag, centroid[i]);//将对应的边的中点获取4 C, b, k j6 Z8 o2 T
}
5 S8 _; @+ v- A; p r
8 j; U* A/ `9 j) N2 D line_coords.start_point[0] = centroid[0][0];//第一个曲线的中心坐标
7 m! H% a7 d! j5 ^ line_coords.start_point[1] = centroid[0][1];
: J5 u6 z" j4 ]) D2 z line_coords.start_point[2] = centroid[0][2];3 S$ t+ T* c+ D, O/ t; z
! c; b2 r; e4 ^0 f8 p/ R9 o line_coords.end_point[0] = centroid[1][0];
! ~/ V1 ^6 q- b, J9 E: l line_coords.end_point[1] = centroid[1][1];2 ^& D: A. H5 g1 }
line_coords.end_point[2] = centroid[1][2];
1 S4 v* p3 I! A! l: e, {
3 `% ], K- i( h! I UF_CURVE_create_line(&line_coords, &lineTag);9 N. y. ^- K+ r3 P& Y6 C
UF_PART_save();, N5 \. b. p2 N. }) H! R% X
6 |' i5 J7 g$ D; t4 w& ]
|
-
-
评分
-
查看全部评分
|