迅排设计
项目作者: 茶无味
项目网址: https://xp.palxp.cn
入驻时间: 2023-09-12
开源许可证: MIT

项目描述

一款漂亮且功能强大的在线图片设计器,仿稿定设计,适用于多种场景:海报生成、电商产品图、文章长图、视频/公众号封面等。迅速排版,轻松创意,让设计更简单!

项目介绍

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


迅排设计

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

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

  • 丝滑的操作体验,丰富的交互细节,基础功能完善
  • 采用服务端生成图片,确保多端出图统一性,支持各种 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。

合成图片时本地会启动一个 Chrome 浏览器实例。

打包

前端页面 截图服务
npm run v-build cd sreenshot
npm run build

截图服务

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

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

截图服务 Docker 部署

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

服务端

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

抠图服务部署

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

感谢

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

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

Q&A

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

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

Q:后端源码不开源吗?

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

其它

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

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

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

Star History Chart

后续部分迭代计划记录

LICENSE

MIT License

百度统计