VideoJS integration
Project description
Whitebox Plugin - VideoJS
This is a plugin for whitebox that provides VideoJS integration, including WHEP (WebRTC) streaming support.
Installation
Simply install the plugin to whitebox:
poetry add whitebox-plugin-videojs
WHEP Tech - WebRTC Streaming
This plugin includes a custom Video.js Tech for WHEP (WebRTC-HTTP Egress Protocol) streaming. WHEP enables ultra-low-latency video playback from WebRTC-capable media servers.
What is WHEP?
WHEP (WebRTC-HTTP Egress Protocol) is a standardized protocol for receiving WebRTC streams. It simplifies WebRTC consumption by using HTTP for signaling:
- Client sends an SDP offer via HTTP POST to the WHEP endpoint
- Server responds with an SDP answer
- ICE candidates are exchanged (trickle ICE supported)
- WebRTC peer connection is established
- Media flows over WebRTC (UDP/SRTP)
Unlike traditional WebRTC which requires custom signaling servers, WHEP uses simple HTTP - making it easy to integrate with any media server that supports it.
Architecture Overview
┌─────────────────────────────────────────────────────────────────────────────┐
│ STREAMING PIPELINE │
└─────────────────────────────────────────────────────────────────────────────┘
┌──────────────┐ ┌─────────────────┐ ┌─────────────────┐
│ Insta360 │ │ FFmpeg │ │ SRS Server │
│ Camera │────▶│ (transcode) │────▶│ (media server) │
│ │WiFi │ │RTMP │ │
└──────────────┘ │ • Dual fisheye │ │ • RTMP ingest │
│ → equirect │ │ • WebRTC/WHEP │
│ • H.264 encode │ │ egress │
└─────────────────┘ └────────┬────────┘
│
│ WHEP (HTTP + WebRTC)
▼
┌──────────────────────────────────────────────────────────────────────────────┐
│ BROWSER │
│ ┌─────────────────┐ ┌─────────────────┐ ┌──────────────────┐ │
│ │ WHEP Tech │ │ Video.js │ │ Pannellum │ │
│ │ (whep-tech.js) │────▶│ Player │────▶│ 360 Viewer │ │
│ │ │ │ │ │ │ │
│ │ • SDP exchange │ │ • <video> with │ │ • WebGL canvas │ │
│ │ • ICE handling │ │ srcObject │ │ • Equirectangular│ │
│ │ • Reconnection │ │ • Playback ctrl │ │ projection │ │
│ └─────────────────┘ └─────────────────┘ └──────────────────┘ │
└──────────────────────────────────────────────────────────────────────────────┘
Key Components
1. WHEP Tech (whep-tech.js)
Custom Video.js Tech that handles WebRTC playback:
// Usage
const player = videojs('my-video', {
techOrder: ['whep'], // Use WHEP tech
sources: [{
src: 'https://srs-server/rtc/v1/whep/?app=live&stream=livestream',
type: 'application/whep' // MIME type triggers WHEP tech
}]
});
Features:
- Automatic SDP offer/answer exchange
- Trickle ICE candidate handling
- Connection state management with events
- Auto-reconnection with exponential backoff
- Graceful cleanup on dispose
Events emitted:
whep:connecting- Starting connectionwhep:streaming- Media flowingwhep:reconnecting- Connection lost, retryingwhep:error- Connection failed
2. Integration with Pannellum (360 Video)
The whitebox-plugin-pannellum provides 360-degree video rendering. It detects WebRTC streams via srcObject:
// In Pannellum360Video.jsx
const isWebRTC = !!videoEl?.srcObject;
if (isWebRTC) {
// Direct Pannellum initialization - pass video element as texture
pannellum.viewer(container, {
type: "equirectangular",
panorama: videoEl, // Video element with srcObject
dynamic: true,
});
} else {
// Regular video URL - use videojs-pannellum plugin
player.pannellum(config);
}
Why the distinction?
- WebRTC uses
srcObject(MediaStream) notsrc(URL) - The videojs-pannellum plugin doesn't handle
srcObject - Direct Pannellum init passes the video element as a WebGL texture source
Connection Flow
1. Player initialized with WHEP source
└─▶ WhepTech.setSrc() called
2. Create RTCPeerConnection
└─▶ Add transceiver for video (recvonly)
└─▶ Create SDP offer
3. HTTP POST offer to WHEP endpoint
└─▶ Server returns SDP answer
└─▶ setRemoteDescription(answer)
4. ICE candidate gathering
└─▶ Local candidates sent via PATCH
└─▶ Remote candidates from Link headers
5. Connection established
└─▶ ontrack fires with MediaStream
└─▶ video.srcObject = stream
└─▶ Emit 'whep:streaming'
6. On disconnect
└─▶ Exponential backoff retry
└─▶ Emit 'whep:reconnecting'
Frame Detection for 360 Video
WebRTC streams require special handling for 360 rendering. We must wait for actual video frames before initializing Pannellum:
// waitForVideoFrame() in Pannellum360Video.jsx
if ("requestVideoFrameCallback" in videoEl) {
// Chrome 83+, Firefox 130+ - fires when frame is ready
videoEl.requestVideoFrameCallback(checkFrame);
} else {
// Fallback: poll videoWidth/videoHeight
setInterval(checkDimensions, 100);
}
This prevents the "black sphere" issue where Pannellum initializes before any video data arrives.
Additional Instructions
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 whitebox_plugin_videojs-0.1.5.tar.gz.
File metadata
- Download URL: whitebox_plugin_videojs-0.1.5.tar.gz
- Upload date:
- Size: 22.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.0.dev0 CPython/3.14.4 Linux/6.1.75+
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fed433f864babc43b4182d1a253fc628966d796a2a410c287fd6449a44056c5a
|
|
| MD5 |
041b1d09c3d323a8d80912a80a56ed34
|
|
| BLAKE2b-256 |
027b230838c5e0f4d348df11956ec51644a96914e0e8e93329440474ffe63c85
|
File details
Details for the file whitebox_plugin_videojs-0.1.5-py3-none-any.whl.
File metadata
- Download URL: whitebox_plugin_videojs-0.1.5-py3-none-any.whl
- Upload date:
- Size: 24.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.0.dev0 CPython/3.14.4 Linux/6.1.75+
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
47d38b1aebf9dc582289e5e720463bcd2b77301294b78eb826fc4826428646c7
|
|
| MD5 |
6ee52ad749e3be391a1e90b6147d38f4
|
|
| BLAKE2b-256 |
d1053d71e08ce1571fe2e207244841e61c3f48bb85f9f5ebe1c3ebbbc2687554
|