Giter Site home page Giter Site logo

linecode / shaka-player-embedded Goto Github PK

View Code? Open in Web Editor NEW

This project forked from shaka-project/shaka-player-embedded

0.0 1.0 0.0 6.59 MB

Shaka Player in a C++ Framework

License: Apache License 2.0

Makefile 0.07% Python 9.04% Shell 0.10% Objective-C 6.08% C++ 76.66% C 0.13% Objective-C++ 3.16% JavaScript 4.77%

shaka-player-embedded's Introduction

Shaka Player Embedded

Shaka Player Embedded is a framework that runs Shaka Player in native (C++) apps. This gives a cross-platform interface to Shaka Player allowing native apps to use the player. Your native apps can now be built with the same features, behavior, and API as your Shaka-based web apps.

In addition to the C++ API, we provide a high-level wrapper for iOS called ShakaPlayerView which can be used from either Objective-C or Swift.

See our documentation and iOS tutorial.

Platform support

We only support iOS at this time, but other platforms could be added.

Because many on our team use Linux, there is a Linux port included to make it easier to work on non-iOS-specific features. Linux is not, however, a first-class target platform at this time.

Release status

This project is currently in an open beta. We would love to have your feedback on what we've built, but we are not yet feature-complete for v1.0. As such, ABI compatibility is not yet guaranteed.

Announcements & Issues

If you are interested in release and survey announcements, please join our mailing list: https://groups.google.com/forum/#!forum/shaka-player-users

This is a very low-volume list that only admins of the project may post to.

For issues or to start a discussion, please use github issues: https://github.com/google/shaka-player-embedded/issues

Widevine support

Widevine support requires the Widevine CDM for iOS, which must be obtained separately from Widevine, under license. The Widevine CDM is not open-source.

We don't have an exact release date yet, but the Widevine CDM for iOS should be available by the time we tag v1.0 of Shaka Player Embedded.

Setting up for development

  1. The source is managed by Git at https://www.github.com/google/shaka-player-embedded. You will need these tools available on your development system:
  • Git v1.7.5+
  • Python v2.7
    • Requires installing package enum34
  • autoconf 2.57+
    • m4
    • automake 1.7+
    • perl

This does not require a C++ compiler as it uses a pre-compiled version of clang downloaded from Google Cloud Storage. However, it does require a C++11 compatible C++ library (installed with most compilers, e.g. gcc).

  1. Install Chromium depot tools, which contains ninja and other required tools. See https://www.chromium.org/developers/how-tos/install-depot-tools for details.

  2. Get the source

git clone https://github.com/google/shaka-player-embedded.git
cd shaka-player-embedded

We use git submodules to manage third-party dependencies. You can run git submodule update (or pass --recurse-submodules to git clone) to download all the submodules; or you can wait and have the configure script download only those you need.

  1. Configure and Build

You need to run configure to setup configuration settings. You can pass --help to see some of the options you can use. We don't support in-tree builds; you need to run configure in another directory.

Once configure is done, you can build using build.py. There is a Makefile that will run the script for you if you prefer.

mkdir foo
cd foo
../configure
make
  1. Copy the shared library

Once it is built, you can use the resulting shared library.

On iOS, there will be a ShakaPlayerEmbedded.framework folder that you use; there is also a ShakaPlayerEmbedded.FFmpeg.framework bundle that you need to include in your app, but you shouldn't use it directly since we don't maintain ABI for it.

On other platforms, there is a libshaka-player-embedded.dylib or a libshaka-player-embedded.so file you can use. Like iOS, there is a libshaka-player-embedded.ffmpeg.* file you need to include too.

If you are using a custom --eme-impl, you need to copy the respective shared libraries too, if needed.

Running the checks

If you intend to send a pull-request, you need to ensure the code complies with style guidelines. This is done with the shaka/tools/presubmit.py script, which can be run with make check.

To run all the checks, you also have to have clang-tidy installed. It needs to be installed on PATH, or you can pass --clang-tidy to the script to tell it where to find the binary.

shaka-player-embedded's People

Contributors

joeyparrish avatar nitro404 avatar themodmaker avatar theodab avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.