点击查看详细介绍

UF_MODL_unite_bodies() 函数的参数解释说明、函数详细用法,以及实例代码演示

misnn 7年前 1327 0

购买与咨询 NX 二次开发视频教程,请联系微信号:13890821008  QQ号:85585969  


函数结构:
UF_MODL_unite_bodies
(
tag_t target,
tag_t tool
)

函数说明:
团结两具尸体。UF_MODL_unite_bodies_with_retained_options荣誉的设置建模Preferences对话框中选择“从布尔人脸属性”,但UF_MODL_unite_bodies始终应用的显示属性目标身上新面孔。

函数参数:
第1个参数为输入:
target代表参数变量,tag_t 为输入参数类型,目标和由此产生的体

第2个参数为输入:
tool代表参数变量,tag_t 为输入参数类型,刀体

UF_MODL_unite_bodies函数实例代码演示:
描述该程序演示如何使用下面的UG/ Open API的程序:UF_MODL_unite_bodiesUF_MODL_subtract_bodiesUF_MODL_intersect_bodies项目描述下面的例子需要一个开放,空白部分。该代码创建一个体和汽缸。然后执行结合,相减,相交及这两个机构与之间的操作撤消在每个操作之间。
[quote]
#include <stdio.h>
#include <uf_modl.h>
#include <uf.h>
#include <uf_defs.h>
#include <uf_undo.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)
{


tag_t block, cylinder, feature, *resulting_bodies = NULL;

double origin[3]={0.0,0.0,0.0};
double direction[3]={0.0,0.0,1.0};

int num_results;

char *edge_lens[3]={"1","1","1"};
char *diameter={"1.0"};
char *height="2.0";

int rollback_id = 0;
UF_UNDO_mark_name_t mark_name = NULL;

/* Create a block and cylinder. */
UF_CALL(UF_MODL_create_block1(UF_NULLSIGN,
origin,
edge_lens,
&feature));
UF_CALL(UF_MODL_ask_feat_body(feature,
&block));

UF_CALL(UF_MODL_create_cyl1(UF_NULLSIGN,
origin,
height,
diameter,
direction,
&feature));
UF_CALL(UF_MODL_ask_feat_body(feature,
&cylinder));

/* Set undo mark */
UF_CALL(UF_UNDO_set_mark( UF_UNDO_invisible,
mark_name,
(UF_UNDO_mark_id_t *)&rollback_id));

/* Perform unite */
UF_CALL(UF_MODL_unite_bodies(block,
cylinder));

/* Undo the unite */
UF_CALL(UF_UNDO_undo_to_mark(rollback_id,
NULL));

/* Set undo mark */
UF_CALL(UF_UNDO_set_mark( UF_UNDO_invisible,
mark_name,
(UF_UNDO_mark_id_t *)&rollback_id));

/* Perform subtract */
UF_CALL(UF_MODL_subtract_bodies(block,
cylinder,
&num_results,
&resulting_bodies));

if (num_results > 0)
UF_free(resulting_bodies);

/* Undo the subtract */
UF_CALL(UF_UNDO_undo_to_mark(rollback_id,
NULL));

/* Perform intersect */
UF_CALL(UF_MODL_intersect_bodies(block,
cylinder,
&num_results,
&resulting_bodies));
if (num_results > 0)
UF_free(resulting_bodies);


}
/*ARGSUSED*/
void ufusr(char *param, int *retcode, int paramLen)
{
if (!UF_CALL(UF_initialize()))
{
do_ugopen_api();
UF_CALL(UF_terminate());
}
}

int ufusr_ask_unload(void)
{
return (UF_UNLOAD_IMMEDIATELY);
}


[/quote]

0

最新回复 (0)
请登录后发表新帖