Go to file
2015-05-11 08:19:16 -07:00
Examples/VideoPlayer Update to support react-native 0.3.10 2015-05-11 08:19:15 -07:00
RCTVideo.xcodeproj Add header search path for standalone build 2015-04-07 10:57:00 -07:00
.gitignore Initial commit 2015-03-30 22:07:55 -07:00
package.json Add trailing / 2015-05-11 08:19:16 -07:00
RCTVideo.h Initial commit for seeking 2015-04-09 01:15:57 +03:00
RCTVideo.m Update to support react-native 0.3.10 2015-05-11 08:19:15 -07:00
RCTVideoManager.h Initial commit 2015-03-30 22:07:55 -07:00
RCTVideoManager.m Update to support react-native 0.3.10 2015-05-11 08:19:15 -07:00
README.md Update to support react-native 0.3.10 2015-05-11 08:19:15 -07:00
Video.android.js Initial commit 2015-03-30 22:07:55 -07:00
Video.ios.js Removed unnecessary ref 2015-04-09 18:12:54 +03:00
VideoResizeMode.js Initial commit 2015-03-30 22:07:55 -07:00
VideoStylePropTypes.js Move resizeMode to prop from style (at request of @vjeux) and add pause 2015-04-05 10:17:03 -07:00

react-native-video

A

Add it to your project

  1. Run npm install react-native-video --save (must be 0.3.10 or higher)
  2. Open your project in XCode, right click on Libraries and click Add Files to "Your Project Name" (Screenshot).
  3. Add libRTCVideo.a to Build Phases -> Link Binary With Libraries (Screenshot).
  4. Click on RCTVideo.xcodeproj in Libraries and go the Build Phases tab. Double click the text to the right of Header Search Paths and verify that it has $(SRCROOT)../react-native/React - if it isn't, then add it. This is so XCode is able to find the headers that the RCTVideo source files are referring to by pointing to the header files installed within the react-native node_modules directory. (Screenshot).
  5. Whenever you want to use it within React code now you can: var Video = require('react-native-video');

Example

// Within your render function, assuming you have a file called
// "background.mp4" in your project. You can include multiple videos
// on a single screen if you like.
<Video source={{uri: "background"}} // Can be a URL or a local file.
       rate={1.0}                   // 0 is paused, 1 is normal.
       volume={1.0}                 // 0 is muted, 1 is normal.
       muted={false}                // Mutes the audio entirely.
       paused={false}               // Pauses playback entirely.
       resizeMode="cover"           // Fill the whole screen at aspect ratio.
       repeat={true}                // Repeat forever.
       style={styles.backgroundVideo} />

// Later on in your styles..
var styles = Stylesheet.create({
  backgroundVideo: {
    position: 'absolute',
    top: 0,
    left: 0,
    bottom: 0,
    right: 0,
  },
});

Example code here.

TODOS

  • Add some way to interface with seekToTime
  • Add support for captions
  • Support require('video!...')
  • Add support for playing multiple videos in a sequence (will interfere with current repeat implementation)
  • Add onComplete callback for when it finishes playing