Skip to content

Latest commit

 

History

History
205 lines (146 loc) · 4.7 KB

README.md

File metadata and controls

205 lines (146 loc) · 4.7 KB

react-native-unity-view

Integrate unity3d within a React Native app. Add a react native component to show unity. Works on both iOS and Android.

How to use

Install

npm install git://github.com/fluiddot/react-native-unity-view.git --save
(original) npm install react-native-unity-view --save

react-native link react-native-unity-view

Add Unity Project

  1. Create an unity project, Example: 'Cube'.
  2. Create a folder named unity in react native project folder.
  3. Move unity project folder to unity folder.

Now your project files should look like this.

.
├── android
├── ios
├── unity
│   └── <Your Unity Project>    // Example: Cube
├── node_modules
├── package.json
├── README.md

Configure Player Settings

  1. First Open Unity Project.
  2. Click Menu: File => Build Settings => Player Settings
  3. Add RNBridge.package from node_modules/react-native-unity-view/unity/RNBridge.unitypackage
  4. Setup export settings in: unity/Assets/RNBridge/Editor/ExportSettings
  • Xcode project Name: Your react native xcode project name
  • iOS Build Mode: Change this depending whether you want to build for device or simulator
  • iOS Build Type: Debug or Release

IOS Platform:

Other Settings find the Rendering part, uncheck the Auto Graphics API and select only OpenGLES2.

Build

Open your unity project in Unity Editor. Now you can export unity project with Build/Export Android or Build/Export IOS menu.

image

Android will export unity project to android/UnityExport.

IOS will export unity project to ios/UnityExport.

Configure Native Build

Android Build

Make alterations to the following files:

  • android/settings.gradle
...
include ":UnityExport"
project(":UnityExport").projectDir = file("./UnityExport")

IOS Build

  1. Open your react native project in XCode.
  2. Drag node_modules/react-native-unity-view/ios/Config.xcconfig to yout XCode project. Choose Create folder references.
  3. Setting .xcconfig to project. image
  4. Go to Targets => Build Settings. Change Dead Code Stripping to YES. image

Use In React Native

Props

onMessage

Receive message from unity.

Example:

  1. Send Message use C#.
RNBridge.Instance.CallToNative(new RNMessage("method", new Dictionary<string, object>(){
	{"argument1", value1},
	{"argument2", value2}
}));
  1. Receive Message in javascript
onMessage = (message) => {
    console.log('UnityMessage:', message.method, message.arguments);
}

render() {
    return (
        <View style={[styles.container]}>
            <UnityView
                style={style.unity}
                onMessage={this.onMessage}
            />
        </View>
    );
}

Methods

postMessage(method: string, arguments?: any)

Send message to unity.

  • method The method you want to call.
  • arguments Arguments of the method.

Example:

  1. Add a listener in a component:
public class MyComponent : MonoBehaviour {
	public void Start() {
		RNBridge.Instance.OnCallFromNative += OnCallFromNative;
	}
	
	void OnCallFromNative(RNMessage message) {
		string method = message.method;
		string argument1 = message.arguments.ToString("argument1");
		int argument2 = message.arguments.ToInt("argument2");
		...
	}
}
  1. Send message from react native:
onPress = () => {
    if (this.unity) {
      this.unity.postMessage('method', {argument1: 'value1', argument2: 0});
    }
}

render() {
    return (
        <View style={[styles.container]}>
            <UnityView
                ref={(ref) => this.unity = ref}
                style={style.unity}
            />
            <Button onPress={this.onPress} />
        </View>
    );
}

pause()

Pause the unity player.

Thanks @wezzle. See #13

resume()

Resume the unity player.

Example Code

import React from 'react';
import { StyleSheet, Image, View, Dimensions } from 'react-native';
import UnityView from 'react-native-unity-view';

export default class App extends React.Component<Props, State> {
    render() {
    return (
      <View style={styles.container}>
        <UnityView style={{ position: 'absolute', left: 0, right: 0, top: 0, bottom: 0, }} /> : null}
        <Text style={styles.welcome}>
          Welcome to React Native!
        </Text>
      </View>
    );
  }
}

Enjoy!!!