/poster-design

一款漂亮且功能强大的在线图片设计器,仿稿定设计,适用于多种场景:海报生成、电商产品图、文章长图、视频/公众号封面等,让设计更简单!A beautiful online image designer, suitable for various scenarios like generate posters, making design easier.

Primary LanguageJavaScriptMIT LicenseMIT

在线体验 | 中文文档网站 | 架构及目录说明


迅排设计

一款漂亮且功能强大的在线海报图片设计器,仿稿定设计。

适用于海报图片生成、电商分享图、文章长图、视频/公众号封面等多种场景。

  • 丝滑的操作体验,丰富的交互细节,基础功能完善
  • 采用服务端生成图片,确保多端出图统一性,支持各种 CSS 特性
  • 简易 AI 抠图工具,上传图片一键去除背景
  • 技术栈:Vue3 、Vite2 、Vuex 、ElementPlus
  • 图片生成:Puppeteer、Express

支持功能

  • 导入 PSD 文件解析成模板、在线导出图片下载
  • 元素拖拽、组合、缩放、层级调整、对齐等操作。
  • 图片素材插入、替换、裁剪,图片容器等功能。
  • SVG 素材颜色、透明度编辑,文字花字组合。
  • 画布自定义尺寸、滚轮缩放、自适应画布
  • 吸附对齐、辅助引导线、标尺功能。
  • 键盘快捷键、右键菜单快捷操作,复制删除等常用操作。
  • 风格二维码编辑,支持单色、渐变、自定义 logo 等。
  • 图层操作,支持拖拽变更层级。
  • 颜色调色板,原生级取色器颜色吸管(Chrome)。

拉取源码

环境需求:Node.js v16.18 以上版本

git clone https://github.com/palxiao/poster-design.git
cd poster-design

安装依赖

npm run prepared

网络太慢?尝试运行:npm config set registry https://registry.npmmirror.com 再安装依赖

本地运行

npm run serve

将会同时运行前端界面与图片生成服务(3000端口为前端项目,7001端口为图片生成服务):

如果你本地没有成功启动两个服务,可能是 win 系统不兼容,手动进 screenshot 目录安装依赖(npm install)并启动服务(npm run dev) 或者使用 VSCode 自带的终端来运行命令,注意不要使用 CMD。

打包

前端页面 截图服务
npm run v-build /screenshot/README.md

截图服务

代码位于 /screenshot 目录下,查看接口 API 文档

打包注意事项与服务器配置相关请进入该目录下查看 README 文件说明。

截图服务 Docker 部署

可以通过 Docker 运行一个带 Linux 浏览器的容器,参考说明

服务端

根据你的具体场景自行实现,目前本项目中的所有后端接口可参考:接口 API 文档

抠图服务部署

docker run -d -p 5000:5000 --restart always danielgatis/rembg s

感谢

项目还使用或参考了一些优秀开源项目,包括但不限于:

  • moveable: 提供了画布中选择、拖动缩放等能力
  • html2canvas: 前端生成图片兜底方案
  • qr-code-styling: 风格化二维码
  • rembg: 图片删除背景,使用 u2net 预训练模型

Q&A

Q:项目可以直接部署上线吗?

A:本项目支持本地运行体验完整功能,如需部署到生产,需自行开发配套的后端接口,自行部署图片生成服务,部署方法参考项目中的文档。

Q:后端源码不开源吗?

A:考虑到服务端的开发语言、数据库类型都可能不尽相同,且本项目中实现简单,代码不具备参考性,所以暂时只提供接口 API 文档。(目前仅是一些增删改查)

其它

项目最早使用 Vue2 开发,后改用 Vue3 重构,所以有部分代码混合了 Options 写法。

或许你在工作中有类似的需求,或许你也对开发编辑器感兴趣,希望这个项目能给到你一些微薄帮助!

目前本项目也还在迭代中,有很多的不足,我也是一边学习一边成长。开源不易,希望看到这里的你可以给本项目点个 Star 支持一下~

Star History Chart

部分迭代计划:

  • P1: 文字特效属性编辑面板开发
  • P1:字体抽取功能
  • P1:PSD 解析重构(涉及基础库更换)

-> 完整后续迭代计划文档

LICENSE

MIT License