PolyWorks插件开发实战指南——从编译到调用的全流程解析
1. PolyWorks插件开发环境搭建搞PolyWorks插件开发第一步得把环境折腾明白。我当年第一次接触这玩意儿的时候被各种版本兼容性问题折腾得够呛。现在回头看其实只要注意几个关键点就能少走弯路。先说说开发工具的选择。PolyWorks官方文档明确说了支持VS2017但我实测下来VS2019也能用不过有个坑得特别注意用VS2019编译C项目时可能会报错这通常是因为安装VS时没勾选必要的C开发组件。建议新手直接装VS2017社区版省心。安装时记得勾选.NET桌面开发和使用C的桌面开发这两个工作负载别问我是怎么知道的...SDK的获取也很关键。PolyWorks安装目录下有个plugins文件夹里面藏着宝贝——官方提供的示例项目有C#、VB和C三种语言的demo。我建议新手先从C#的demo入手因为.NET环境的错误提示更友好调试起来更方便。具体路径一般在C:\Program Files\InnovMetric\PolyWorks MS 2021\plugins注意版本号可能不同。2. 编译第一个Demo插件咱们以CSharpBasic这个demo为例手把手走一遍编译流程。打开VS2019记得右键选以管理员身份运行不然可能遇到权限问题找到CSharpBasic.csproj工程文件。这里有个小技巧如果直接双击打开可能会报错最好是通过VS的文件→打开→项目/解决方案来加载。加载成功后别急着点生成。先检查下目标框架版本右键项目→属性→应用程序看看目标框架是不是.NET Framework 4.x。PolyWorks插件对.NET版本有要求太新或太旧都不行。确认无误后直接CtrlShiftB编译顺利的话会在bin\Debug下生成CSharpBasic.dll。遇到过最坑爹的情况是编译报错无法找到InnovMetric.PolyWorks.IMPluginInterfaces引用。这是因为没正确配置SDK路径。解决方法是在解决方案资源管理器里右键引用→添加引用→浏览找到PolyWorks安装目录下的IMPluginInterfaces.dll一般在bin文件夹里。3. 插件注册的玄学问题生成的dll不能直接用得先注册到PolyWorks系统里。操作分两步首先把dll拷贝到plugins目录然后运行注册脚本。听起来简单是吧但这里有几个魔鬼细节第一拷贝dll时必须保证PolyWorks完全退出包括后台进程。我有次折腾半天注册不成功最后发现是任务管理器里还有个PWInspector.exe在后台挂着。第二注册脚本RegisterIMCOMServers.bat必须用管理员权限运行而且最好右键选择以管理员身份运行而不是在已经打开的普通cmd里提权。注册成功的标志是弹出一个命令行窗口最后显示Registration succeeded。如果卡住不动或者报错大概率是权限问题。还有个冷知识注册表里HKEY_LOCAL_MACHINE\SOFTWARE\InnovMetric下的键值如果混乱也会导致注册失败这时候可以尝试卸载重装PolyWorks。4. 插件调用实战技巧注册成功后打开PolyWorks的工作区管理器Workspace Manager在插件选项卡里应该能看到你的插件。但有时候明明注册成功了却找不到插件这种情况我遇到过不下十次总结出几个排查方向首先检查插件是否被正确加载。在PolyWorks安装目录的logs文件夹里有个PWInspector.log文件用记事本打开搜索你的插件名如果有Failed to load之类的错误信息说明dll可能依赖了不该依赖的库。C#插件特别容易因为引用了不兼容的第三方库而出问题。调用插件时位置一般在菜单栏的插件下拉列表里。但有些版本的UI设计很反人类插件可能藏在二级甚至三级菜单里。比如我遇到的某个版本CSharpSample插件居然要点击插件→示例→CSharp→ShowMessage才能调出来简直像在玩密室逃脱。5. 调试与排错指南当插件没按预期工作时别急着重装系统试试这几个调试方法第一招附加调试器。在VS里选择调试→附加到进程找到PWInspector.exe附加。这样就能在插件代码里下断点了。注意PolyWorks主程序是32位的所以VS也要用32位调试器。第二招查看事件查看器。Windows的事件查看器里有个应用程序日志PolyWorks的崩溃信息经常在这里能找到。我曾经靠这个解决过一个棘手的COM组件冲突问题。第三招用Process Monitor监控文件访问。当插件神秘失踪时用这个工具看PolyWorks到底在哪些路径寻找dll经常能发现路径配置错误或者权限问题。6. 进阶开发建议等你能熟练编译和调用基础插件后可以尝试更复杂的功能开发。这里分享几个实战经验首先是UI线程问题。PolyWorks的插件接口调用必须在UI线程执行如果在后台线程直接调用会引发跨线程异常。解决方法是用Control.Invoke或者Dispatcher.Invoke把调用封送到UI线程。其次是性能优化。我在开发一个点云处理插件时发现直接操作大数组特别卡。后来改用Marshal.Copy和指针操作性能提升了20倍。但要注意这种非托管代码操作容易引发内存泄漏。最后说说版本兼容性。不同版本的PolyWorks的API可能有细微差别建议在代码里做好版本判断。我现在的做法是在插件初始化时检查IMHost.Version然后根据版本号启用或禁用特定功能。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2518165.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!