1.0.0 • Published 5 years ago

vue-slider-gif-maker v1.0.0

Weekly downloads
4
License
MIT
Repository
github
Last release
5 years ago

vue-slider-gif-maker

基于gifvue-slider-component二次封装的拖拽截图生成gif的vue组件

Todo

  • 拖拽截图
  • 生成gif
  • 手动拖动选择画面截取
  • 选择范围后自动截取
  • 继承vue-slider-component入参
  • 支持gif帧率入参

Run example

npm i

npm run dev

Use it

由于组件需要依赖放置于静态资源目录下的worker文件。安装后将会自动收到copy文件到本地静态资源目录的提示。

或者也可手动获取本repositorie中asset目录下的gif.worker.js文件,并放置在本地项目的静态资源目录下。

为什么需要有一个worker文件,点击这里了解更多

npm install vue-slider-gif-maker --save

// 按照提示输入本地应用的静态资源目录,请以提示的路径为为基础。 What`s your static asset dir(Current dir is "/current")? Please base on current dir!:public

"gif.worker.js" had copied to " /current/public"

```html
<template>
  <div>
    <vue-slider-gif-maker maker-type="drop" href=""></vue-slider>
  </div>
</template>
<script>
import vueSliderGifMaker from 'vue-slider-gif-maker'

自动截取生成GIF

mergeGifVideo

最终输出结果

gifResult

Props

Props类型默认值描述参数描述
hrefString""视频链接地址
maker-typeStringdrop截取方式drop:拖拽范围后自动截取;click:选择画面截取
vue-slider-configObject{}vue-slider组件的参数透传vue-slider组件入参

Methods

Methods使用条件入参效果返回
screenShotmaker-type='click'截图{img:(Img DOM),blob:(图片二进制内容)}
mergeGifmaker-type='click'https://github.com/jnordberg/gif.js生成gif{gif:(Img DOM),blob:(图片二进制内容)}
autoMergeGifmaker-type='drop'{frame:截取时间段内取几张图片}其他参数同上选定区间后自动截图并生成gif {gif:(Img DOM),blob:(图片二进制内容),imgMap:(ImgDom的Array)}