/****************************************************************************** Copyright (c) 1999 Unigraphics Solutions, Inc. Unpublished - All Rights Reserved *******************************************************************************/ /* The code in the following example creates a semicircle and computes its centroid. */ #include #include #include #include #include #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 wcs_tag; UF_CURVE_arc_t arc_coords; tag_t arc; double centroid[3]; tag_t centroid_id; UF_CSYS_ask_wcs( &wcs_tag ); UF_CSYS_ask_matrix_of_object( wcs_tag, &arc_coords.matrix_tag ); arc_coords.start_angle = 0.0; arc_coords.end_angle = 180.0*DEGRA; arc_coords.arc_center[0] = 0.0; arc_coords.arc_center[1] = 0.0; arc_coords.arc_center[2] = 0.0; arc_coords.radius = 1.0; if (!UF_CALL(UF_CURVE_create_arc( &arc_coords, &arc))) { if (!UF_CALL(UF_CURVE_ask_centroid( arc, centroid))) { UF_CALL(UF_CURVE_create_point(centroid, ¢roid_id)); } } } /*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); }