当前位置: 首页 > article >正文

告别手动注册!用Inno Setup为你的C# SolidWorks插件制作一键安装包(附VS生成后事件脚本)

从代码到产品用Inno Setup打造SolidWorks插件的专业安装体验在SolidWorks二次开发领域许多开发者投入大量精力完善插件功能却在最后交付环节草草了事——简单复制DLL文件搭配批处理脚本的方式不仅显得业余更给终端用户带来诸多不便。本文将系统介绍如何通过Inno Setup将C#开发的SolidWorks插件转化为具有完整安装/卸载流程的专业Windows安装包并实现与Visual Studio的无缝集成构建真正的一键发布工作流。1. 为什么需要专业安装包当开发者完成一个功能完善的SolidWorks插件后通常会面临如何分发给团队或客户的问题。传统的手动注册方式存在几个明显缺陷用户体验差非技术用户对运行bat脚本存在天然恐惧缺乏版本管理无法跟踪已安装的插件版本卸载不彻底手动卸载容易残留注册表项和文件权限问题Windows 10/11的UAC机制可能导致注册失败专业安装包的价值不仅在于提升产品形象更重要的是解决上述痛点。Inno Setup作为轻量级安装包制作工具具有以下优势特性传统方式Inno Setup方案安装体验需手动操作图形化向导卸载支持需单独脚本集成卸载程序权限处理需管理员手动授权自动提权版本控制无内置版本管理依赖检查无可检测.NET框架2. Inno Setup核心配置详解2.1 基础脚本结构Inno Setup脚本(.iss)采用类INI文件格式以下是一个典型SolidWorks插件安装包的核心结构[Setup] AppNameMySolidWorksPlugin AppVersion1.0 DefaultDirName{pf}\MySolidWorksPlugin DefaultGroupNameMySolidWorksPlugin OutputDir.\Output OutputBaseFilenameSetup_MyPlugin Compressionlzma SolidCompressionyes PrivilegesRequiredadmin [Files] Source: ..\bin\Release\*.dll; DestDir: {app}; Flags: ignoreversion Source: RegAsm.exe; DestDir: {app}; Flags: ignoreversion [Run] Filename: {app}\RegAsm.exe; Parameters: {app}\SolidWorksAddin.dll /codebase; StatusMsg: Registering COM component...; Flags: runhidden [UninstallRun] Filename: {app}\RegAsm.exe; Parameters: {app}\SolidWorksAddin.dll /u; Flags: runhidden关键参数说明PrivilegesRequiredadmin确保以管理员权限运行Flagsignoreversion避免DLL版本冲突{app}表示安装目录的宏runhidden静默执行注册过程2.2 解决Windows权限问题现代Windows系统的安全机制可能导致插件加载失败需要在安装时正确设置目录权限[Dirs] Name: {app}; Permissions: users-modify [Registry] Root: HKLM; Subkey: SOFTWARE\SolidWorks\Addins\{{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}}; ValueType: string; ValueName: Description; ValueData: My Plugin; Flags: uninsdeletekey Root: HKLM; Subkey: SOFTWARE\SolidWorks\Addins\{{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}}; ValueType: dword; ValueName: Title; ValueData: 1; Flags: uninsdeletekey提示GUID值需与插件类的[Guid]属性完全一致3. 自动化构建集成3.1 Visual Studio生成后事件要实现编译即发布的自动化流程需要在VS项目中配置生成后事件if $(ConfigurationName) Release ( C:\Program Files (x86)\Inno Setup 6\ISCC.exe $(ProjectDir)SetupScript.iss /DAppVersion$(AssemblyVersion) xcopy /Y $(ProjectDir)Output\*.exe \\BuildServer\Releases\ )此脚本实现三个功能仅在Release配置下触发打包将程序集版本传递给安装包自动拷贝安装包到共享目录3.2 进阶版本管理通过MSBuild任务可实现更精细的版本控制Target NamePostBuild AfterTargetsPostBuildEvent GetAssemblyIdentity AssemblyFiles$(TargetPath) Output TaskParameterAssemblies ItemNameAssemblyInfo/ /GetAssemblyIdentity PropertyGroup AssemblyVersion%(AssemblyInfo.Version)/AssemblyVersion /PropertyGroup Exec Command$(ProgramFiles)\Inno Setup 6\ISCC.exe $(ProjectDir)Setup.iss /DAppVersion$(AssemblyVersion) /DAppPath$(TargetDir)/ /Target4. 安装包增强功能4.1 多语言支持Inno Setup原生支持多语言界面只需在脚本中添加[Languages] Name: en; MessagesFile: compiler:Default.isl Name: zh; MessagesFile: compiler:Languages\ChineseSimplified.isl [CustomMessages] en.InstallForAllUsersInstall for all users zh.InstallForAllUsers为所有用户安装4.2 运行环境检测确保目标系统满足插件要求[Code] function InitializeSetup(): Boolean; begin if not IsDotNetInstalled(net452, 0) then begin MsgBox(This plugin requires .NET Framework 4.5.2, mbError, MB_OK); Result : False; end else Result : True; end;4.3 静默安装支持为便于企业部署可添加静默安装参数[Setup] ... SetupLoggingyes [Run] ... Filename: {app}\Register.bat; Parameters: /silent; Flags: runhidden skipifsilent5. 调试与问题排查即使精心设计的安装包也可能遇到各种环境问题以下是几个常见场景的解决方案插件未出现在SolidWorks中检查注册表项是否正确写入确认DLL已成功注册使用regasm /tlb生成类型库查看SolidWorks加载日志%temp%\solidworks_loading.log权限不足导致加载失败[Registry] Root: HKLM; Subkey: SOFTWARE\SolidWorks\Addins; Permissions: users-full版本冲突处理[Files] Source: *.dll; DestDir: {app}; Flags: ignoreversion sharedfile在实际项目中我发现最稳妥的做法是在安装完成后添加一个验证步骤[Run] Filename: {sys}\cmd.exe; Parameters: /C {app}\VerifyInstall.bat; Description: Verify installation; Flags: postinstall runhidden这个bat脚本可以检查注册状态、文件权限等关键指标确保插件能够正常加载。

相关文章:

告别手动注册!用Inno Setup为你的C# SolidWorks插件制作一键安装包(附VS生成后事件脚本)

从代码到产品:用Inno Setup打造SolidWorks插件的专业安装体验 在SolidWorks二次开发领域,许多开发者投入大量精力完善插件功能,却在最后交付环节草草了事——简单复制DLL文件搭配批处理脚本的方式,不仅显得业余,更给终…...

从ST转战小华HC32F448:一个电机控制老兵的实战避坑与快速上手指南

从ST转战小华HC32F448:一个电机控制老兵的实战避坑与快速上手指南 当国产MCU的性价比优势逐渐凸显,越来越多的工程师开始关注小华半导体这类新兴玩家。作为深耕电机控制领域多年的开发者,我最近在变频器项目中尝试了HC32F448这颗芯片&#xf…...

Perplexity社会新闻搜索响应延迟突增47%?独家披露其底层新闻图谱更新机制与3类高危缓存失效场景

更多请点击: https://kaifayun.com 第一章:Perplexity社会新闻搜索响应延迟突增47%?独家披露其底层新闻图谱更新机制与3类高危缓存失效场景 Perplexity 社会新闻搜索服务近期观测到 P95 响应延迟从 320ms 飙升至 468ms,增幅达 4…...

2026年国产数据库大盘点与趋势:自主可控时代的数据库生态

一、2026年国产数据库市场概况 1. 市场发展现状 2026年国产数据库市场呈现稳步增长态势。在信创政策深化、数据安全法规完善的大背景下,数据库作为核心基础软件,其国产化进程持续推进。 2026年主要厂商市场表现: 金仓KES:在政务领…...

基础设施监控:全面监控基础设施状态

基础设施监控:全面监控基础设施状态 一、基础设施监控概述 1.1 基础设施监控的定义 基础设施监控是指对IT基础设施的状态、性能和可用性进行持续监控和管理的过程。它包括服务器、网络、存储和应用等方面的监控,确保基础设施的稳定运行和高效利用。 1.2 …...

CANN/asc-devkit Div除法函数文档

Div 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。 项目地址: https://gitcode.com/cann/a…...

从ZZULIOJ到LeetCode:数组合并的“双指针”套路,一篇就够(附C/Java/Python三语实现)

从双指针到多语言实现:有序数组合并的通用解法精要 合并有序数组是算法学习中的经典问题,也是技术面试中的高频考点。无论是ZZULIOJ这类在线判题系统,还是LeetCode等面试准备平台,都将其作为考察基础算法能力的重要题型。本文将深…...

边缘网络:构建边缘计算的网络基础设施

边缘网络:构建边缘计算的网络基础设施 一、边缘网络概述 1.1 边缘网络的定义 边缘网络是指部署在网络边缘的网络基础设施,它将计算、存储和网络资源扩展到离用户更近的位置。边缘网络支持低延迟数据处理、实时响应和分布式计算,是边缘计算的关…...

CANN/asc-devkit Mull乘法溢出API

Mull 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。 项目地址: https://gitcode.com/cann/…...

drf-nested-routers测试指南:确保嵌套路由稳定性的完整方案

drf-nested-routers测试指南:确保嵌套路由稳定性的完整方案 【免费下载链接】drf-nested-routers Nested Routers for Django Rest Framework 项目地址: https://gitcode.com/gh_mirrors/dr/drf-nested-routers drf-nested-routers是Django Rest Framework的…...

Lusca源码解析:深入理解Express安全中间件的实现原理

Lusca源码解析:深入理解Express安全中间件的实现原理 【免费下载链接】lusca Application security for express apps. 项目地址: https://gitcode.com/gh_mirrors/lu/lusca Lusca是一款专为Express应用设计的安全中间件,它集成了多种安全防护机制…...

Ormar 性能优化:10 个提升数据库查询效率的技巧

Ormar 性能优化:10 个提升数据库查询效率的技巧 【免费下载链接】ormar python async orm with fastapi in mind and pydantic validation 项目地址: https://gitcode.com/gh_mirrors/or/ormar Ormar 是一个专为 FastAPI 设计的 Python 异步 ORM,…...

暗黑破坏神2存档修改器:释放你的游戏创造力

暗黑破坏神2存档修改器:释放你的游戏创造力 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit 你是否曾想过,如果能让暗黑破坏神2中的角色拥有完美的装备组合?如果…...

深度解析Py-ART雷达数据处理:从数据校正到高级反演的全流程实战

深度解析Py-ART雷达数据处理:从数据校正到高级反演的全流程实战 【免费下载链接】pyart The Python-ARM Radar Toolkit. A data model driven interactive toolkit for working with weather radar data. 项目地址: https://gitcode.com/gh_mirrors/py/pyart …...

git讲解,git vscode 对应,git pycharm 对应

文章目录安装git配置git什么是git 仓库创建版本库git addvscodegit statusgit addgit statuspycharm变更列表视图如果创建文件的时候选择了添加到git版本控制暂存区域视图时光穿梭机版本回退修改文件vscodepycharm变更列表暂存区域git logvscodepycharmgit reset 版本回退git r…...

D1021UK,125W高功率输出的推挽式DMOS RF FET射频晶体管

简介今天我要向大家介绍的是 TT Electronics/Semelab 的金金属化多用途硅DMOS RF FET晶体管——D1021UK。这是一款专为HF/VHF/UHF通信频段(1 MHz至400 MHz)设计的推挽式(Push-Pull)射频功率场效应管,在28V工作电压下可…...

百度网盘Mac版SVIP破解终极指南:三步解锁高速下载限制

百度网盘Mac版SVIP破解终极指南:三步解锁高速下载限制 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 还在为百度网盘Mac版的龟速下载而烦恼…...

D1016UK,1MHz至1GHz宽带适用的低噪声高效率射频功率晶体管

简介今天我要向大家介绍的是 TT Electronics/Semelab 的DMOS RF FET晶体管——D1016UK。这是一款专为VHF/UHF通信频段(1 MHz至1GHz)设计的金金属化多用途硅RF功率场效应管,采用推挽式架构,在28V工作电压下可提供40W的输出功率。作…...

对服务器网络参数具体相关概念

你问到了 高并发系统真正的“全链路瓶颈” 问题,非常关键! 要真正理解“一个请求从用户到服务器再返回”到底经历了什么、哪里可能卡住,确实不能只看 CPU —— 网卡、网络带宽、协议开销、包大小、运营商、甚至流量套餐,都会影响整…...

MyBatis-Plus详解(速成版)

一、介绍MyBatis-Plus: 1.概念 MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 MyBatis-Plus的官网简介:https://baomidou.com/introduce/ 2.特点: 无侵入&#xff…...

告别VS Code!用CLion 2024.3 + CUDA 12.1搭建高效GPU开发环境(附CMake配置避坑指南)

CLion 2024.3 CUDA 12.1:打造专业级GPU开发环境的终极指南 在GPU加速计算领域,开发者长期面临一个两难选择:是使用功能全面但笨重的Visual Studio,还是选择轻量灵活但功能有限的VS Code?JetBrains CLion 2024.3的出现…...

VSCode里Code Runner跑Python总报9009?别慌,检查一下你的setting.json文件

VSCode中Code Runner执行Python报错9009的终极排查指南 当你第一次在VSCode中用Code Runner插件运行Python脚本,满心期待看到输出结果时,终端却弹出"Process exited with code 9009"的红色错误提示——这种挫败感我深有体会。这个看似神秘的错…...

163MusicLyrics:免费解锁网易云QQ音乐歌词,告别本地音乐“哑巴“时代

163MusicLyrics:免费解锁网易云QQ音乐歌词,告别本地音乐"哑巴"时代 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 还在为本地音乐播放…...

Pearcleaner:Mac应用彻底清理的终极解决方案,告别数字垃圾困扰

Pearcleaner:Mac应用彻底清理的终极解决方案,告别数字垃圾困扰 【免费下载链接】Pearcleaner A free, source-available and fair-code licensed mac app cleaner 项目地址: https://gitcode.com/gh_mirrors/pe/Pearcleaner 还在为Mac应用卸载后残…...

AutoSar网络管理(NM)与0x28通信控制服务:搞懂主从节点,精准控制子总线流量

AutoSar网络管理中0x28服务的拓扑控制艺术:主从架构与子总线流量精准调度 在车载电子系统日益复杂的今天,一条CAN总线上可能挂着十几个ECU节点,而网关则需要管理多条这样的总线。想象一下,当某个子总线上的节点需要软件更新时&…...

技术解密:如何从零构建开源贴片机的完整指南

技术解密:如何从零构建开源贴片机的完整指南 【免费下载链接】lumenpnp The LumenPnP is an open source pick and place machine. 项目地址: https://gitcode.com/gh_mirrors/lu/lumenpnp 在电子制造领域,贴片机一直是小型创客和硬件开发者难以企…...

mat-chem-sim-pred开发者指南:如何贡献新的科学计算算子

mat-chem-sim-pred开发者指南:如何贡献新的科学计算算子 【免费下载链接】mat-chem-sim-pred 面向工业领域,聚焦计算仿真、预测两大核心场景,构建面向流程工业"机理数据"双轮驱动的领域计算层,推动AI for Science在材料…...

AI大模型Agent面试,超详细(附答案)!

AI大模型Agent面试,超详细(➕答案)!假如你从2026年开始学大模型,按这个步骤走准能稳步进阶。 接下来告诉你一条最快的邪修路线, 3个月即可成为模型大师,薪资直接起飞。阶段1:大模型基础阶段2:RA…...

三步搞定Windows和Office永久激活:KMS_VL_ALL_AIO智能激活全攻略

三步搞定Windows和Office永久激活:KMS_VL_ALL_AIO智能激活全攻略 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统频繁弹出激活提示而烦恼吗?Office突然…...

终极AMD Ryzen调试指南:简单三步掌握硬件性能调优

终极AMD Ryzen调试指南:简单三步掌握硬件性能调优 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://gitcod…...