#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. linux mint 中文支持

    sudo apt-get install localessudo dpkg-reconfigure locales 设置zh_CN.UTF-8

  2. 微信小程序隐私指引完整填写范本(开发者收集你选中的照片或视频信息,用于?)

    为了分辨用户,开发者将在获取你的明示同意后,收集你的微信昵称.头像.为了显示距离,开发者将在获取你的明示同意后,收集你的位置信息.开发者收集你的地址,用于获取位置信息.开发者收集你的发票信息,用于维护 ...

  3. P12证书转BKS证书

    安卓 识别的证书格式是bks ,而我之前生成的证书格式是p12 所以需要转换一下,至于怎么生成p12,请看我转载的的文章  Nginx https 双向认证. 1.请先下载第三方转换工具protecl ...

  4. Account Manager privacy agreement

    Account Manager privacy agreement [Account Manager] (hereinafter referred to as "we") )We ...

  5. 【转载】VMWare 各版本下载地址【centos7安装gerrit】

    https://blog.csdn.net/weixin_44129085/article/details/110443135 centos7安装gerrit https://blog.csdn.ne ...

  6. nginx(二) の 配置静态资源网站

    首先在开始配置前,要想明白,nginx 配置 静态资源 服务时基本逻辑,其实就是要 将路由地址与服务器中文件真实的存储地址进行映射. 配置静态资源样例 配置前,首先要将当前配置文件的路径,写入到 ng ...

  7. MATLAB基础—基础认识

    数建-MATLAB(基础认识) 一些基本使用 clear all :清除Workspace中的所有变量 clc: 清除Command Window中的所有命令 注释:%%(空空格)多行注释 或 % 单 ...

  8. EhLib 9安装

    EhLib 9安装 安装EhLib: 在Installer文件夹里找到EhLibInstaller.exe,右键以管理员权限运行EhLibInstaller.exe. 按照提示一路安装下来,顺利完成. ...

  9. 实验1task5

    <实验结论> #include <stdio.h> #include <stdlib.h> int main() { float a,b,c; printf(&qu ...

  10. MAC 不带XIB新建ViewController

    - (void)loadView{ NSView *view = [[NSView alloc]init]; self.view = view; } MAC 开发的小伙伴