Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

This part of the documentation extends the integration process of Appoxee's native library into the Unity3D world.

...

Integrating Unity Plugin will provide you with the functionality supported as part of the Appoxee SDK (iOS SDK 4.1.0 .8 / Android 2.7.0), aside from Appoxee Inbox which is not supported as part of the Unity plugin.

...

Phase 1
  1. Download the Appoxee Android Unity Plugin Zip file for the EULA Page.
  2. Extract the zip file to path : UnityProjectName/Assets
  3. For Android Only : Replace in AndroidManifest.xml the "YOUR_PACKAGE_NAME" placeholder to your reverse-domain package name as you set in the Unity IDE
  4. Verify that this is the directory structure and content after extracting : 
    1. UnityProjectName/Assets/AppoxeePlugin.cs 
    2. UnityProjectName/Assets/IAppoxeeCallable.cs 
    3. UnityProjectName/Assets/Plugins/Android/appoxee-sdk.jar 
    4. UnityProjectName/Assets/Plugins/Android/appoxee-unity-plugin.jar 
    5. UnityProjectName/Assets/Plugins/Android/AppoxeeSDK/AndroidManifest.xml 
    6. UnityProjectName/Assets/Plugins/Android/AppoxeeSDK/project.properties 
    7. UnityProjectName/Assets/Plugins/Android/AppoxeeSDK/libs 
    8. UnityProjectName/Assets/Plugins/Android/AppoxeeSDK/res 
    9. UnityProjectName/Assets/Plugins/Android/google-play-services_lib 
    10. UnityProjectName/Assets/Plugins/ios/AppoxeePlugin.h + m
    11. UnityProjectName/Assets/Plugins/ios/AppoxeePluginDelegate.h + m
    12. UnityProjectName/Assets/Plugins/ios/UnityAppController+AppoxeeUnity.h + m
    13. UnityProjectName/Assets/Plugins/ios/AppoxeeSDK.framework
    14. UnityProjectName/Assets/Plugins/ios/AppoxeeSDKResources.bundle

  5. Open your Unity project.
Phase 2
  1. Your MainCameraScript class must implement IAppoxeeCallable in order to receive the results of the API calls.

  2. Your MainCameraScript class should hold a member of the AppoxeePlugin in order to use the different API calls after initializing it, using the Factory method.
  3. In order to initialise the Appoxee Unity Bridge, call AppoxeePlugin.CreateAppoxeeUnityBridge() , passing it your gameObject, Your SDK Key & Secret Key . Do so in your onStart() method.

    Warning
    titleSDK Key & Secret - Do Not Confuse Platforms!


     

    iOS - Make sure the Key & Secret under your iOS Application in the Appoxee Dashboard is used for your iOS Unity App, and is passed to the plugin via a AppoxeeConfig.plist file.

    Android -Make sure the Key & Secret under your Android Application in the Appoxee Dashboard is used for your Android Unity App, and is passed as a parameter to the initialization method.


    Do not mix between them!
  4. In your onStart() method, call AppoxeeReportActivate() in order to signal  to the SDK that the App is now in foreground. This is crucial for analytics.
  5. In your onDestroy() method, call AppoxeeReportBackground() in order to signal to the SDK that the App is now in background, This is crucial for analytics.
  6. Android Users - Please Note : if your AppoxeePlugin member is NULL after calling the Factory method, the appoxee-unity-plugin.jar is MISSING, thus resulting a crash on each API call.
  7. The following code snippet shows the MainCameraScript class as step 1 - 5 explain : 

    Code Block
    languagec#
    titleInit AppoxeeAndroidBridge
    linenumberstrue
    using UnityEngine;
    using System;
    ...
    public class MainCameraScript : MonoBehaviour,IAppoxeeCallable<String> {
    ...
    	private AppoxeePlugin unityBridge; //Keep as field/member in order to use the API. if Null, API calls will cause a crash in runtime.
    ...
    
        // Use this for initialization
    
        void Start () {
            if (myBridge == null) {
    
                Debug.Log ("UNITY: Start() calling constructor");
    
                #if UNITY_IOS
    
                // No need to pass an SDK key & App secret on iOS.
    
                // Values should be passed via and .plist file, in the Xcode project.
    
                    myBridge =AppoxeePlugin.CreateAppoxeeUnityBridge(this,"", "");
    
                #elif UNITY_ANDROID
    
                    myBridge =AppoxeePlugin.CreateAppoxeeUnityBridge(this,"SDK.Key", "App.Secret")
    
                #endif
    
                } 
        }
    ...
    	//If Application is on it's way for background / out of focus, must report deactivation for analytics 
    	void OnApplicationPause(bool pauseStatus) {
            if (pauseStatus) {
                #if UNITY_ANDROID
                if (unityBridge != null) {
                    unityBridge.ReportDeactivation();
                }
                #elif
    
                #endif
            }
        }
    	//If Application is in focus/back in foreground, must report activation for analytics 
        void OnApplicationFocus(bool focusStatus) {
            if (focusStatus) {
                #if UNITY_ANDROID
                if (unityBridge != null) {
                    unityBridge.ReportActivation();
                }
                #elif
    
                #endif
            }
        }
    ...
    }
  8. iOS Only
    1. Build Open your Xcode project and open Xcode.
    2. In your Xcode project, create a .plist file (File -> New -> File... Recource -> Property List) , and provide and name it AppoxeeConfig.plist. Provide your SDK key. file needs to be named: AppoxeeConfig.plist., and other relevant settings.
    Code Block
    languageactionscript3
    titleAppoxeeConfigurationAppoxeeConfig.plist example
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
    <plist version="1.0">
        <dict>
            <key>sdk</key>
            <dict>
    <key>AppoxeeSDKID</key>
    <string>Your SDK ID</string><
                <key>sdk_key</key>
                <string>123456789.00</string>
                <key>is_eu</key> <!-- Optional, indicate if account is EU / US -->
                <false/>
                <key>open_landing_page_inside_app</key> <!-- Optional, indicate if landing page should open inside the app or via Safari -->
                <false/>
            </dict>
        </dict>
    </plist>
  9. API Documentation can be seen in the following link

...