A Streamlit component for annotating videos with drawable regions and time-range markers
Project description
Streamlit Video Annotator
A custom Streamlit component for annotating videos with drawable regions and time-range markers. Perfect for computer vision, machine learning, and video analysis applications.
Features
- Video Playback Controls: Play, pause, and scrub through videos
- Multiple Drawing Tools:
- Rectangle
- Circle
- Freedraw (path)
- Arrow
- Time-Range Annotations: Mark start and end times for each annotation
- Color Customization: Choose from multiple colors for annotations
- Comments: Add text descriptions to annotations
- Annotation Management: View, edit, and delete existing annotations
- Internationalization: Customize all UI labels for different languages
- Responsive Design: Adjustable height and responsive layout
Installation
pip install streamlit-video-annotator
Try the Demo
Clone the repository and run the demo app:
git clone https://github.com/mikaelnystrom/video_annotator.git
cd video_annotator
pip install -e .
streamlit run app.py
The demo app includes:
- Sample video (Big Buck Bunny)
- Multiple language options (English, Swedish, Spanish, French, German)
- Customizable colors and height
- Live annotation preview and data display
Quick Start
import streamlit as st
from streamlit_video_annotator import video_annotator
# Basic usage
result = video_annotator(
video_url="https://example.com/video.mp4",
height=600
)
# Handle new annotations
if result and result.get("newAnnotation"):
st.write("New annotation created:", result["newAnnotation"])
# Save to database, process, etc.
# Handle deletions
if result and result.get("deletedAnnotationId"):
st.write("Annotation deleted:", result["deletedAnnotationId"])
Advanced Usage
With Existing Annotations
from streamlit_video_annotator import video_annotator
# Load existing annotations from your database
existing_annotations = [
{
"id": "annotation-1",
"startTime": 5.0,
"endTime": 10.0,
"shape": {
"type": "rectangle",
"x": 0.2,
"y": 0.3,
"width": 0.4,
"height": 0.3,
"color": "#ff0000"
},
"comment": "Object of interest",
"createdAt": "2026-01-08T10:00:00Z"
}
]
result = video_annotator(
video_url="https://example.com/video.mp4",
existing_annotations=existing_annotations,
height=800
)
Custom Labels (Internationalization)
# Swedish labels example
swedish_labels = {
"play": "Spela",
"pause": "Pausa",
"tools": "Verktyg",
"rectangle": "Rektangel",
"circle": "Cirkel",
"freedraw": "Frihand",
"arrow": "Pil",
"color": "Färg",
"markStart": "Markera Start",
"markEnd": "Markera Slut",
"saveAnnotation": "Spara Annotering",
"cancel": "Avbryt",
"delete": "Ta bort"
}
result = video_annotator(
video_url="video.mp4",
labels=swedish_labels
)
Custom Colors
result = video_annotator(
video_url="video.mp4",
colors=["#FF5733", "#33FF57", "#3357FF", "#F033FF"]
)
API Reference
video_annotator()
video_annotator(
video_url: str,
existing_annotations: Optional[List[AnnotationData]] = None,
height: int = 800,
labels: Optional[Dict[str, str]] = None,
colors: Optional[List[str]] = None,
key: Optional[str] = None,
) -> Optional[Dict[str, Any]]
Parameters:
video_url(str): Direct URL to the video file. Supports MP4, WebM, and other browser-compatible formats. Note: YouTube URLs are not supported.existing_annotations(list, optional): List of annotation dictionaries to display.height(int, optional): Component height in pixels. Default: 600.labels(dict, optional): Custom UI labels for internationalization.colors(list, optional): List of color hex codes for annotations. Default: ['#00ff00', '#ff0000', '#0000ff', '#ffff00', '#ff00ff', '#00ffff'].key(str, optional): Unique key for the component instance.
Returns:
Dictionary with:
annotations: Full list of current annotationsnewAnnotation: Most recently added annotation (if any)deletedAnnotationId: ID of deleted annotation (if any)
Returns None if no changes occurred.
Data Structures
AnnotationData
{
"id": str, # Unique identifier
"startTime": float, # Start time in seconds
"endTime": float, # End time in seconds
"shape": ShapeData, # Shape information
"comment": str, # User comment
"createdAt": str # ISO 8601 timestamp
}
ShapeData
{
"id": str,
"type": str, # 'rectangle', 'circle', 'path', or 'arrow'
"color": str, # CSS color (e.g., '#ff0000')
# For rectangles:
"x": float, # 0-1 normalized
"y": float, # 0-1 normalized
"width": float, # 0-1 normalized
"height": float, # 0-1 normalized
# For circles:
"x": float, # Center X (0-1 normalized)
"y": float, # Center Y (0-1 normalized)
"radius": float, # 0-1 normalized
# For arrows:
"x": float, # Start X
"y": float, # Start Y
"endX": float, # End X
"endY": float, # End Y
# For paths (freedraw):
"points": [ # List of points
{"x": float, "y": float},
...
]
}
Use Cases
- Computer Vision Training: Create labeled datasets for object detection and tracking
- Video Analysis: Mark regions of interest in research videos
- Quality Assurance: Annotate defects or issues in video footage
- Sports Analysis: Mark player positions and movements
- Medical Imaging: Annotate regions in medical video footage
- Educational Content: Create interactive video lessons with annotations
Requirements
- Python >= 3.8
- Streamlit >= 1.0.0
Development
Local Development Setup
- Clone the repository
- Install dependencies:
pip install -e . cd video_annotator/frontend npm install
- For frontend development, start the dev server and set the dev mode flag:
npm start STREAMLIT_COMPONENT_DEV=true streamlit run app.py
Publishing to PyPI
This package uses GitHub Actions with PyPI trusted publishing for secure, automated releases.
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Support
If you encounter any issues or have questions, please file an issue on GitHub.
Links
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file streamlit_video_annotator-0.1.4.tar.gz.
File metadata
- Download URL: streamlit_video_annotator-0.1.4.tar.gz
- Upload date:
- Size: 164.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0dadcee3b00adbc018b83bd28816f62d068513d5440c5f0bf725f2e1c8de0384
|
|
| MD5 |
5e8d51c349f6126e21f4d4ef18f63f57
|
|
| BLAKE2b-256 |
616f17b3885e506502ff73dc3b5eecc05f0ecdb62badb1e070103fee34f616a7
|
Provenance
The following attestation bundles were made for streamlit_video_annotator-0.1.4.tar.gz:
Publisher:
publish.yml on Mikaelnystroms/video_annotator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
streamlit_video_annotator-0.1.4.tar.gz -
Subject digest:
0dadcee3b00adbc018b83bd28816f62d068513d5440c5f0bf725f2e1c8de0384 - Sigstore transparency entry: 1297755035
- Sigstore integration time:
-
Permalink:
Mikaelnystroms/video_annotator@53fdaefbe1c92aa4f65e54c5e96155e8cbe103af -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/Mikaelnystroms
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@53fdaefbe1c92aa4f65e54c5e96155e8cbe103af -
Trigger Event:
push
-
Statement type:
File details
Details for the file streamlit_video_annotator-0.1.4-py3-none-any.whl.
File metadata
- Download URL: streamlit_video_annotator-0.1.4-py3-none-any.whl
- Upload date:
- Size: 171.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8dfed0279f645cde88e7027b0a0f372d073a1f039e3af4b43da7e529426ca65b
|
|
| MD5 |
6b95d099b90752fe34ed478db4701fbb
|
|
| BLAKE2b-256 |
9c6d81fc432bfb79c0919fad64b2508342f21b4ea4559c371397fb3a46bc48a9
|
Provenance
The following attestation bundles were made for streamlit_video_annotator-0.1.4-py3-none-any.whl:
Publisher:
publish.yml on Mikaelnystroms/video_annotator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
streamlit_video_annotator-0.1.4-py3-none-any.whl -
Subject digest:
8dfed0279f645cde88e7027b0a0f372d073a1f039e3af4b43da7e529426ca65b - Sigstore transparency entry: 1297755100
- Sigstore integration time:
-
Permalink:
Mikaelnystroms/video_annotator@53fdaefbe1c92aa4f65e54c5e96155e8cbe103af -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/Mikaelnystroms
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@53fdaefbe1c92aa4f65e54c5e96155e8cbe103af -
Trigger Event:
push
-
Statement type: