购买与咨询 NX 二次开发视频教程,请联系微信号:13890821008 QQ号:85585969
函数结构:UF_MODL_create_extrusion( tag_t * objects, int object_count, UF_MODL_SWEEP_TRIM_object_p_t trim_data, char * taper_angle, char * limits [ 2 ], char * offsets [ 2 ], double region_point [ 3 ], logical region_specified, logical solid_creation, double direction [ 3 ], UF_FEATURE_SIGN sign, tag_t * * features, int* number_of_features) 函数说明:
创建一个拉伸特征。将所得体是,如果输入一个固体串是封闭的并且solid_creation选项为TRUE。否则,一个表身体的效果。的片材不能被锥形并且taper_angle必须设置为0.0。所述UF_MODL_SWEEP_TRIM_object结构被用来定义修整对象。挤出的限制是有效的只有当没有指定UF_MODL_SWEEP_TRIM_object结构(NULL)。 该区域点对应于选择相交的对象之后选择的点。如果region_point_specified是假,那么该地区的点被忽略。注意,偏移方向是由所述的叉积确定第一型材段的方向矢量与挤压方向向量。段的方向跟随轮廓的方向流,而不是分段的参数或数学方向。通过对象列表创建的配置文件必须是连续的。
函数参数:
第1个参数为输入:
objects代表参数变量,tag_t * 为输入参数类型,对象的列表被挤压
第2个参数为输入:
输入int 整数型的参数,参数的变量格式为object_count,对象的数量
第3个参数为输入:
trim_data代表参数变量,UF_MODL_SWEEP_TRIM_object_p_t 为输入参数类型,指针结构修剪数据
第4个参数为输入:
输入char * 字符类型的参数,参数的变量格式为taper_angle,锥角。的锥角可以是仅当正在创建的主体是一个片体非零。
第5个参数为输入:
输入char * 字符类型的参数,参数的变量格式为limits [ 2 ],挤出的限制。只有有效的,如果trim_data= NULL
第6个参数为输入:
输入char * 字符类型的参数,参数的变量格式为offsets [ 2 ],偏移量开弦
第7个参数为输入:
输入double 双精度类型的参数,参数的变量格式为region_point [ 3 ],在区域所需点
第8个参数为输入:
region_specified代表参数变量,logical 为输入参数类型,真或假的期望区域
第9个参数为输入:
solid_creation代表参数变量,logical 为输入参数类型,如果为TRUE,如果输入字符串关闭创建实体。否则,片体是结果。
第10个参数为输入:
输入double 双精度类型的参数,参数的变量格式为direction [ 3 ],挤压方向
第11个参数为输入:
sign代表参数变量,UF_FEATURE_SIGN 为输入参数类型,要执行的操作的符号。UF_NULLSIGN=创建新的目标坚实UF_POSITIVE=添加到目标固体UF_NEGATIVE=从目标减去固体UF_UNSIGNED=相交目标固体
第12个参数为输出:
features代表参数变量,tag_t * * 为输出参数类型,拉伸特征标签的数组。这必须通过调用UF_free释放。
第13个参数为输出:
输出int* 整数型的参数,参数的变量格式为number_of_features,返回的功能数
UF_MODL_create_extrusion函数实例代码演示:
这个例子需要一个开放的一部分。该代码创建一个单元块和一个4边的多边形是挤出并联合在一起的底部块。
[quote]
#include <stdlib.h>
#include <stdio.h>
#include <uf_curve.h>
#include <math.h>
#include <uf_modl.h>
#include <uf.h>
#define EPSILON (double)1.0e-7
#define UF_CALL(X) (report( __FILE__, __LINE__, #X, (X)))
static int report( char *file, int line, char *call, int irc)
{
if (irc)
{
char messg[133];
printf("%s, line %d: %s\n", file, line, call);
(UF_get_fail_message(irc, messg)) ?
printf(" returned a %d\n", irc) :
printf(" returned error %d: %s\n", irc, messg);
}
return(irc);
}
static void do_ugopen_api(void)
{
int obj_cnt;
char *offsets[2] = {"0.0", "0.0"};
UF_FEATURE_SIGN mode_sign = UF_POSITIVE;
UF_MODL_SWEEP_TRIM_object_t trim_object;
int i, num;
uf_list_p_t face_list;
double corner_pt[3] = { 0.0, 0.0, 2.0 };
char *edges_len[3] = { "1", "1", "1" };
char *limits[2]={ "0", "0" };
char *taper_angle="0.0";
tag_t blk_eid, face;
tag_t trim_objects[1],line1, line2, line3, line4;
tag_t *objects, generators[4];
double pt1[3],face_dir[3],dir[3];
UF_CURVE_line_t sline1, sline2, sline3, sline4;
pt1[0]=0.0;
pt1[1]=0.0;
pt1[2]=0.0;
/* line#1 */
sline1.start_point[0] = 0.0;
sline1.start_point[1] = 0.0;
sline1.start_point[2] = 0.0;
sline1.end_point[0] = 0.0;
sline1.end_point[1] = 1.0;
sline1.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&sline1,&line1));
/* line#2 */
sline2.start_point[0] = 0.0;
sline2.start_point[1] = 1.0;
sline2.start_point[2] = 0.0;
sline2.end_point[0] = 2.5;
sline2.end_point[1] = 3.5;
sline2.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&sline2,&line2));
/* line#3 */
sline3.start_point[0] = 2.5;
sline3.start_point[1] = 3.5;
sline3.start_point[2] = 0.0;
sline3.end_point[0] = 1.0;
sline3.end_point[1] = 0.0;
sline3.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&sline3,&line3));
/* line#4 */
sline4.start_point[0] = 1.0;
sline4.start_point[1] = 0.0;
sline4.start_point[2] = 0.0;
sline4.end_point[0] = 0.0;
sline4.end_point[1] = 0.0;
sline4.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&sline4,&line4));
/* line 4 */
generators[0] = line1;
generators[1] = line2;
generators[2] = line3;
generators[3] = line4;
dir[0]=0.0; dir[1]=0.0; dir[2]=1.0;
/* create block 1x1x1 */
UF_CALL(UF_MODL_create_block1( UF_NULLSIGN, corner_pt,
edges_len, &blk_eid ));
UF_CALL(UF_MODL_create_list( &face_list));
UF_CALL(UF_MODL_ask_feat_faces( blk_eid, &face_list));
UF_CALL(UF_MODL_ask_list_count( face_list,&num));
trim_object.trim_count = 0;
for ( i = 0; i < num; i ++ )
{
int type, sense;
double point[3], box[6], radius, rad_data;
UF_CALL(UF_MODL_ask_list_item(face_list, i, &face));
UF_CALL(UF_MODL_ask_face_data(face, &type, point, face_dir,
box, &radius, &rad_data, &sense));
if (type == 22 && fabs(face_dir[2] + 1) < EPSILON && (fabs(2.0
- point[2]) < EPSILON ) )
{
trim_objects[0] = face;
trim_object.trim_count = 1;
trim_object.trim_objects = trim_objects;
break;
}
}
UF_CALL(UF_MODL_delete_list(&face_list));
trim_object.sign = UF_MODL_SWEEP_TRIM_TO_FACE;
UF_CALL(UF_MODL_create_extrusion(generators, 4, &trim_object,
taper_angle,limits,offsets,
pt1, false, true, dir,
mode_sign,&objects,&obj_cnt));
UF_free(objects);
}
/*ARGSUSED*/
void ufusr(char *param, int *retcode, int param_len)
{
if (!UF_CALL(UF_initialize()))
{
do_ugopen_api();
UF_CALL(UF_terminate());
}
}
int ufusr_ask_unload(void)
{
return (UF_UNLOAD_IMMEDIATELY);
}
[/quote]