Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hallee9000/heron-handoff
A Figma handoff tool, support offline exporting.
https://github.com/hallee9000/heron-handoff
figma handoff
Last synced: about 5 hours ago
JSON representation
A Figma handoff tool, support offline exporting.
- Host: GitHub
- URL: https://github.com/hallee9000/heron-handoff
- Owner: hallee9000
- License: agpl-3.0
- Created: 2019-11-25T08:33:13.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-08-24T02:56:49.000Z (5 months ago)
- Last Synced: 2025-01-26T22:30:15.711Z (about 6 hours ago)
- Topics: figma, handoff
- Language: JavaScript
- Homepage: https://heron.design
- Size: 19.9 MB
- Stars: 336
- Watchers: 11
- Forks: 26
- Open Issues: 20
-
Metadata Files:
- Readme: README-CN.md
- License: LICENSE
Awesome Lists containing this project
README
# Figma Heron Handoff
> [!WARNING]
> 该插件目前处于维护状态,不再更新,如有更多需求可以考虑使用[月维](https://moonvy.com/?homepage)Heron Handoff 可以帮助你生成带有设计标注的文件,方便交付给开发。这个项目是设计标注模板,你需要先去[这里](https://www.figma.com/community/plugin/830051293378016221/Heron-Handoff)安装插件使用。
- 在线体验: https://hallee9000.github.io/heron-handoff?demo=true
- 插件代码: https://github.com/hallee9000/heron-handoff-figma-plugin## 使用方式
### 1. 安装插件
前往 [Heron Handoff Plugin](https://www.figma.com/community/plugin/830051293378016221/Heron-Handoff) 页面或搜索 Heron handoff 进入插件页面点击安装。### 2. 在文件内打开插件
打开一个设计文件,在画布中右击,依次选取 plugin -> Heron Handoff,即可启动插件。### 3. 选择 Frame
插件会罗列该文件所有 page 中的每一个第一级 Frame(可以理解为画板)。你可以在里面选择需要导出标注的 Frame,然后点击开始导出。下方还有一个**导出组件列表选项**,可以单独导出组件列表。如果你像我一样(如下图)把组件都放在一个 Frame 内,就不需要勾选它了。
### 4. 选择切图
插件会自动识别到文件中带有 export 的图层(下图右侧面板最下方),将其罗列在切图列表中,你可以选择需要导出的切图。切图的命名会自动按照你所选择的倍数和填写的后缀命名,如果有重复会自动在末尾加数字,并用红色惊叹号特别标注。万事俱备,点击下面的按钮开始导出。
### 5. 查看标注文件
在上一步点击生成设计标注之后,会导出一个压缩包文件到本地,解压后打开里面的 index.html 就可以查看标注啦。因为每一次导出标注文件都是离线的,所以如果你的设计有改动并不会自动同步,需要你重新导出。## 作为模块导入
此应用已被发布至 [NPM](https://www.npmjs.com/package/heron-handoff),如果你想基于此做二次开发也可以直接从 NPM 导入这个模块。首先,安装模块。
```bash
yarn add heron-handoff
```接着,导入模块并配置属性。
```jsx
import Canvas from 'heron-handoff'const settings = {
convention: 1,
exportWebP: false,
includeComponents: false,
language: "zh",
platform: 1,
remBase: 16,
resolution: 0,
unit: 2
}
const pagedFrames = {
"755:1494": {
"name": "Plugin",
"frames": [
{
"id": "2590:442",
"name": "settings",
"image": {
"url": "/mock/2590-442.png"
}
}
]
},
"755:1493": {
"name": "Dashboard",
"frames": [
{
"id": "2941:26",
"name": "file detail",
"image": {
"url": "/mock/2941-26.png"
}
}
]
}
}
const exportSettings = [{
contentsOnly: true,
fileName: "[email protected]",
format: "PNG",
id: "I2590:136;2731:1",
image: {url: "/mock/exports/[email protected]"},
name: "icon",
suffix: ""
}]
const fileData = {
name: 'Handoff design',
document: {},
styles: {}
}export default function () {
return (
{ console.log('Back icon clicked.') }}
/>
)
}
```这些属性的数据是从 [heron-handoff-plugin](https://github.com/hallee9000/heron-handoff-figma-plugin) 导入的,你可以参考其源码来配置你的属性。
## 常见问题
### 如何交付切图?
插件只会识别每一个在右侧加了 Export 的元素,Slice 功能只是为了兼容 Sketch 导入的文件,本插件不会将其作为切图对待,所以如果 Slice 图层没有在右侧添加 Export 也不会被识别为切图。此外,Main 组件添加了 Export,它的实例(Instance)不会被自动添加 Export,也不会被识别为切图。也就是说,你给文件中几个图层加了多少 Export,就会有多少切图。
比如下图,会生成 `[email protected]` 和 `thumb-up.svg`(该图层名字为 `thumb-up`)两个切图。
### 为什么有时候会错位?
标注错位一般是由于两种原因导致的:
1. 有一些元素进行了旋转或者翻转操作。
2. 第一级 Frame(画板)内的元素超出了,但是 Frame 没有勾选裁切内容(Clip content)。
目前第一种情况还无法解决,请尽量避免,第二种情况请一定要给第一级 Frame 勾选一下该选项。## 赞助捐赠
Figma Heron Handoff 代码全部开源,如果对你有帮助,可以扫码支持我一下。>该项目使用 [Create React App](https://github.com/facebook/create-react-app).