react-native-video-frame-seekbar
TypeScript icon, indicating that this package has built-in type declarations

0.0.2 • Public • Published

react-native-video-frame-seekbar

A React Native component that allows users to seek through video frames and select a range directly on the seekbar. This library is designed to enhance video playback experience by providing a visual frame timeline and selection capability.

Features

  • Frame Seeking: Navigate through video by viewing frames on the seekbar.
  • Range Selection: Select a specific range within the video directly from the seekbar.

Installation

npm install react-native-video-frame-seekbar
# or
yarn add react-native-video-frame-seekbar

Usage

To use this component, you need to provide frame images separately. The library does not include frame extraction functionality, but you can use ffmpeg-kit-react-native for extracting frames.

Example

import React, { useCallback } from 'react';
import { Button, SafeAreaView } from 'react-native';
import VideoFrameSeekbar from 'react-native-video-frame-seekbar';

// Your app component
function App() {
    // Component logic here...
    return (
        <SafeAreaView>
            {/* Video and VideoFrameSeekbar components */}
        </SafeAreaView>
    );
}

Props

The component accepts the following props:

Prop Type Description
totalDuration number Total duration of the video in milliseconds.
currentTimeProvider () => Promise<number> Function to provide the current time of the video.
frameProvider (milliseconds: number) => string | null Function to provide the frame image source for a given time.
size number? Optional. Size of the seekbar.
onStartDrag () => void Optional. Callback when dragging starts.
onDrag (position: number) => void Optional. Callback during dragging.
onEndDrag (position: number) => void Optional. Callback when dragging ends.
select Select | null Optional. Object for range selection.
thumbsDragStart () => void Optional. Callback when thumb dragging starts.
thumbsDrag (position: number) => void Optional. Callback during thumb dragging.
thumbsDragEnd ({start: number; end: number}, target: 'START' | 'END') => void Optional. Callback when thumb dragging ends.

Note: It's recommended to use useCallback for the callback props to avoid unnecessary re-renders.

Demo

Action Demo
Seeking Seeking Demo
Range Selection Selection Demo

License

This project is licensed under the MIT License - see the LICENSE file for details.

/react-native-video-frame-seekbar/

    Package Sidebar

    Install

    npm i react-native-video-frame-seekbar

    Weekly Downloads

    14

    Version

    0.0.2

    License

    MIT

    Unpacked Size

    33.9 kB

    Total Files

    34

    Last publish

    Collaborators

    • nahooni0511