购买与咨询 NX 二次开发视频教程,请联系微信号:13890821008 QQ号:85585969
函数结构:UF_MODL_create_extrusion_path( tag_t * objects, int object_count, tag_t * path_objects, int path, UF_MODL_SWEEP_TRIM_object_p_t trim_data, char * offsets [ 2 ], double region_point [ 3 ], logical region_specified, logical solid_creation, UF_FEATURE_SIGN sign, tag_t * * features, int* number_of_features) 函数说明:
创建使用扫沿导拉伸特征。
函数参数:
第1个参数为输入:
objects代表参数变量,tag_t * 为输入参数类型,Section对象。
第2个参数为输入:
输入int 整数型的参数,参数的变量格式为object_count,部分对象的数量
第3个参数为输入:
path_objects代表参数变量,tag_t * 为输入参数类型,路径对象
第4个参数为输入:
输入int 整数型的参数,参数的变量格式为path,路径对象的数量
第5个参数为输入:
trim_data代表参数变量,UF_MODL_SWEEP_TRIM_object_p_t 为输入参数类型,不曾用过
第6个参数为输入:
输入char * 字符类型的参数,参数的变量格式为offsets [ 2 ],偏置
第7个参数为输入:
输入double 双精度类型的参数,参数的变量格式为region_point [ 3 ],点所需的区域
第8个参数为输入:
region_specified代表参数变量,logical 为输入参数类型,真或假的期望区域
第9个参数为输入:
solid_creation代表参数变量,logical 为输入参数类型,如果为真,打造坚实的机构,如果存在输入字符串封闭。否则,片体是结果。
第10个参数为输入:
sign代表参数变量,UF_FEATURE_SIGN 为输入参数类型,要执行的操作的符号。UF_NULLSIGN=创建新的目标坚实UF_POSITIVE=添加到目标固体UF_NEGATIVE=从目标减去固体UF_UNSIGNED=相交目标固体
第11个参数为输出:
features代表参数变量,tag_t * * 为输出参数类型,拉伸特征标签的数组。这必须通过调用UF_free释放。
第12个参数为输出:
输出int* 整数型的参数,参数的变量格式为number_of_features,返回的功能数
UF_MODL_create_extrusion_path函数实例代码演示:
下面的例子需要一个开放的一部分。该代码创建一个4边形,其沿着导向线挤出。
[quote]
#include <stdio.h>
#include <uf_curve.h>
#include <uf.h>
#include <uf_modl.h>
#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_NULLSIGN;
tag_t line1, line2, line3, line4, guide, *objects;
tag_t generators[4];
double pt1[3] = {2.5, 3.5, 0.0};
UF_CURVE_line_t mline1, mline2, mline3, mline4, mguide;
/* line 1 */
mline1.start_point[0] = 0.0;
mline1.start_point[1] = 0.0;
mline1.start_point[2] = 0.0;
mline1.end_point[0] = 0.0;
mline1.end_point[1] = 1.0;
mline1.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&mline1, &line1));
/* line 2 */
mline2.start_point[0] = 0.0;
mline2.start_point[1] = 1.0;
mline2.start_point[2] = 0.0;
mline2.end_point[0] = 2.5;
mline2.end_point[1] = 3.5;
mline2.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&mline2, &line2));
/* line 3 */
mline3.start_point[0] = 2.5;
mline3.start_point[1] = 3.5;
mline3.start_point[2] = 0.0;
mline3.end_point[0] = 1.0;
mline3.end_point[1] = 0.0;
mline3.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&mline3, &line3));
/* line 4 */
mline4.start_point[0] = 1.0;
mline4.start_point[1] = 0.0;
mline4.start_point[2] = 0.0;
mline4.end_point[0] = 0.0;
mline4.end_point[1] = 0.0;
mline4.end_point[2] = 0.0;
UF_CALL(UF_CURVE_create_line(&mline4, &line4));
generators[0] = line1;
generators[1] = line2;
generators[2] = line3;
generators[3] = line4;
/* Guide Line */
mguide.start_point[0] = 2.5;
mguide.start_point[1] = 3.5;
mguide.start_point[2] = 0.0;
mguide.end_point[0] = 2.5;
mguide.end_point[1] = 3.5;
mguide.end_point[2] = 1.0;
UF_CALL(UF_CURVE_create_line(&mguide, &guide));
UF_CALL(UF_MODL_create_extrusion_path(generators, 4, &guide, 1, NULL,
offsets, pt1, false, true,
mode_sign, &objects, &obj_cnt ));
}
/*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]