UNPKG

react-native-vlc-media-player

Version:

React native media player for video streaming and playing. Supports RTSP,RTMP and other protocols supported by VLC player

286 lines (246 loc) 7.41 kB
import React from "react"; import ReactNative from "react-native"; const { Component } = React; import PropTypes from "prop-types"; import resolveAssetSource from "react-native/Libraries/Image/resolveAssetSource"; const { StyleSheet, requireNativeComponent, NativeModules, View, UIManager } = ReactNative; export default class VLCPlayer extends Component { constructor(props, context) { super(props, context); this.seek = this.seek.bind(this); this.resume = this.resume.bind(this); this._assignRoot = this._assignRoot.bind(this); this._onError = this._onError.bind(this); this._onProgress = this._onProgress.bind(this); this._onEnded = this._onEnded.bind(this); this._onPlaying = this._onPlaying.bind(this); this._onStopped = this._onStopped.bind(this); this._onPaused = this._onPaused.bind(this); this._onBuffering = this._onBuffering.bind(this); this._onOpen = this._onOpen.bind(this); this._onLoadStart = this._onLoadStart.bind(this); this._onLoad = this._onLoad.bind(this); this._onRecordingState = this._onRecordingState.bind(this); this._onSnapshot = this._onSnapshot.bind(this); this.changeVideoAspectRatio = this.changeVideoAspectRatio.bind(this); } static defaultProps = { autoplay: true, }; setNativeProps(nativeProps) { this._root.setNativeProps(nativeProps); } startRecording(path) { UIManager.dispatchViewManagerCommand( ReactNative.findNodeHandle(this), UIManager.getViewManagerConfig('RCTVLCPlayer').Commands .startRecording, [path], ); } stopRecording() { UIManager.dispatchViewManagerCommand( ReactNative.findNodeHandle(this), UIManager.getViewManagerConfig('RCTVLCPlayer').Commands.stopRecording, [] ); } snapshot(path) { UIManager.dispatchViewManagerCommand( ReactNative.findNodeHandle(this), UIManager.getViewManagerConfig('RCTVLCPlayer').Commands.snapshot, [path] ); } seek(pos) { this.setNativeProps({ seek: pos }); } resume(isResume) { this.setNativeProps({ resume: isResume }); } autoAspectRatio(isAuto) { this.setNativeProps({ autoAspectRatio: isAuto }); } changeVideoAspectRatio(ratio) { this.setNativeProps({ videoAspectRatio: ratio }); } _assignRoot(component) { this._root = component; } _onBuffering(event) { if (this.props.onBuffering) { this.props.onBuffering(event.nativeEvent); } } _onError(event) { if (this.props.onError) { this.props.onError(event.nativeEvent); } } _onOpen(event) { if (this.props.onOpen) { this.props.onOpen(event.nativeEvent); } } _onLoadStart(event) { if (this.props.onLoadStart) { this.props.onLoadStart(event.nativeEvent); } } _onProgress(event) { if (this.props.onProgress) { this.props.onProgress(event.nativeEvent); } } _onEnded(event) { if (this.props.onEnd) { this.props.onEnd(event.nativeEvent); } } _onStopped() { this.setNativeProps({ paused: true }); if (this.props.onStopped) { this.props.onStopped(); } } _onPaused(event) { if (this.props.onPaused) { this.props.onPaused(event.nativeEvent); } } _onPlaying(event) { if (this.props.onPlaying) { this.props.onPlaying(event.nativeEvent); } } _onLoad(event) { if (this.props.onLoad) { this.props.onLoad(event.nativeEvent); } } _onRecordingState(event) { if (this.lastRecording === event.nativeEvent.recordPath) { return; } if (!event.nativeEvent.isRecording && event.nativeEvent.recordPath) { this.lastRecording = event.nativeEvent.recordPath; this.props.onRecordingCreated(this.lastRecording); } } _onSnapshot(event) { if (event.nativeEvent.success && this.props.onSnapshot) { this.props.onSnapshot(event.nativeEvent); } } render() { /* const { source } = this.props;*/ const source = resolveAssetSource(this.props.source) || {}; let uri = source.uri || ""; if (uri && uri.match(/^\//)) { uri = `file://${uri}`; } let isNetwork = !!(uri && uri.match(/^https?:/)); const isAsset = !!( uri && uri.match(/^(assets-library|file|content|ms-appx|ms-appdata):/) ); if (!isAsset) { isNetwork = true; } if (uri && uri.match(/^\//)) { isNetwork = false; } source.isNetwork = isNetwork; source.autoplay = this.props.autoplay; source.initOptions = source.initOptions || []; if (this.props.repeat) { const existingRepeat = source.initOptions.find(item => item.startsWith('--repeat') || item.startsWith('--input-repeat')); if (!existingRepeat) { source.initOptions.push("--repeat"); } } const nativeProps = Object.assign({}, this.props); Object.assign(nativeProps, { style: [styles.base, nativeProps.style], source: source, src: { uri, isNetwork, isAsset, type: source.type || "", mainVer: source.mainVer || 0, patchVer: source.patchVer || 0, }, onVideoLoadStart: this._onLoadStart, onVideoOpen: this._onOpen, onVideoError: this._onError, onVideoProgress: this._onProgress, onVideoEnded: this._onEnded, onVideoEnd: this._onEnded, onVideoPlaying: this._onPlaying, onVideoPaused: this._onPaused, onVideoStopped: this._onStopped, onVideoBuffering: this._onBuffering, onVideoLoad: this._onLoad, onRecordingState: this._onRecordingState, onSnapshot: this._onSnapshot, progressUpdateInterval: this.props.onProgress ? 250 : 0, }); return <RCTVLCPlayer ref={this._assignRoot} {...nativeProps} />; } } VLCPlayer.propTypes = { /* Native only */ rate: PropTypes.number, seek: PropTypes.number, resume: PropTypes.bool, paused: PropTypes.bool, autoAspectRatio: PropTypes.bool, videoAspectRatio: PropTypes.string, volume: PropTypes.number, disableFocus: PropTypes.bool, src: PropTypes.string, playInBackground: PropTypes.bool, playWhenInactive: PropTypes.bool, resizeMode: PropTypes.string, poster: PropTypes.string, repeat: PropTypes.bool, muted: PropTypes.bool, audioTrack: PropTypes.number, textTrack: PropTypes.number, onVideoLoadStart: PropTypes.func, onVideoError: PropTypes.func, onVideoProgress: PropTypes.func, onVideoEnded: PropTypes.func, onVideoPlaying: PropTypes.func, onVideoPaused: PropTypes.func, onVideoStopped: PropTypes.func, onVideoBuffering: PropTypes.func, onVideoOpen: PropTypes.func, onVideoLoad: PropTypes.func, /* Wrapper component */ source: PropTypes.oneOfType([PropTypes.object, PropTypes.number]), subtitleUri: PropTypes.string, autoplay: PropTypes.bool, onError: PropTypes.func, onProgress: PropTypes.func, onEnded: PropTypes.func, onStopped: PropTypes.func, onPlaying: PropTypes.func, onPaused: PropTypes.func, onRecordingCreated: PropTypes.func, /* Required by react-native */ scaleX: PropTypes.number, scaleY: PropTypes.number, translateX: PropTypes.number, translateY: PropTypes.number, rotation: PropTypes.number, ...View.propTypes, }; const styles = StyleSheet.create({ base: { overflow: "hidden", }, }); const RCTVLCPlayer = requireNativeComponent("RCTVLCPlayer", VLCPlayer);