|
o8 e# }6 {6 r$ y g& C
利用 ug/OPEN API开发具体产品的应用系统时,常常遇到如何建立零件间装配约束关系的问题。如何实现零件间自动装配,是开发应用系统的难点之一。 1. 装配约束关系的简化 1 J G! g3 }, S. I* X
在实际应用中,装配约束的配合类型有贴合、对准、角度、平行、正交、对中等多种类型,用于装配约束的对象类型有面、边、基准面、基准轴、点、线、曲线、坐标系等多种形式。为了便于数据描述,可将组件间的装配关系做了适当的简化,如图1、2所示,该例中,将零件间的装配约束关系简化为两组件间三个基准面的贴合或对准的装配约束类系。其中,图2中X,Y,Z为对应部件中的基准面名。# c. S' o! f, u6 v: X% i
图1 简化前的装配约束关系   ? 图2 简化后的装配约束关系 简化组件装配约束关系后,将主动组件的部件名、组件名与对象名,从动组件的部件名、组件名与对象名,以及装配约束类型等信息保存在ODBC数据库中。在系统加载部件时,可根据数据库中的装配信息,实现组件的自动装配。 2.自动装配的实现2 h! o4 B/ o9 P1 q% g7 B: B. o
4 c6 a" ?* f! B1 X
2.1主动组件的加载
4 S- B$ v4 h7 Z, K# G% L
" z- b* b: a# z& x 使用UF_ASSEM_add_part_to_assembly函数即可将部件加载到装配体。下段程序用于加载部件的,其中,parent_tag为父部件的部件标识,part_name为加载部件的部件名,inst_name为加载部件的组件名,inst_tag返回加载部件的实例标识。 5 p2 `2 T8 W2 a
void UG_OPEN_add_part_to_assem(tag_t parent_tag,char *part_name,?char *inst_name,tag_t *inst_tag) 8 n6 h6 M2 X+ L- o/ y3 }# E
{
. U7 P# z& ~7 d" Xdouble origin[3] = {0,0,0};& K, i1 y1 [5 N+ g
double csys_matrix[6] = {1,0,0,0,1,0};
' \0 b% H9 G# g# M% ~! Dint layer = -1;
0 O+ Q! z* H% a/ JUF_PART_load_status_t load_status;7 p2 |/ h; w9 s& {
UF_ASSEM_add_part_to_assembly(parent_tag, part_name, NULL,inst_name, origin, csys_matrix, layer, inst_tag, &load_status);& N9 I5 F3 u' b
if ( load_status.file_names != NULL ): G; u+ f I; A: f. C. P
UF_free_string_array( load_status.n_parts, load_status.file_names );
* X( T9 j- f; W* J4 Y. r3 D3 Zif ( load_status.statuses != NULL ) @8 a7 E( p8 ~4 ]
UF_free(load_status.statuses );
! o* J$ ~2 J P1 Y" [! q. O6 v} 6 }+ }7 P, g2 Z: }, d2 \
2.2 主动、从动组件事例标识的获取
. t+ M: [( T) \* O3 v 主动组件的事例标识可以通过UF_ASSEM_ask_part_occ_of_inst函数直接获取。从动组件事例标识的获取较为繁琐,其步骤为:(1) 确定从动组件的部件标识;(2)获取从动组件的所有事例标识;(3)匹配事例标识对应的组件名与从动组件组件名,确定从动组件的事例标识。需要注意的是,在同一装配中,部件名相同的其组件名不能相同,组件名相同的其部件名不能相同。 ) `) k1 Z4 S. m6 P$ U( z) U" h
下段程序代码用于获取从动组件事例标识,其中,part_name 为部件文件文件名,inst_name为部件文件组件名,occ_tag返回部件文件事例标识。
# R% ?) n1 D3 _! d6 avoid UG_OPEN_ask_part_occ_by_name(char *part_name, char *inst_name,tag_t *occ_tag )1 _; M- v- E& c% _
{ ! K+ n) X" E6 m z
tag_t *part_occs;
* ]' Z9 I, Q. L7 xtag_t temp_tag;6 Z' N. Q; w, C* Y, S8 U# e# p
int i;. E/ N8 @! U% |8 Y. ^
char part_n[133], refset_name[31],instance_name[31];?- V" a! r2 q, \0 O8 u3 W
double origin[ 3 ],csys_matrix[ 9 ],transform[ 4 ][ 4 ];?
& O! u( u: Q, }' \ Dtemp_tag = UF_PART_ask_part_tag(part_name);
) y/ O7 M" k- \; w, Cif(temp_tag != NULL_TAG)/ o6 ^7 t X# A4 Q; E' u
{5 H) t% F9 E- ^& ]' K
UF_ASSEM_ask_occs_of_part (NULL_TAG, temp_tag, &part_occs );7 D- K: n4 H) [) K5 @/ Q
i = 0;
1 P6 j) F" G6 O. ?while(part_occs != NULL_TAG)
+ v% {6 [; \* ~- a$ e{, f( d0 b7 g+ `, W2 A2 ~9 ]
UF_ASSEM_ask_component_data(part_occs, part_n, refset_name,?6 Z( u7 k4 O1 N7 W6 L2 y# v
instance_name, origin, csys_matrix, transform);
. n: W3 N% i8 H: ]: q7 kif(strcmp(strlwr(instance_name),strlwr(inst_name)) ==0 ) break;; M9 W. B: L2 f, d1 O! i5 X6 `
i++;) k+ @$ l5 I( R) F$ @
}$ M. m/ ]& z, L
if(part_occs != NULL_TAG)?9 q ~) B! |" h7 f. k' u8 s
*occ_tag = part_occs;
( m! d4 r% j* \' @, Oelse; O# V* ?) @& y" _+ R
*occ_tag = NULL_TAG;
$ n, a" D' Y; S: K1 S. Z1 g8 PUF_free(part_occs);
; V. S- J( D) x" y" c}
" M& f9 U7 i: j, z9 _* {/ c6 }else: H! O! j; J; z
*occ_tag = NULL_TAG;8 z( J# j2 c* b" K8 E- g# g- u; H
} 8 j' E4 j' A/ N5 E8 w+ e
2.3 约束对象标识的获取" i& X. W7 P7 m
1 Q* O- X$ A! F V& k
获取用于建立装配约束关系的对象标识的步骤为:(1)将对象所在部件设置为工作部件;(2)利用UF_OBJ_cycle_by_name 获取对象标识。同样需要注意的是,在同一部件中,对象名应唯一。 # o- C, J6 R3 H3 @; Q0 R8 f$ w: m
下段程序代码用于获取对象标识,其中part_tag为对象所在部件的部件标识,obj_name为对象名,obj_tag返回约束对象的标识。 * c5 w) l% a) d% R# l1 z8 w
void UG_OPEN_ask_obj_tag_by_name(tag_t part_tag, char *obj_name, tag_t *obj_tag)
$ D7 J+ z. ~/ ^( q" u8 i, T{# Z- S0 [9 {, ]! g+ u' s
tag_t work_part, object_tag = NULL_TAG;?, O2 v8 V9 b& g9 B8 p, K
work_part = UF_ASSEM_ask_work_part();6 b% E4 J$ p S9 p0 k
if(part_tag != NULL_TAG)
* G" H# R/ s) d+ r1 e' A+ e{
1 Y% l* W# A) C, B$ s4 |3 u+ RUF_ASSEM_set_work_part(part_tag);1 n0 c4 X ?) l0 F0 u
UF_OBJ_cycle_by_name (obj_name, &object_tag);?
3 t8 Y( c; |- S0 I8 i/ cif (object_tag != NULL_TAG)
$ | @$ W7 D& _( X; a*obj_tag = object_tag;! _, m4 a1 u3 x% k, u' a: v
else
3 S# w/ G" P& g( k' ?: X2 j3 ~) g*obj_tag = NULL_TAG;
( _. w% ]8 w, M4 }2 n}
5 R" f9 _# A- A l$ z9 A5 Melse# y: S/ W3 ~4 P! R; @0 K0 ~
{' b6 n; F4 L1 l& i" b2 v7 z
*obj_tag = NULL_TAG;
n% w5 K& J, A' t}
5 r( P2 v5 T: E) c* \' J$ y' KUF_ASSEM_set_work_part(work_part);
; o7 k) ?) G7 Y( M% |. S}
. Y# d0 g/ o* I# a8 q2.4装配约束关系的建立+ d2 _1 F- z* J! F% O m) c
建立组件间的装配约束的步骤为:(1) 定义装配约束,即填充结构UF_ASSEM_constraint_s;(2)利用函数UF_ASSEM_solve_mc求解约束;(3) 利用函数UF_ASSEM_apply_mc_data将约束应用到装配体上;(4) 利用函数UF_MODl_update更新模型,以反映模型变化。
6 z* h* G1 W; J% U, J4 ?; E! P% _( Q 下段程序代码用于两组件间的装配约束关系的建立,其中, from_part_ins为主动组件实例标识,from_obj_tag为主动组件中的对象标识,from_part_occ为主动组件的事例标识,to_obj_tag为从动组件的对象标识,to_part_occ为从动组件的事例标识,mate_type为装配类型。
$ V8 J, a- L* X2 V1 c2 Y, uvoid UG_OPEN_atuo_mate_by_datum(tag_t from_part_ins,tag_t *from_obj_tag,
0 y9 b& d* c k- ?: ]tag_t from_part_occ,tag_t *to_obj_tag,' Y, T6 T% J4 N0 U! @* Q
tag_t to_part_occ,char **mate_type )& ^; X0 v5 H8 @" \4 [# b
{
; u' k; j& `" R) `# [" uUF_ASSEM_mating_condition_t? ftf;' T) {% p, i; \! g
UF_ASSEM_mc_status_t? status;% d7 y* p. W. ]' \" h
UF_ASSEM_mc_structure_state_t struct_status;+ B2 u/ o+ h0 t
UF_ASSEM_dof_t? dof;- f( o. \: d9 Z( T6 i/ b. v' k
double transform[4][4];9 ^% q7 T5 u8 R/ a% ~- q1 l
int ret,i;1 @; T; B2 o% I: J7 }; ]: E
UF_ASSEM_init_mc (&ftf);5 T- l9 t) V/ I6 g+ ^
ftf.mated_object = from_part_ins;/ @# v7 I8 f) T _+ V2 H
ftf.name = NULL;
3 _/ G2 T- O$ ^ftf.user_name = false;2 F$ D) y3 u, W( c
for(i=0; i<3; i++)
6 n/ E7 @ D6 w* b0 l{
& T! I. {2 U I$ l$ Eftf.constraints.from_status = UF_ASSEM_ok;+ S, Y2 G' i, W' x! k
ftf.constraints.to_status = UF_ASSEM_ok;
4 w$ Q2 ~4 D$ T& w4 T4 q `& fif(strcmp(strlwr(mate_type),"m") == 0): k$ j" s7 r- d$ f
ftf.constraints.mate_type = UF_ASSEM_v16_mate;
8 f D+ G8 S# h3 h) a/ aelse
( P4 O4 E- ^9 c+ q% [+ ?ftf.constraints.mate_type = UF_ASSEM_v16_align ;
4 ^5 L& ? _; Hftf.constraints.from_type = UF_ASSEM_datum_plane;! d3 d* {* ?* _$ @" J
ftf.constraints.to_type = UF_ASSEM_datum_plane;6 U: F2 L7 E2 F4 n
ftf.constraints.from = from_obj_tag;2 U1 a1 V- _0 H; T
ftf.constraints.from_part_occ = from_part_occ;" M! J5 |: p! I5 x
ftf.constraints.to = to_obj_tag;
' i& N$ ]7 n h. x4 A% Wftf.constraints.to_part_occ = to_part_occ;4 M/ ?+ K* x5 h9 G
ftf.constraints.offset = NULL_TAG;* t9 k; P6 R( @
ftf.constraints.name = NULL;
. M& l D" `( f0 A1 O; Sftf.constraints.user_name = false;
! z$ L6 N/ u. d0 M" T- g a} 7 W/ S2 p( S) ]9 x! h! k& s6 w
ftf.num_constraints = 3;$ ?0 H" k0 g, i" m9 O
ftf.suppressed = false;
* S" b7 V0 z& r6 o. P4 H% t, `" ?ret=UF_ASSEM_solve_mc(&ftf, &status, &dof, transform);% N3 H' A( l9 S8 e1 d9 D9 R
if(ret == 0 || status == UF_ASSEM_mc_solved)' P- L( x4 i+ X1 h
{
( V# x' z7 J" _- |3 m* Y! _UF_ASSEM_apply_mc_data(&ftf, &struct_status, &status);' r8 [# y/ d1 A& Y! g+ o2 F, m
if(struct_status == UF_ASSEM_structure_ok && status == UF_ASSEM_mc_solved)3 C. L) p- e. H5 v2 y
{
5 h! n T0 U l+ h9 _UF_DISP_refresh();
' t5 o& y# Q" m2 V5 ]6 IUF_MODL_update();
1 ]/ \7 a' R" j7 D. X U/ U}: p# ~: f3 a, Q; H) N* Y% t# y
}
& {- o& f0 Y# w( s- C} |
|