2023-10-26 00:54:14 -06:00
# Installation
Using npm:
```shell
npm install --save react-native-video
```
or using yarn:
```shell
yarn add react-native-video
```
Then follow the instructions for your platform to link react-native-video into your project
# Specific platform installation
< details >
< summary > iOS< / summary >
## iOS
### Standard Method
2024-04-04 05:23:44 -06:00
Run `pod install` in the `ios` directory of your project.
2023-10-26 00:54:14 -06:00
2024-05-28 01:31:00 -06:00
⚠️ from version `6.0.0` the minimum iOS version required is `13.0` . For more information see [updating section ](updating.md )
2023-11-13 13:36:16 -07:00
### Enable custom feature in podfile file
2023-10-26 00:54:14 -06:00
2024-05-07 09:25:09 -06:00
Samples available in sample app see [sample pod file ](https://github.com/TheWidlarzGroup/react-native-video/blob/9c669a2d8a53df36773fd82ff0917280d0659bc7/examples/basic/ios/Podfile#L34 )
2023-12-23 03:10:04 -07:00
#### Video caching
2023-10-26 00:54:14 -06:00
2023-11-13 13:36:16 -07:00
To enable Video caching usage, add following line in your podfile:
([more info here](other/caching.md))
```podfile
# enable Video caching
+ $RNVideoUseVideoCaching=true
2023-10-26 00:54:14 -06:00
```
#### Google IMA
Google IMA is the google SDK to support Client Side Ads Integration (CSAI), see [google documentation ](https://developers.google.com/interactive-media-ads/docs/sdks/ios/client-side ) for more information.
To enable google IMA usage define add following line in your podfile:
```podfile
$RNVideoUseGoogleIMA=true
```
2024-07-10 03:49:13 -06:00
**If you are using Expo you can use [expo plugin ](other/expo.md ) for it**
2023-10-26 00:54:14 -06:00
< / details >
< details >
< summary > Android< / summary >
## Android
2024-07-24 02:07:19 -06:00
From version >= 6.0.0, your application needs to have kotlin version >= 1.8.0
2023-11-07 23:41:17 -07:00
```:
buildscript {
...
2024-07-24 02:07:19 -06:00
ext.kotlinVersion = '1.8.0',
ext.compileSdkVersion = 34
ext.targetSdkVersion = 34
2023-11-07 23:41:17 -07:00
...
}
```
2023-10-26 00:54:14 -06:00
### Enable custom feature in gradle file
2024-07-10 03:49:13 -06:00
**If you are using Expo you can use [expo plugin ](other/expo.md ) for it**
2024-04-16 06:23:19 -06:00
You can disable or enable the following features by setting the following variables in your `android/build.gradle` file:
- `useExoplayerIMA` - Enable Google IMA SDK (Ads support)
- `useExoplayerRtsp` - Enable RTSP support
- `useExoplayerSmoothStreaming` - Enable SmoothStreaming support
- `useExoplayerDash` - Enable Dash support
- `useExoplayerHls` - Enable HLS support
Each of these features enabled will increase the size of your APK, so only enable the features you need.
By default enabled features are: `useExoplayerSmoothStreaming` , `useExoplayerDash` , `useExoplayerHls`
Example:
2023-10-26 00:54:14 -06:00
```gradle
buildscript {
ext {
...
2024-04-16 06:23:19 -06:00
useExoplayerIMA = true
useExoplayerRtsp = true
useExoplayerSmoothStreaming = true
useExoplayerDash = true
useExoplayerHls = true
2023-10-26 00:54:14 -06:00
...
}
}
```
2024-06-19 03:26:17 -06:00
See [sample app ](https://github.com/TheWidlarzGroup/react-native-video/blob/9c669a2d8a53df36773fd82ff0917280d0659bc7/examples/basic/android/build.gradle#L14C5-L14C5 )
2023-12-23 03:10:04 -07:00
2023-10-26 00:54:14 -06:00
< / details >
< details >
< summary > Windows< / summary >
## Windows
### Autolinking
**React Native Windows 0.63 and above**
Autolinking should automatically add react-native-video to your app.
### Manual Linking
**React Native Windows 0.62**
Make the following additions to the given files manually:
`windows\myapp.sln`
Add the _ReactNativeVideoCPP_ project to your solution (eg. `windows\myapp.sln` ):
1. Open your solution in Visual Studio 2019
2. Right-click Solution icon in Solution Explorer > Add > Existing Project...
3. Select `node_modules\react-native-video\windows\ReactNativeVideoCPP\ReactNativeVideoCPP.vcxproj`
`windows\myapp\myapp.vcxproj`
Add a reference to _ReactNativeVideoCPP_ to your main application project (eg. `windows\myapp\myapp.vcxproj` ):
1. Open your solution in Visual Studio 2019
2. Right-click main application project > Add > Reference...
3. Check _ReactNativeVideoCPP_ from Solution Projects
`pch.h`
Add `#include "winrt/ReactNativeVideoCPP.h"` .
`app.cpp`
Add `PackageProviders().Append(winrt::ReactNativeVideoCPP::ReactPackageProvider());` before `InitializeComponent();` .
**React Native Windows 0.61 and below**
Follow the manual linking instructions for React Native Windows 0.62 above, but substitute _ReactNativeVideoCPP61_ for _ReactNativeVideoCPP_ .
< / details >
< details >
< summary > tvOS< / summary >
## tvOS
`react-native link react-native-video` doesn’ t work properly with the tvOS target so we need to add the library manually.
First select your project in Xcode.
![tvOS step 1 ](../assets/tvOS-step-1.jpg )
After that, select the tvOS target of your application and select « General » tab
![tvOS step 2 ](../assets/tvOS-step-2.jpg )
Scroll to « Linked Frameworks and Libraries » and tap on the + button
![tvOS step 3 ](../assets/tvOS-step-3.jpg )
Select RCTVideo-tvOS
![tvOS step 4 ](../assets/tvOS-step-4.jpg )
< / details >
< / details >
2024-01-15 23:21:38 -07:00
< details >
< summary > visionOS< / summary >
## visionOS
2024-04-04 05:23:44 -06:00
Run `pod install` in the `visionos` directory of your project
2024-01-15 23:21:38 -07:00
< / details >
2024-11-13 13:19:57 -07:00
< details >
< summary > web< / summary >
Nothing to do, everything should work out of the box.
Note that only basic video support is present, no hls/dash or ads/drm for now.
< / details >