Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/theoplayer/flutter-theoplayer-sdk
THEOplayer Flutter SDK
https://github.com/theoplayer/flutter-theoplayer-sdk
android flutter html5 ios theoplayer video-player web
Last synced: 15 days ago
JSON representation
THEOplayer Flutter SDK
- Host: GitHub
- URL: https://github.com/theoplayer/flutter-theoplayer-sdk
- Owner: THEOplayer
- License: mit
- Created: 2023-11-29T13:13:52.000Z (about 1 year ago)
- Default Branch: develop
- Last Pushed: 2024-10-24T16:01:59.000Z (3 months ago)
- Last Synced: 2024-10-25T05:35:15.806Z (3 months ago)
- Topics: android, flutter, html5, ios, theoplayer, video-player, web
- Language: Dart
- Homepage: https://theoplayer.com
- Size: 10.7 MB
- Stars: 12
- Watchers: 3
- Forks: 0
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
# THEOplayer Flutter SDK
## Table of Contents
1. [Overview](#overview)
2. [Prerequisites](#prerequisites)
3. [How to use these guides](#how-to-use-these-guides)
4. [Features](#features)
5. [Getting Started](#getting-started)
6. [Contributing](#contributing)## Overview
The `theoplayer` package provides a `THEOplayer` component supporting video playback on the
following platforms:- Android, Android TV & FireTV
- iOS
- HTML5 (web, mobile web)
- **OUT OF SCOPE**: Tizen and WebOS (smart TVs, set-top boxes and gaming consoles).This document covers the creation of a minimal app including a `THEOplayer` component,
and an overview of the accompanying example app.It also gives a description of the properties of the `THEOplayer` component, and
a list of features and known limitations.## Prerequisites
For each platform, a dependency to the corresponding THEOplayer SDK is included through a dependency manager:- Gradle & Maven for Android
- Cocoapods for iOS
- npm for Web **_the initial version of the SDK relies on a local copy of `THEOplayer.chromeless.js` (and additional modules), so adding it manually is required!_
In order to use one of these THEOplayer SDKs, it is necessary to obtain a valid THEOplayer license for that specific platform,
i.e. HTML5, Android, and/or iOS. You can sign up for a THEOplayer SDK license through [our portal](https://portal.theoplayer.com/).If you have no previous experience in Flutter, we encourage you to first explore the
[Flutter Documentation](https://docs.flutter.dev/),
as it gives you a good start on one of the most popular app development frameworks.## How to use these guides
These are guides on how to use the THEOplayer Flutter SDK in your Flutter project(s) and can be used
linearly or by searching the specific section. It is recommended that you have a basic understanding of how
Flutter works to speed up the way of working with THEOplayer Flutter SDK.## Features
Depending on the platform on which the application is deployed, a different set of features can be available.
If a feature is missing, additional help is needed, or you need to extend the package,
please reach out to us for support.Feature
Android, Android TV, Fire TV
Web
iOS, tvOSStreaming
MPEG-DASH (fmp4, CMAF), HLS (TS, CMAF), Progressive MP4, MP3
HLS (TS, CMAF), Progressive MP4, MP3Content Protection
Widevine
Widevine, Fairplay
FairplayDRM Connectors
Through hooking into native implementation… check guides!Subtitles & Closed Captions
In-stream subtitles supported by the platform.
Note: If you use Texture-based rendering (SURFACE_TEXTURE and SURFACE_PRODUCER) on Android, you need to implement the subtitle rendering based on track events.Metadata
Event stream, emsg, ID3, EXT-X-DATERANGEFullscreen
Supported throughplayer.presentationMode
APIPicture-in-Picture
Supported throughplayer.allowAutomaticPictureInPicture
API
Supported throughplayer.presentationMode
API
Supported throughplayer.allowAutomaticPictureInPicture
APIAdvertising Integration
Coming soon… (Can not wait? Check our in-app integration branches)Analytics Connectors
Coming soon…Cast Integration
Coming soon… (Can not wait? Check our in-app integration branches)THEOlive
Coming soon… (Can not wait? You can still use our THEOlive SDK)
Supported throughTHEOliveSource
andplayer.theolive
API
Coming soon… (Can not wait? You can still use our THEOlive SDK)## Getting Started
This section starts with creating a minimal demo app that integrates the `theoplayer` package,
followed by an overview of the available properties and functionality of the THEOplayer component.
A minimal example application including a basic user interface and demo sources is included in [this repository](https://github.com/THEOplayer/flutter-theoplayer-sdk/tree/main/flutter_theoplayer_sdk/flutter_theoplayer_sdk/example),
and discussed in the next section. Finally, an overview of features, limitations and known issues is listed.- [Creating a minimal demo app](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/creating-minimal-app.md)
- [Getting started on Android](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/creating-minimal-app.md#getting-started-on-android)
- [Getting started on iOS](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/creating-minimal-app.md#getting-started-on-ios)
- [Getting started on Web](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/creating-minimal-app.md#getting-started-on-web)
- [The THEOplayer component](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/theoplayer-component.md)
- Knowledge Base
- [Using custom DRM connectors](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/custom_drm.md)
- [Limitations and known issues](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/limitations.md)
- [Picture-in-picture](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/picture-in-picture.md)
- [Custom branches](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/doc/custom-branches.md): custom forks to expose native functionality## Contributing
All contributions are welcomed!
Please read our [Contribution guide](https://github.com/THEOplayer/flutter-theoplayer-sdk/blob/main/CONTRIBUTING.md) on how to get started!