Electron图标相关

核心:ICO converter:https://www.icoconverter.com/

报错如下:

bash 复制代码
> electron-builder

  • electron-builder  version=24.13.3 os=10.0.26200
  • loaded configuration  file=package.json ("build" field)
  • writing effective config  file=release\builder-effective-config.yaml
  • packaging       platform=win32 arch=x64 electron=28.3.3 appOutDir=release\win-unpacked
  ⨯ cannot execute  cause=exit status 1
                    errorOut=Reserved header is not 0 or image type is not icon for 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
Fatal error: Unable to set icon

                    command='C:\Users\17687\AppData\Local\electron-builder\Cache\winCodeSign\winCodeSign-2.6.0\rcedit-x64.exe' 'C:\Users\17687\Desktop\raw-converter\release\win-unpacked\RAW Converter.exe' --set-version-string FileDescription 'RAW Converter' --set-version-string ProductName 'RAW Converter' --set-version-string LegalCopyright 'Copyright © 2026 RAW Converter Team' --set-file-version 1.0.0 --set-product-version 1.0.0.0 --set-version-string InternalName 'RAW Converter' --set-version-string OriginalFilename '' --set-version-string CompanyName 'RAW Converter Team' --set-icon 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
                    workingDir=
  • Above command failed, retrying 3 more times
  ⨯ cannot execute  cause=exit status 1
                    errorOut=Reserved header is not 0 or image type is not icon for 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
Fatal error: Unable to set icon

                    command='C:\Users\17687\AppData\Local\electron-builder\Cache\winCodeSign\winCodeSign-2.6.0\rcedit-x64.exe' 'C:\Users\17687\Desktop\raw-converter\release\win-unpacked\RAW Converter.exe' --set-version-string FileDescription 'RAW Converter' --set-version-string ProductName 'RAW Converter' --set-version-string LegalCopyright 'Copyright © 2026 RAW Converter Team' --set-file-version 1.0.0 --set-product-version 1.0.0.0 --set-version-string InternalName 'RAW Converter' --set-version-string OriginalFilename '' --set-version-string CompanyName 'RAW Converter Team' --set-icon 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
                    workingDir=
  • Above command failed, retrying 2 more times
  ⨯ cannot execute  cause=exit status 1
                    errorOut=Reserved header is not 0 or image type is not icon for 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
Fatal error: Unable to set icon

                    command='C:\Users\17687\AppData\Local\electron-builder\Cache\winCodeSign\winCodeSign-2.6.0\rcedit-x64.exe' 'C:\Users\17687\Desktop\raw-converter\release\win-unpacked\RAW Converter.exe' --set-version-string FileDescription 'RAW Converter' --set-version-string ProductName 'RAW Converter' --set-version-string LegalCopyright 'Copyright © 2026 RAW Converter Team' --set-file-version 1.0.0 --set-product-version 1.0.0.0 --set-version-string InternalName 'RAW Converter' --set-version-string OriginalFilename '' --set-version-string CompanyName 'RAW Converter Team' --set-icon 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
                    workingDir=
  • Above command failed, retrying 1 more times
  ⨯ cannot execute  cause=exit status 1
                    errorOut=Reserved header is not 0 or image type is not icon for 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
Fatal error: Unable to set icon

                    command='C:\Users\17687\AppData\Local\electron-builder\Cache\winCodeSign\winCodeSign-2.6.0\rcedit-x64.exe' 'C:\Users\17687\Desktop\raw-converter\release\win-unpacked\RAW Converter.exe' --set-version-string FileDescription 'RAW Converter' --set-version-string ProductName 'RAW Converter' --set-version-string LegalCopyright 'Copyright © 2026 RAW Converter Team' --set-file-version 1.0.0 --set-product-version 1.0.0.0 --set-version-string InternalName 'RAW Converter' --set-version-string OriginalFilename '' --set-version-string CompanyName 'RAW Converter Team' --set-icon 'C:\Users\17687\Desktop\raw-converter\build\icon.ico'
                    workingDir=
  • Above command failed, retrying 0 more times

修复方案:

bash 复制代码
这个错误是因为你的 `icon.ico` 文件格式不正确。`rcedit` 工具要求 ICO 文件必须符合特定的格式规范。

## 解决方案:

### 1. **修复 ICO 文件格式**
确保你的 `icon.ico` 文件包含正确的图标格式:
- 必须包含至少一个有效的图标图像
- 建议包含多种尺寸:16x16, 32x32, 48x48, 64x64, 128x128, 256x256
- ICO 文件头必须正确(Reserved header 必须为 0)

### 2. **重新生成正确的 ICO 文件**

**方法 A:使用在线工具**
- 访问 https://icoconverter.com/
- 上传你的 PNG 图片(建议至少 256x256 像素)
- 选择输出格式为 ICO
- 下载生成的 ICO 文件

**方法 B:使用 ImageMagick**
```bash
# 安装 ImageMagick,然后执行:
magick convert input.png -define icon:auto-resize=256,128,96,64,48,32,16 build/icon.ico
```

**方法 C:使用在线工具 ico1111**
- https://ico1111.com/
- 支持多个尺寸

### 3. **验证 ICO 文件**
```bash
# 使用 Python 验证 ICO 文件格式
python -c "with open('build/icon.ico', 'rb') as f: print('Header:', f.read(6).hex())"
```
正确的 ICO 文件头应该是 `00000100` 开头。

### 4. **临时禁用图标(用于测试)**
如果急需构建,可以先在 `package.json` 中注释掉图标配置:

```json
{
  "build": {
    "win": {
      // "icon": "build/icon.ico",  // 临时注释
      "target": "nsis"
    }
  }
}
```

### 5. **推荐的图标文件结构**
确保你的图标文件包含以下尺寸:
- 256x256 (PNG 压缩)
- 128x128
- 64x64
- 48x48
- 32x32
- 16x16

### 6. **完整示例 - 创建正确的 ICO**
你可以使用这个在线工具专门生成符合 Electron 要求的 ICO:
- https://www.electron.build/icons
- 上传你的应用图标(建议 SVG 或大尺寸 PNG)
- 下载生成的 ICO 文件

### 7. **快速修复步骤**
1. 删除现有的 `build/icon.ico`
2. 准备一个高质量的 PNG 图片(至少 256x256)
3. 使用 https://icoconverter.com/ 转换
4. 选择 "Include the following sizes": 16,32,48,64,128,256
5. 下载并替换 `build/icon.ico`
6. 重新运行 `npm run dist` 或构建命令

如果问题仍然存在,请检查:
- ICO 文件是否损坏:尝试用图片查看器打开
- 文件路径是否正确:`C:\Users\17687\Desktop\raw-converter\build\icon.ico`
- 文件名大小写是否正确
相关推荐
XS0301062 小时前
Java 基础(十一)反射
java·开发语言
凤山老林2 小时前
Spring Boot 集成 TigerGraph 实现图谱分析技术方案
java·spring boot·后端·图谱分析·tigergraph
t***5442 小时前
Dev-C++中使用Clang调试有哪些常见错误
java·开发语言·c++
xuhaoyu_cpp_java2 小时前
Mybatis学习(四)
java·经验分享·笔记·学习·mybatis
.生产的驴2 小时前
SpringBoot 大文件分片上传 文件切片、断点续传与性能优化 切片技术与优化方案 文件高效上传
java·服务器·spring boot·后端·spring·spring cloud·状态模式
小满zs2 小时前
Next.js精通SEO第三章(TDK + OG)
前端·seo
张风捷特烈3 小时前
状态管理大乱斗#03 | Provider 源码全面评析
android·前端·flutter
灵感__idea9 小时前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
吴文周10 小时前
告别重复劳动:一套插件让 AI 替你写代码、修Bug、做测试、上生产
前端·后端·ai编程