dodu2014 / timeSlider

time-slider是一个基于原生js打造的视频回放时间轴组件,本组件适用于任何框架。

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Introduce:

video-time-slider是一个基于原生js打造的视频回放时间轴组件,本组件适用于任何框架。 image text

demonstration

打开demo.html就可以直接演示操作了。

Install:

npm install video-time-slider --save

Usage:

const timeSliderInstance = initTimeSlider(el,config)

React Hook:

import {useEffect} from 'react';
import initTimeSlider from 'video-time-slider';
function App() {
  useEffect(()=>{
    initTimeSlider('#timeSlider',{
      curDaytimeChunkArray:['012200-023000-C','002200-003000-B','001200-002000-A','000000-001000-A'], // 时间段
      presentSeconds:20,// 当天开始播放秒数
      timeChunkType:{ // 时间段类型
        A:'red',
        B:'yellow',
        C:'blue'
      },
      speed:1, // 速度
      isInitialPlay:true, // 是否初始化后进行播放
     })
  })
  return (
    <>
     <div id='timeSlider'></div>
    </>
  );
}
export default App;

Vue3:

<script setup lang="ts">
import initTimeSlider from 'video-time-slider';
import { nextTick } from 'vue';
nextTick(()=>{
  initTimeSlider('#timeSlider',{
      curDaytimeChunkArray:['012200-023000-C','002200-003000-B','001200-002000-A','000000-001000-A'],
      presentSeconds:20,
      timeChunkType:{
        A:'red',
        B:'yellow',
        C:'blue'
      },
      speed:1,
      isInitialPlay:true,
  })
})
</script>
<template>
   <div id='timeSlider'></div>
</template>

Script:

<script src="../dist/main.js"></script>
<script>
initTimeSlider('#timeSlider',{
  curDaytimeChunkArray:['012200-023000-C','002200-003000-B','001200-002000-A','000000-001000-A'],
  presentSeconds:20,
  timeChunkType:{
    A:'red',
    B:'yellow',
    C:'blue'
  },
  speed:1,
  isInitialPlay:true,
 })
</script>

config:

参数 描述 类型 可选值 默认值
curDaytimeChunkArray 当天的时间块,每一项格式为startTime-endTime-type Array 必填 --
presentSeconds 开始播放时间,这个时间为秒数,而且必须在curDaytimeChunkArray时间段内 number 必填 --
timeChunkType 时间段类型,属性名为类型与curDaytimeChunkArray对应,属性值为渲染到时间轴上的颜色 object 必填 --
speed 时间线滚动的速率 number -- 1
isInitialPlay 是否初始化后进行播放,如果设置为false,可以调用实例的timeLinePlay进行播放 boolean -- false

Method(instance):

timeLinePlay

开始播放

timeLineStop

停止播放

setTimeLineLeft

外部控制时间线移动时调用。

instance.presentSeconds = 30; // 设置时间线的时间
instance.setTimeLineLeft()   // 设置时间线的位置

版本 1.0.0

  • 第一版本
  • 支持时间轴精度调整
  • 支持时间线滚动跳动以及判断时间线移动的移动位置的合理性
  • 支持以时间线为中心进行缩放时间轴
  • 支持不同类型的时间段
  • 支持时间轴的点击和拖动

About

time-slider是一个基于原生js打造的视频回放时间轴组件,本组件适用于任何框架。


Languages

Language:JavaScript 78.3%Language:CSS 19.4%Language:HTML 2.3%