# 🎨 PPTist > 一个基于 Vue3.x + TypeScript 的在线演示文稿(幻灯片)应用,还原了大部分 Office PowerPoint 常用功能,支持 文字、图片、形状、线条、图表、表格、视频、音频、公式 几种最常用的元素类型,每一种元素都拥有高度可编辑能力,同时支持丰富的快捷键和右键菜单,支持导出本地 PPTX 文件,支持移动端基础编辑和预览,支持 PWA。您可以在此基础上搭建自己的在线幻灯片应用。 在线体验地址:[https://pipipi-pikachu.github.io/PPTist/](https://pipipi-pikachu.github.io/PPTist/) # 👀 前排提示 1. 本项目的目标是打造一个 “在线幻灯片应用” ,而非 “低代码平台”、“H5 编辑器” 或 “图片编辑工具” 等。 2. 本项目的目标受众是有【Web 幻灯片】开发需求的开发者,提供的链接只是一个演示地址,并不能作为工具使用,也不提供任何在线服务。 如果你只是需要一个服务或工具,可以选择更优秀和成熟的产品,例如:[石墨文档](https://shimo.im/)、[金山文档](https://www.kdocs.cn/)、[Slidev](https://sli.dev/)、[revealjs](https://revealjs.com/) 等。 3. 本项目是基于 DOM 的渲染方案,好处是简单。但是相比 Canvas 渲染的方案,在复杂场景下性能会存在一定的差距,所以如果你对性能有较高的要求,本项目可能不是一个好的参考方向。 4. 这里总结了一些[常见问题](https://github.com/pipipi-pikachu/PPTist/blob/master/doc/Q&A.md),第一次提 Issues 和 PR 时,务必提前阅读此文档。 # 🚀 项目运行 ``` npm install npm run serve ``` # 📚 功能列表 ### 基础功能 - 历史记录(撤销、重做) - 快捷键 - 右键菜单 - 导出本地文件(PPTX、JSON、图片、PDF) - 导入导出特有 .pptist 文件 - 打印 ### 幻灯片页面编辑 - 页面添加、删除 - 页面顺序调整 - 页面复制粘贴 - 背景设置(纯色、渐变、图片) - 设置画布尺寸 - 网格线 - 标尺 - 画布缩放、移动 - 主题设置 - 幻灯片备注 - 幻灯片模板 - 翻页动画 - 元素动画(入场、退场、强调) ### 幻灯片元素编辑 - 元素添加、删除 - 元素复制粘贴 - 元素拖拽移动 - 元素旋转 - 元素缩放 - 元素多选(框选、点选) - 多元素组合 - 多元素批量编辑 - 元素锁定 - 元素吸附对齐(移动和缩放) - 元素层级调整 - 元素对齐到画布 - 元素对齐到其他元素 - 多元素均匀分布 - 拖拽添加图文 - 粘贴外部图片 - 元素坐标、尺寸和旋转角度设置 - 元素超链接(链接到网页、链接到其他幻灯片页面) #### 文字 - 富文本编辑(颜色、高亮、字体、字号、加粗、斜体、下划线、删除线、角标、行内代码、引用、超链接、对齐方式、项目符号、缩进、清除格式) - 行高 - 字间距 - 段间距 - 首行缩进 - 填充色 - 边框 - 阴影 - 透明度 #### 图片 - 裁剪(自定义、按形状、按纵横比) - 滤镜 - 着色(蒙版) - 翻转 - 边框 - 阴影 - 替换图片 - 重置图片 - 设置为背景图 #### 形状 - 填充色 - 边框 - 阴影 - 透明度 - 翻转 - 编辑文字 #### 线条 - 颜色 - 宽度 - 样式 - 端点样式 #### 图表(柱状图、条形图、折线图、面积图、散点图、饼图、环形图) - 数据编辑 - 背景填充 - 主题色 - 坐标系与坐标文字颜色 - 其他图表设置 - 边框 - 图例 #### 表格 - 行、列添加删除 - 主题设置(主题色、表头、汇总行、第一列、最后一列) - 合并单元格 - 单元格样式(填充色、文字颜色、加粗、斜体、下划线、删除线、对齐方式) - 边框 #### 视频 - 预览封面设置 #### 音频 - 图标颜色 - 自动播放 - 循环播放 #### 公式 - LaTeX编辑 - 颜色设置 - 公式线条粗细设置 ### 幻灯片放映 - 全部幻灯片预览 - 画笔、黑板工具 - 激光笔 - 自动放映 - 演讲者视图 ### 移动端 - 基础编辑 - 页面添加、删除、复制、备注、撤销重做 - 插入文字、图片、矩形、圆形 - 元素通用操作:移动、缩放、复制、删除、层级调整、对齐 - 元素样式:文字(加粗、斜体、下划线、删除线、字号、颜色、对齐方向)、填充色 - 基础预览 - 播放预览 # 📅 后续规划 - 组合元素重构:能够支持组合元素进行旋转、缩放、整体执行动画等; - 导入本地PPTX文件; - 将 Vue CLI 更换到 Vite 生态; # 🎯 开发 目前没有完整的开发文档,但下面这些文档可能会对你有一些帮助: - [项目目录与数据结构](https://github.com/pipipi-pikachu/PPTist/blob/master/doc/DirectoryAndData.md) - [画布与元素的基本原理](https://github.com/pipipi-pikachu/PPTist/blob/master/doc/Canvas.md) - [如何自定义一个元素](https://github.com/pipipi-pikachu/PPTist/blob/master/doc/CustomElement.md) # 💻 贡献代码 首先感谢每一位关注本项目的朋友,非常欢迎每一位对本项目感兴趣的朋友贡献代码。 ### 具体参考如下: - fork 源码,下载到本地并运行项目 - 添加/修改代码 - 对相关改动进行全面的自我测试(这非常重要) - 确认无误后提交修改到 Github - 提交 Pull Request ### 另外需要注意的是: - 每一次 Pull Request 都不应该提交过多的代码,且务必说明本次改动的具体目的,例如:修复了某个 bug、优化了某个方法 等,方便进行 Code Review; - 对于 bug 的修复,应该将本次 Pull Request 和相对应 bug 的 issue 关联起来,让别人知道该问题已经被修复; - 对于较大的新功能,你需要先提交 Issues,例如 “添加 XXX 功能”,确认该功能有被添加的必要后,再开始工作; - 对于一些主观的样式、交互逻辑调整:如颜色、图标的使用,某些预设配置的增减修改等,一般不予通过。但可以在 Issues 中进行讨论; - 其他如简单的代码优化、文档修正等,只要修改合理都会被接受。 在此感谢每一位贡献者。 # 📄 开源协议 [GPL-3.0 license](https://github.com/pipipi-pikachu/PPTist/blob/master/LICENSE) © [pipipi-pikachu](https://github.com/pipipi-pikachu)