tnfe / shida

《视搭》是一个视频可视化搭建项目。您可以通过简单的拖拽方式快速生产一个短视频,使用方式就像易企秀或Maka 等 h5 搭建工具一样的简单,仅抛砖引玉希望您喜欢。
Apache License 2.0
581 stars 148 forks source link

介绍

《视搭》是一个视频可视化搭建项目。您可以通过简单的拖拽方式快速生产一个短视频,使用方式就像易企秀或百度 H5 等 h5 搭建工具一样的简单。目前行业内罕有关于视频可视化搭建的开源项目,《视搭》是一个相对比较完整的开源项目,仅抛砖引玉希望您喜欢。

《视搭》的后端视频合成部分是基于FFCreatorhttps://github.com/tnfe/FFCreator这个库开发的,FFCreator 是一个基于 node.js 的轻量、灵活的短视频加工库。您只需要添加几张图片或视频片段再加一段背景音乐,就可以快速生成一个很酷的视频短片。

《视搭》前端部分 fork 自quark-h5项目开发,本项目未做太多扩展。quark-h5 是一个很棒的 h5 搭建开源工具,架构合理、代码比较清晰易读,感谢作者。

项目预览:

工程目录

|-- client                  --------前端项目界面代码
    |--common                   --------前端界面对应静态资源
    |--components               --------组件
    |--config                   --------配置文件
    |--eventBus                 --------eventBus
    |--filter                   --------过滤器
    |--mixins                   --------混入
    |--pages                    --------页面
    |--router                   --------路由配置
    |--store                    --------vuex状态管理
    |--service                  --------axios封装
    |--App.vue                  --------App
    |--main.js                  --------入口文件
    |--permission.js                    --------权限控制
|-- server                  --------服务器端项目代码
    |--confog                   --------配置文件
    |--controller               --------数据库链接相关
    |--extend                   --------框架扩展
    |--model                    -------Schema和Model
    |--middleware               --------中间件
    |--core                     --------Koa MVC实现自动加载核心文件
    |--views                    --------ejs页面模板
    |--public                   --------静态资源
    |--router.js                --------路由
    |--app.js                   --------服务端入口
|-- common                  --------前后端公用代码模块(如加解密)
|-- engine-template                 --------页面模板引擎,使用webpack打包成js提供页面引用
|-- config.json                     --------配置文件

编辑器整体设计

视频合成核心

开发调试

启动 mongodb

安装依赖

npm i

启动前端并开启 watch 模式

此模式下会开启热更新

npm run watch-publish

启动服务端

npm run dev-server
启动完访问http://localhost:4000 就可以看到工程页面了

先注册用户, 然后登陆体验操作

发布部署

启动 mongodb

需要全局安装 pm2

npm install pm2 -g

启动命令

npm run publish && npm run start

License

Apache License 2.0