NX二次开发 版本通用方法
对于用C++做NX二次开发,随着NX的版本变更,二开所用的函数也会有相应的更新调整,生成的DLL不能跨版本运行,报错率极高,甚至不能加载。折腾了好久找到三种方法:
1.纯使用C++的代码开发或者尽可能使用UF函数(方法不大靠普,能不能跨版使有点碰运气的成份)
2.同一功能对应不同的NX版本编译不同版本的DLL,对应不同的版本建立不同的按钮。(亲测是能正常使用,但是一个功能多个按钮,不专业)
3.同一个功能多个版本共用一个按钮,建立一个主DLL通过识别NX主版本,再根据NX的版本调用该功能对应版本的DLL(看起来专业多了,目前NX8.5、NX10、NX12 NX1946 做了测试,正常使用。不知道二开高手是怎么做,有更好的方法请指点下)
法1 和法 2 都有明显的缺陷,不适用,下面说明下法3是如何实现的。(自个网上找资料折腾出来的方法,不知道对不对,目前功能实现起来是没有问题)
1)首先把功能对应NX版本编译不同的DLL

2)新建工程

3)工程创建以下函数
//获取运行程序的路径
HMODULE GetSelfModuleHandle()
{
MEMORY_BASIC_INFORMATION mbi;
return ((::VirtualQuery(GetSelfModuleHandle, &mbi, sizeof(mbi)) != 0)
? (HMODULE)mbi.AllocationBase : NULL);
}
CString GetProgramDir() //获取运行程序的路径
{
char exeFullPath[MAX_PATH]; // 全路径
string strPath = "";
GetModuleFileName(GetSelfModuleHandle(), exeFullPath, MAX_PATH);
strPath = (string)exeFullPath; // 获取程序路径
int pos = strPath.find_last_of('\\', strPath.length());
CString path;
path = strPath.substr(0, pos).c_str();
return path;
}
string MyClass::GetPath() //输出程序路径
{
CString exe_path = GetProgramDir();
string ProgramDirPath = exe_path;
return string(ProgramDirPath);//返回路径
}
string MyClass::YiNingToolPath(string DLLDir) //分割程序路径获取工具目录
{
try
{
//反向找位置,分割字符串(只读取文件夹路径)
string strPath = DLLDir;
string strDir;
int nPos = strPath.find_last_of('\\');
if (string::npos != nPos)
{
strDir = strPath.substr(0, nPos);
}
return string(strDir);//返回文件夹路径
}
catch (exception& ex)
{
//---- Enter your exception handling code here -----
MyClass::theUI->NXMessageBox()->Show("分割程序路径获取工具目录", NXOpen::NXMessageBox::DialogTypeError, ex.what());
}
}
void MyClass::UFUN_API_Call_DLL(char* dllPath)
{
//调系统命令
typedef void(*load_ufusr_f_p_t)(char* param, int* retcode, int paramLen);
load_ufusr_f_p_t load_ufusr_ptr = NULL;
int irc = UF_load_library(dllPath, "ufusr", (UF_load_f_p_t*)&load_ufusr_ptr);
//调用DLL
if (load_ufusr_ptr != NULL)
{
int retcode;
load_ufusr_ptr(dllPath, &retcode, 1);
}
if (irc != 0)
{
uc1601("failed load", 1);
UF_unload_library(dllPath); // 注意该语句只能在失败时被调用,否则UG会退出
return;
}
}
void MyClass::GetNXRev()//获取NX主要版本
{
try
{
UF_initialize();
theSession->ListingWindow()->Open();//打开信息窗口
//获取NX主要版本
UF_get_release(&NXrelease); //获取NX主要版本
//theSession->ListingWindow()->WriteLine(NXrelease);
UF_terminate();
}
catch (exception& ex)
{
//---- Enter your exception handling code here -----
MyClass::theUI->NXMessageBox()->Show("帮助", NXOpen::NXMessageBox::DialogTypeError, "程序错误,请检查代码");
}
}
void MyClass::CallToolingDLL(string CallDllName) //对应版本调用DLL
{
try
{
UF_initialize();
theSession->ListingWindow()->Open();//打开信息窗口
string CurrentDllPath = GetPath();//输出程序路径
string CurrentToolPath = YiNingToolPath(CurrentDllPath); //分割程序路径获取工具目录
//theSession->ListingWindow()->WriteLine("当前DLL路径:" + CurrentDllPath);
//theSession->ListingWindow()->WriteLine("当前外挂路径:" + CurrentToolPath);
string NX85DllPath = CurrentDllPath + "\\NX85\\" + CallDllName + "_NX85.dll";
string NX10DllPath = CurrentDllPath + "\\NX10\\" + CallDllName + "_NX10.dll";
string NX12DllPath = CurrentDllPath + "\\NX12\\" + CallDllName + "_NX12.dll";
string NX1946DllPath = CurrentDllPath + "\\NX1946\\" + CallDllName + "_NX1946.dll";
char YiNing_tools_NX85[256];
char YiNing_tools_NX10[256];
char YiNing_tools_NX12[256];
char YiNing_tools_NX1946[256];
sprintf(YiNing_tools_NX85, "%s", NX85DllPath.c_str());
sprintf(YiNing_tools_NX10, "%s", NX10DllPath.c_str());
sprintf(YiNing_tools_NX12, "%s", NX12DllPath.c_str());
sprintf(YiNing_tools_NX1946, "%s", NX1946DllPath.c_str());
GetNXRev();//获取NX主版本
//获取NX主要版本
if (strcmp(NXrelease, "NX V8.5") == 0)
{
UFUN_API_Call_DLL(YiNing_tools_NX85);
//theSession->ListingWindow()->WriteLine(YiNing_tools_NX85);
}
else if (strcmp(NXrelease, "NX V10.0") == 0)
{
UFUN_API_Call_DLL(YiNing_tools_NX10);
//theSession->ListingWindow()->WriteLine(YiNing_tools_NX10);
}
else if (strcmp(NXrelease, "NX V12.0") == 0)
{
UFUN_API_Call_DLL(YiNing_tools_NX12);
//theSession->ListingWindow()->WriteLine(YiNing_tools_NX12);
}
else if (strcmp(NXrelease, "NX V1926") == 0)
{
UFUN_API_Call_DLL(YiNing_tools_NX1946);
//theSession->ListingWindow()->WriteLine(YiNing_tools_NX1946);
}
UF_terminate();
}
catch (exception& ex)
{
//---- Enter your exception handling code here -----
MyClass::theUI->NXMessageBox()->Show("对应版本调用", NXOpen::NXMessageBox::DialogTypeError, "程序错误,请检查代码");
}
}
3)入口函数徙通过字符串对比识别菜单按钮调用DLL

4)编译生成DLL:YiNingToolsSelectMen.dll
5)外挂菜单挂上生成的DLL

6)效果图如下

NX二次开发 版本通用方法的更多相关文章
- 【NX二次开发】NX内部函数,查找内部函数的方法
[NX二次开发]NX内部函数,libufunx.dll文件中的内部函数 [NX二次开发]NX内部函数,libugui.dll文件中的内部函数 [NX二次开发]NX内部函数,libuifw.dll文件中 ...
- NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))
NX二次开发API里没有对EXCAL读写操作的相关函数,市面上有很多种方法去实现,比如UFUN调KF,ODBC,OLE(COM组件)等等.这里我是用的OLE(COM组件)方式去做的,这种在VC上创建的 ...
- NX二次开发-UDO用户自定义对象(UFUN)【持续完善】
每当提起UDO总是会让我想起大专毕业那会失业找工作,后来有个宝贵机会去了软件公司上班,拿到了我人生中的第一个NX二次开发项目,一个关于测量汽车前后左右摄像头的项目.当时那个项目就用到了UDO,对于只看 ...
- C# NX二次开发环境搭建
在网上看到一篇C#二次开发环境搭建的文章:NX二次开发-使用NXOPEN C#手工搭建开发环境配置 ,写得非常好.我按照文章操作,过程中遇到几个问题,把问题分享给大家,希望对各位有帮助. 注意三点: ...
- NX二次开发-C#使用DllImport调用libufun.dll里的UF函数(反编译.net.dll)调用loop等UF函数
在写这篇文章的时候,我正在头晕,因为下班坐车回家,有些晕车了.头疼的要死.也吃不下去饭. 版本:NX11+VS2013 最近这一年已经由C++过度到C#,改用C#做应用程序开发和NX二次开发. C#在 ...
- NX二次开发-创建NX9 NXOpenCPP Wizard开发向导模板
这篇文章,我在CSDN,在唐工论坛都发过.http://www.nxopen.cn/forum.php?mod=viewthread&tid=2039&highlight=NX9 博客 ...
- NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))
在看这个博客前,请读者先去完整看完:NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))https://ufun-nxopen.blog.csdn.net/article ...
- NX二次开发-BlockUI对话框嵌套MFC对话框制作进度条
半年前在一些QQ群看到有大神NX二次开发做出了进度条,那个时候我还不会弄,也不知道怎么弄得,后来断断续续得研究了一下,直到今天我把它做出来了.内心还是很喜悦的!回想自己这两年当初从没公司肯给我做NX二 ...
- NX二次开发-UFUN计算两点距离UF_VEC3_distance
NX11+VS2013 #include <uf.h> #include <uf_curve.h> #include <uf_vec.h> UF_initializ ...
- NX二次开发-NX+VS写代码设断点调试技巧
在做NX二次开发的时候写完代码,编译可以通过,但是执行的时候却没有反应,或者得到的结果不对,说明肯定有地方传值出错了.我在查找代码错误的时候有几种方法:1.uc1601打印函数输入和输出的值看对不对. ...
随机推荐
- [JSOI2015]圈地
原题链接:P6094 [JSOI2015]圈地 题意简述 把一块 \(n \times m\) 的地分给两个人,选择分出第 \(i\) 行第 \(j\) 列的地可以获得 \(a_{i,j}\) 的收益 ...
- Vue基础(2)双向绑定
双向数据绑定 通过修改标签,例:切换radio.checkbox......都会对绑定的数据有影响 通过事件触发方法,修改data中数据,反向作用于radio.checkbox...... 1.v-m ...
- (jmeter笔记)jmeter打印日志
Bean Shell常用内置变量 JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下: log:写入信息到jmeber.l ...
- C#中Newtonsoft.Json.dll 的使用
1.类库说明Newtonsoft.Json.dll是.NET 下开源的json格式序列号和反序列化的类库,利用此类库,可以方便地操作json数据,其中在反序列化时,可以直接将格式化的json数据处理成 ...
- nginx 白名单配置
方法一. iptables [root@root~]# vim /etc/sysconfig/iptables .... -A INPUT -s 白名单IP -p tcp -m state --sta ...
- C语言II一作业02
1.作业头 | 这个作业属于哪个课程 | < https://edu.cnblogs.com/campus/zswxy/SE2020-3> | | ---- | ---- | ---- | ...
- 全局监控Promise错误
一.问题引入 Promise 在前端中的使用已经非常普遍了,但是许多开发者或许习惯了链式调用却忘了捕获 Promise 的错误了. 例如: function forgetCatchError () { ...
- 【PTA】1049 Counting Ones
The task is simple: given any positive integer N, you are supposed to count the total number of 1's ...
- Jenkins在windows环境下的3种部署方式
本文主要介绍Jenkins在windows环境下的3种部署方式: (1)官网下载jenkins.msi文件直接安装.jenkins官网地址:https:/jenkins.io/zh/ (2)jenki ...
- 2022/7/28 第七组陈美娜 API类
API:Application Program Interface应用程序接口 JDK给我们提供的一些已经写好的类,可以直接调方法来解决问题 类的方法在宏观上都可以称为接口 接口:1.interfac ...