Skip to content

Latest commit

 

History

History
145 lines (101 loc) · 3.19 KB

README.md

File metadata and controls

145 lines (101 loc) · 3.19 KB

react-native-tv-cast

react-native-tv-cast is a plugin to cast content from android phone to any smart tv that is connected to internet with ease, thus increasing flexibility to use any where in the component.

Getting started

$ npm install react-native-tv-cast --save

$ yarn add react-native-tv-cast

To use this dependency in your project, the following packages are needed.

  1. 'react'
  2. 'react-native'

Mostly automatic installation

Modify app/build.gradle

  implementation ( 'com.github.ConnectSDK:Connect-SDK-Android:2.0.0')

Modify MainApplication.java

import com.connectsdk.discovery.DiscoveryManager;
import com.connectsdk.discovery.DiscoveryProvider;
import com.connectsdk.service.DeviceService;

  @Override
  public void onCreate() {
    super.onCreate();
    DiscoveryManager.init(getApplicationContext());
    try {
      DiscoveryManager.getInstance().registerDeviceService((Class<DeviceService>) Class.forName("com.connectsdk.service.CastService"), (Class<DiscoveryProvider>)Class.forName("com.connectsdk.discovery.provider.CastDiscoveryProvider"));
    } catch (ClassNotFoundException e) {
      Log.d("CHROME","CHROME CAST NOT REGISTERED");
      e.printStackTrace();
    }
    ...
  }

Important Note

Amazon FireTv Casting works only when targetSdk is set to 29 or below.

To get the devices list. you need to add listeners using DeviceEventEmitter

'deviceList' for list of devices

'duration' for duration

Usage (Example of react-native-tv-cast )

import React, {Component} from 'react';
import { View, TouchableOpacity, DeviceEventEmitter } from 'react-native';
import TVCast from 'react-native-tv-cast';
/*
    npm install react-native-tv-cast
*/

const App = () => {

React.useEffect(()=> {
  DeviceEventEmitter.addListener('deviceList', (e) => {
    //get device that is discovered in your wifi network.
    // add the devices in usestate array
  });
},[])

const castDevice = () => {
  // this method triggers casting process and connects to your tv by using identifier.
  // TVCast.setDevice(deviceId: DeviceId, StreamData: streamData, callback: CallbackType)

}

const stopCasting = () => {
  TVCast.stopCast();
}

   
  return (
    <View>          
      <TouchableOpacity onPress={() =>{
        castDevice();
      }} >
        <Text>CAST </Text>
      </TouchableOpacity>
      <TouchableOpacity onPress={() =>{
        stopCasting();
      }} >
        <Text>STOP CASTING </Text>
      </TouchableOpacity>
    </View>
  );
   
}

Methods :

resetDiscovery()
// resets the discovery

stopCast()
// stops the current casting process

setDevice(deviceId: DeviceId, StreamData: streamData, callback: CallbackType)
// Sets the deviceId where we need to cast.
// where streamData will be 
// var streamData = {
//  url: string;
//  title: string;
//  description: string;
//  icon: string;
// };

issues

Alternative you can raise issues here https://github.com/krishna4157/react-native-tv-cast/issues

Credit goes to :

  1. 'react'
  2. 'react-native'
  3. 'connect-sdk'

Contribution :

if you like my work 😀 u can contribute using vpa : krishna.santho08-1@okaxis

it will be a great support to me ☺.