今天是国庆节,放假休息懒得动,没有出去玩,在家研究一下发射线函数UF_MODL_trace_a_ray。小弟以前在软件公司混的时候,当时我做的那个项目就用到了UF_MODL_trace_a_ray,当时为了赶项目,从别处抄了代码,改吧改吧。自己也没有仔细的去研究一下这个函数的用法。UF_MODL_trace_a_ray在NX二次开发中算是一个用到比较高频的函数,今天研究了一下,写了一道例题,UFUN和NXOpen C++简单混合去用了一下,大致介绍下函数的用法。如有错误,还请各位前辈多多指教小弟!

 NX11+VS2013

     #include <uf.h>
#include <uf_ui.h>
#include <uf_modl.h>
#include <uf_mtx.h>
#include <uf_curve.h>
#include <NXOpen/CurveCollection.hxx>
#include <NXOpen/NXObject.hxx>
#include <NXOpen/Part.hxx>
#include <NXOpen/PartCollection.hxx>
#include <uf_obj.h>
#include <NXOpen/ListingWindow.hxx> NXOpen::Session *theSession = NXOpen::Session::GetSession();
NXOpen::Part *workPart(theSession->Parts()->Work());
NXOpen::Part *displayPart(theSession->Parts()->Display()); UF_initialize(); //创建点
double Point1[] = { -300.0, 50.0, 50.0 };
tag_t PointTag = NULL_TAG;
UF_CURVE_create_point(Point1, &PointTag); //创建块
UF_FEATURE_SIGN Sign = UF_NULLSIGN;
double Corner_pt[] = { 0.0, 0.0, 0.0 };
char *Edge_len[] = { "", "", ""};
tag_t BlkTag = NULL_TAG;
UF_MODL_create_block1(Sign, Corner_pt, Edge_len, &BlkTag); //特征找体
tag_t BodyTag = NULL_TAG;
UF_MODL_ask_feat_body(BlkTag, &BodyTag); //创建射线(从点出发,向X方向,发射到块上)
tag_t Bodies[] = { BodyTag };
double Direction[] = { 1.0, 0.0, 0.0 };
double TransForm[];
UF_MTX4_identity(TransForm);
int num_results;
UF_MODL_ray_hit_point_info_p_t hit_list;
UF_MODL_trace_a_ray(, Bodies, Point1, Direction, TransForm, , &num_results, &hit_list); //判断射线与块是否有交点
if ( num_results == )
{
uc1601("提示:找不到射线交点", );
} if ( num_results != )
{
//创建直线(连接发射点和射线与块的第一个交点)
NXOpen::Point3d StartPoint1{ Point1[], Point1[], Point1[] };
NXOpen::Point3d EndPoint1{ hit_list[].hit_point[], hit_list[].hit_point[], hit_list[].hit_point[] };
NXOpen::Line *Line1;
Line1 = workPart->Curves()->CreateLine(StartPoint1, EndPoint1); //赋予直线红色
UF_OBJ_set_color(Line1->Tag(), ); //创建直线(连接射线与块的第一个交点与第二个交点)
NXOpen::Point3d EndPoint2{ hit_list[].hit_point[], hit_list[].hit_point[], hit_list[].hit_point[] };
NXOpen::Line *Line2;
Line2 = workPart->Curves()->CreateLine(EndPoint1, EndPoint2); //赋予直线绿色
UF_OBJ_set_color(Line2->Tag(), ); //赋予第一个交点所在面为蓝色
tag_t FirstFaceTag = { hit_list[].hit_face };
UF_OBJ_set_color(FirstFaceTag, ); //赋予第二个交点所在面为紫色
tag_t SecondFaceTag = { hit_list[].hit_face };
UF_OBJ_set_color(SecondFaceTag, ); //打印坐标点和方向
char msg[];
sprintf_s(msg, "交点数量为:%d\n射线与块第一个交点坐标为:\nX坐标:%f\nY坐标:%f\nZ坐标:%f\n射线与块第二个交点坐标为:\nX坐标:%f\nY坐标:%f\nZ坐标:%f",
num_results,hit_list[].hit_point[], hit_list[].hit_point[], hit_list[].hit_point[], hit_list[].hit_point[], hit_list[].hit_point[], hit_list[].hit_point[]); lw->Open();
lw->WriteLine(msg);
} UF_terminate();

NX二次开发-UFUN发射线函数UF_MODL_trace_a_ray的用法的更多相关文章

  1. NX二次开发-UFUN拉伸函数UF_MODL_create_extruded

    NX9+VS2012 //NX二次开发中常用拉伸函数为UF_MODL_create_extruded2,但是此函数不能拉伸片体, //想要拉伸片体用函数UF_MODL_create_extruded. ...

  2. NX二次开发-UFUN拉伸函数UF_MODL_create_extruded2

    NX9+VS2012 //NX二次开发中常用拉伸函数为UF_MODL_create_extruded2,但是此函数不能拉伸片体, //想要拉伸片体用函数UF_MODL_create_extruded. ...

  3. NX二次开发-UFUN计时函数UF_begin_timer

    NX9+VS2012 #include <uf.h> #include <uf_modl.h> UF_initialize(); //计时开始 UF_timer_t Timer ...

  4. NX二次开发-UFUN计时函数UF_end_timer

    1 NX9+VS2012 2 3 #include <uf.h> 4 #include <uf_modl.h> 5 6 7 UF_initialize(); 8 9 //计时开 ...

  5. NX二次开发-UFUN遍历函数UF_OBJ_cycle_objs_in_part

    NX11+VS2013 #include <uf.h> #include <uf_obj.h> #include <uf_modl.h> #include < ...

  6. NX二次开发-UFUN遍历函数UF_OBJ_cycle_all

    NX11+VS2013 #include <uf.h> #include <uf_obj.h> #include <uf_modl.h> #include < ...

  7. NX二次开发-UFUN将工程图转成CGM和PDF文件UF_CGM_export_cgm

    文章转载自唐康林NX二次开发论坛,原文出处: http://www.nxopen.cn/thread-126-1-1.html 刚才有同学问到这个问题,如果是用NXOpen来做,直接录制一下就可以了: ...

  8. NX二次开发-UFUN获取NX系统默认导出CGM的选项设置UF_CGM_ask_default_export_options

    文章转载自唐康林NX二次开发论坛,原文出处: http://www.nxopen.cn/thread-126-1-1.html 刚才有同学问到这个问题,如果是用NXOpen来做,直接录制一下就可以了: ...

  9. NX二次开发-UFUN获取当前导出CGM选项设置UF_CGM_ask_session_export_options

    文章转载自唐康林NX二次开发论坛,原文出处: http://www.nxopen.cn/thread-126-1-1.html 刚才有同学问到这个问题,如果是用NXOpen来做,直接录制一下就可以了: ...

随机推荐

  1. Fiddler,对数据进行抓包,拦截,修改等操作

    转载....... 一.fiddler设置fiddler默认是只能抓取http网络格式的,所以我们要先设置下使fiddler可以获取到https网络格式 首先tools→options→https进去 ...

  2. 【leetcode】951. Flip Equivalent Binary Trees

    题目如下: For a binary tree T, we can define a flip operation as follows: choose any node, and swap the ...

  3. 【基础】Pipeline

    1. 参考的优秀文章 Request/Response protocols and RTT 2. 来源 原来,系统中一个树结构的数据来源是Redis,由于数据增多.业务复杂,查询速度并不快.究其原因, ...

  4. PHP ftp_nb_get() 函数

    定义和用法 ftp_nb_get() 函数从 FTP 服务器上下载一个文件并保存到本地一个文件中.(无阻塞) 该函数返回下列值之一: FTP_FAILED(发送/获取失败) FTP_FINISHED( ...

  5. ORACLE动态sql在存储过程中出现表或视图不存在的解决方法

    Oracle动态sql在存储过程中出现表或视图不存在的解决方法 CREATE OR REPLACE PROCEDURE P_test is strsql varchar2(2000); BEGIN   ...

  6. 洛谷 2327 [SCOI2005]扫雷

    输入输出格式 输入格式: 第一行为N,第二行有N个数,依次为第二列的格子中的数.(1<= N <= 10000) 输出格式: 一个数,即第一列中雷的摆放方案数. 输入输出样例 输入样例#1 ...

  7. go解析markdown转成html

    一.代码 package main import ( "fmt" "github.com/microcosm-cc/bluemonday" "gith ...

  8. PHP fpassthru() 函数

    定义和用法 fpassthru() 函数输出文件指针处的所有剩余数据. 该函数将给定的文件指针从当前的位置读取到 EOF,并把结果写到输出缓冲区. 语法 fpassthru(file) 参数 描述 f ...

  9. bzoj1211树的计数 x bzoj1005明明的烦恼 题解(Prufer序列)

    1211: [HNOI2004]树的计数 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3432  Solved: 1295[Submit][Stat ...

  10. (转)OpenFire源码学习之十一:连接管理(下)

    转:http://blog.csdn.net/huwenfeng_2011/article/details/43416523 下面是下部分 C2S 1.当有客户端进行连接时根据Mina框架的模式首先调 ...