- ストリーミング: Griffith はストリーミングを簡単にします。ビデオフォーマットは mp4 や hls にかかわらず、Griffith は Media Source Extension (MSE) を使ってセグメントをロードすることができます。
- 拡張性: Griffith は React アプリにビデオ機能をサポートすることを簡単にします。React に基づいていない場合は、ブラウザで直接使用するための UMD(Universal Module Definition)もサポートされています。
- 信頼性: Griffith は Zhihu の Web およびモバイル Web で広く使用されています。
yarn add griffith
import Player from 'griffith'
const sources = {
hd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_hd.mp4',
},
sd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_sd.mp4',
},
}
render(<Player sources={sources} />)
ノート: Griffith は SSR アプリを対応できません
<script src="https://unpkg.com/griffith-standalone/dist/index.umd.min.js"></script>
const sources = {
hd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_hd.mp4',
},
sd: {
play_url: 'https://zhstatic.zhihu.com/cfe/griffith/zhihu2018_sd.mp4',
},
}
Griffith.createPlayer(element).render({sources})
Griffith は Yarn workspace と Lerna を使っている Monorepo です。
packages/griffith
: コーアライブラリ
packages/griffith-message
: クロスドメイン通信のヘルパーpackages/griffith-utils
: 他のユーティリティ
packages/griffith-mp4
: MP4 プラグインは MediaSource API を使っています。packages/griffith-hls
: HLS プラグインは hls.js を使っています。
example
: サンプル例とデモpackages/griffith-standalone
: 全部のモジュールを含めての UMD バージョン、ブラウザーで直接に使用できます。
webpack のようなビルドツールはデフォルトで griffith-mp4
と packages/griffith-hls
を含みます。ビルド時に環境値を設定して、プラグインを除外することで、バンドルを小さくすることができます。
webpack を使いる場合, DefinePlugin が使えます。
const {DefinePlugin} = require('webpack')
module.exports = {
plugins: [
new DefinePlugin({
__WITHOUT_HLSJS__: JSON.stringify(true), // griffith-hls を抜く
__WITHOUT_MP4__: JSON.stringify(true), // griffith-mp4 を抜く
}),
],
}
ノート:griffith-mp4
と griffith-hls
がないと、ブラウザがネイティブにサポートしている限り、Griffith は MP4 と HLS メディアを再生できなくなります。
下記のとおり、Griffith への貢献はどんなものでも歓迎です。
貢献ガイドを読んて、開発プロセスに参加します。
MIT