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`
- 文件名大小写是否正确
相关推荐
我是一只快乐的小螃蟹4 小时前
1.1 HashMap (JDK1.8) 源码解析
前端
ZhengEnCi5 小时前
J7A-高级Java工程师面试三道灵魂拷问-深度广度与工程素养的终极检验
java·后端
爱勇宝7 小时前
小红花成长新版:模板来了,鼓励也更容易开始
前端·后端·程序员
竹林8188 小时前
Solana前端开发:我在一个NFT铸造页面上被@solana/web3.js的Connection和Transaction签名坑了两天
前端
冬奇Lab8 小时前
每日一个开源项目(第144篇):ai-website-cloner-template - 一条命令、多 Agent 并行,把任意网站逆向成 Next.js 代码
前端·人工智能·开源
玄玄子8 小时前
webpack publicPath作用原理
前端·webpack·程序员
HduSy8 小时前
帮 Claude Code 做了个菜单栏 Token 看板,聊聊里面的一些实现逻辑
前端
用户059540174468 小时前
用了6个月LangChain,才发现AI Agent的记忆存储一直有坑——写了23个Pytest用例才彻底修好
前端·css
奶油mm9 小时前
我偷偷把公司的祖传 jQuery 项目改成了 Vue3,CTO 没发现,但全组都来抄我的代码了
前端
用户2136610035729 小时前
Vue2非父子通信与动态组件
前端·vue.js