#include <uf.h>
#include <uf_modl.h>
#include <uf_part.h>
#include <uf_modl_primitives.h>
#include <uf_object_types.h>
#include <uf_CSYS.h>
#include <UF_VEC.h>
#include <UF_MTX.h>
#include <uf_trns.h> tag_t point_tag=NULL_TAG;
double point[3]={0,0,0};
UF_CURVE_create_point(point,&point_tag);//创建点
/*----------------------------*/
double matrix [16];
double O1[3]={0.0,0.0,1.0};	//变换Z+1
tag_t object2=NULL_TAG; //变化后tag
int status;
uf5943(O1,matrix); //矩阵方法(线性) //矩阵的实现
int numbers=1; // 阵列数量
int tran=2; // 1 :移动 2 :复制
int layer=-1; // -1: 工作层
int trace_curves=2;
uf5947(matrix,&point_tag,&numbers,&tran,&layer,&trace_curves,&object2,NULL,&status);
    UF_CSYS_set_wcs_display(1); //显示工作坐标


 封装


static void moveObjtect(tag_t object, double X, double Y,double Z)
{
tag_t csys_tag = NULL_TAG;
tag_t matrix_id = NULL_TAG;
double csys_origin[3];
UF_CSYS_ask_wcs(&csys_tag);
UF_CSYS_ask_csys_info(csys_tag, &matrix_id, csys_origin);

double min_corner[3], directions[3][3], distances[3];
UF_MODL_ask_bounding_box_exact(object, csys_tag, min_corner, directions, distances);
UF_CSYS_map_point(UF_CSYS_WORK_COORDS, min_corner, UF_CSYS_ROOT_WCS_COORDS, min_corner);
double matrix[16]; //矩阵
double O1[3] = { X - min_corner[0],Y - min_corner[1],Z }; //变换Z+1
tag_t object2 = NULL_TAG; //变化后tag
int status;
uf5943(O1, matrix); //矩阵方法(线性)
//矩阵的实现
int numbers = 1; // 阵列数量
int tran = 1; // 1 :移动 2 :复制
int layer = 0; // -1: 工作层
int trace_curves = 2;
uf5947(matrix, &object, &numbers, &tran, &layer, &trace_curves, &object2, NULL, &status);
if (X > 0 && Y == 0)
{
double min_corner1[3], directions1[3][3], distances1[3];
UF_MODL_ask_bounding_box_exact(object, csys_tag, min_corner1, directions1, distances1);
double origin[3] = { min_corner1[0] + distances1[0],min_corner1[1],0.0 };
tag_t temp_csys = NULL_TAG;
UF_CSYS_create_temp_csys(origin, matrix_id, &temp_csys);
UF_CSYS_set_wcs(temp_csys);
}
else
{
double min_corner1[3], directions1[3][3], distances1[3];
UF_MODL_ask_bounding_box_exact(object, csys_tag, min_corner1, directions1, distances1);
double origin[3] = { min_corner1[0],min_corner1[1]+distances1[1],0.0 };
tag_t temp_csys = NULL_TAG;
UF_CSYS_create_temp_csys(origin, matrix_id, &temp_csys);
UF_CSYS_set_wcs(temp_csys);
}
}

 

NX 二次开发,线性移动uf5943的更多相关文章

  1. 【NX二次开发】多种变换

    变换的种类: uf5942 矩阵乘积变换 uf5943 平移变换 uf5944 缩放变换 uf5945 旋转变换 uf5946 镜像变换 最后使用 uf5947 实现uf5942-uf5946的变换. ...

  2. NX二次开发-Block UI C++界面关于 在Block UI中UF_initialize();和UF_terminate();的使用

    关于 在Block UI中UF_initialize();和UF_terminate();的使用 用Block UI作NX二次开发的时候,不需要在使用UFUN函数的时候加UF_initialize() ...

  3. NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))

    NX二次开发API里没有对EXCAL读写操作的相关函数,市面上有很多种方法去实现,比如UFUN调KF,ODBC,OLE(COM组件)等等.这里我是用的OLE(COM组件)方式去做的,这种在VC上创建的 ...

  4. NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))

    在看这个博客前,请读者先去完整看完:NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))https://ufun-nxopen.blog.csdn.net/article ...

  5. NX二次开发-基于MFC界面对话框与NX交互的开发

    打开VS2013 点击新建,选择MFC DLL 点击确定 点下一步 什么都不改,直接点完成 进来之后先编译一下,看是否编译成功 打开项目属性,更改这几处 $(UGII_BASE_DIR)\ugopen ...

  6. NX二次开发-BlockUI对话框嵌套MFC对话框制作进度条

    半年前在一些QQ群看到有大神NX二次开发做出了进度条,那个时候我还不会弄,也不知道怎么弄得,后来断断续续得研究了一下,直到今天我把它做出来了.内心还是很喜悦的!回想自己这两年当初从没公司肯给我做NX二 ...

  7. NX二次开发-UDO用户自定义对象(UFUN)【持续完善】

    每当提起UDO总是会让我想起大专毕业那会失业找工作,后来有个宝贵机会去了软件公司上班,拿到了我人生中的第一个NX二次开发项目,一个关于测量汽车前后左右摄像头的项目.当时那个项目就用到了UDO,对于只看 ...

  8. NX二次开发-UFUN计算两点距离UF_VEC3_distance

    NX11+VS2013 #include <uf.h> #include <uf_curve.h> #include <uf_vec.h> UF_initializ ...

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

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

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

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

随机推荐

  1. Word发博客测试

    这是一篇来自word的文章测试,测试word写博客发布效果. 操作参考:http://www.cnblogs.com/liezhengli/p/5854470.html 关键在于找到博客园的MetaW ...

  2. 使用Wireshark完成实验3-IP

    1.使用Wireshark打开ip-ethereal-trace-1,如图 电脑IP地址为192.168.1.102 2.如图,IP包头中上层协议字段的值为1,代表为ICMP 3.如图,IP头中有20 ...

  3. taskkill报taskkill不是内部或者外部命令,也不是可运行程序

    转载一下处理这个'taskkill报taskkill不是内部或者外部命令,也不是可运行程序' 的问题:https://blog.csdn.net/wangying_2016/article/detai ...

  4. es实现规格动态域生成

    1.就是把sepc的可以提取出来作为一个域(sepc是一个规格参数) 封装搜索条件(跟jdbc流程一样) @requestparam( required = false) 的作用?   不传值后台也不 ...

  5. pie-engine-ai项目jenkins.yaml文件

    apiVersion: apps/v1kind: Deploymentmetadata: name: jenkins namespace: pie-engine-ai labels: name: je ...

  6. gRPC 入门(一)

    前言 在学习 gRPC 之前,先学习 protobufu 协议,简单的来理解,我们可以使用他来定义 消息 和 服务.然后你只需要实现服务即可,剩下的东西,gRPC 会帮你自动完成. protobufu ...

  7. KiCad,一款开源的PCB设计软件

    Kicad,一款开源的PCB设计软件 1.偷偷摸摸久矣 还记得是大二的实践课,用Protel99se设计一款PCB,把电路图转印到铜板上并腐蚀出来,然后钻孔.焊接,那时候的软件是真难用,后面自学了Al ...

  8. 给含有关键词的label着色

    给含有关键词的label着色 FineFileType() { let arr = document.querySelectorAll('.el-checkbox__label'); for (let ...

  9. dbeaver把表数据导出csv时字符串自动加双引号问题解决

    背景: mysql 5.7 dbeaver 21.1.4 解决:如下图,括起字符这里设置一个 空格(space)即可: 参考1

  10. MySQL时区的问题

    我这里是在application.properties文件中配置的MySQL连接信息. 开始时间显示不征程是因为没有配置时区,后来加上了setTimeZone=Asia/Shanghai,时间显示正常 ...