In this quickstart guide, we will be integrating the ARwayKit SDK in the standard flutter app
Installed Versions
In this guide, we will be using the following versions of Flutter, Dart, and Unity:
Flutter version: 3.10.5
Dart version: 3.0.5
Unity: 2022.3.29f1 LST
Download the ARwayKit SDK
Steps
Download the ARwayKit SDK project from GitHub as a ZIP. You can contact us for access to the ARwayKit SDK.
Creating a Blank Project in Flutter
If you have already created a Flutter project, you may skip the installation instructions and proceed with the next steps. Otherwise, kindly refer to the Flutter documentation for installation guidelines.
After adding the dependencies, you need to fetch them into your Flutter project.
You can fetch the dependencies by -
From the terminal: Run flutter pub getOR
From Android Studio/IntelliJ: Click Packages get in the action ribbon at the top of pubspec.yaml.
From VS Code: Click Get Packages located on the right side of the action ribbon at the top of pubspec.yaml.
Then add an import statement for using the package inside your Dart code.
We have created sample Dart files with unity pre-integrated to help you get started quickly with the project. The Dart files are located in the lib folder within the Flutter project.
Add the ARwayKit SDK to the Flutter Folder
Steps:
Download the Source code (zip) from the GitHub repo (unity-viewer-sdk-3.1.4.zip).
Extract the source code from the downloaded zip file by right-clicking on it and selecting "Extract All" or using a zip extraction tool of your choice.
In your Flutter app directory, create a new folder named "unity".
Move the extracted Unity project folder into the newly created "unity" folder. The expected path should be: unity/unity-viewer-sdk-3.1.4/...
.
├── my_project_name
│ └── .dart_tool
│ └── .idea
│ └── android
│ └── ios
│ └── lib
│ └── linux
│ └── macos
│ └── test
│ └── unity // Create this folder
│ └── <Your Unity Project> // Example: unity-viewer-sdk-3.1.4
│ └── web
│ └── windows
Make sure you have the Unity editor version 2022.3.29f1 installed on your computer. If you don't have it, download and install it from the official Unity website.
Open the Unity editor and navigate to the "unity-viewer-sdk-3.1.4" folder by selecting "Open Project" from the Unity editor's file menu and choosing the appropriate folder.
Before opening the project, ensure that you have the required modules downloaded and installed for both Android and iOS builds. If you haven't already, download and install the following modules in the Unity Hub:
Android Build Support
OpenJDK
Android SDK & NDK Tools
iOS Build Support
Once you have the required modules installed, open the Unity project by selecting it from the Unity Hub or by double-clicking on the Unity project file in the "unity-viewer-sdk-3.1.4" folder.
After opening the project, the Unity editor will start importing the necessary files, and a new Unity editor window will open, displaying the project's contents.
Update Addressables Groups & Set Account ID and Secret Key
Getting the Account ID and Secret Key
From the ARway Creator Portal, go to "For Developers -> Create a New App -> Enter App Name".
Copy your Account ID and SecretKey for that App.
Adding the Account ID and Secret Key
In the Project Window, go to "Assets -> ARway -> Viewer Mode -> Resource-> ARWayKitConfig " and add your credentials for the Account ID and Secret Key.
The expected path is unity/unity-viewer-sdk-3.1.4/fuw-2022.2.0.unitypackage
Using Unity, open the Unity project, go to File -> Build Settings -> Player Settings -> Settings for Android -> Other Settings and change the following under the Configuration section:
In Scripting Backend, change to IL2CPP
In Target Architectures, select ARMv7 and ARM64
File -> Build Settings -> Player Settings -> Settings for iOS -> Other Settings and change the following under the Configuration section:
In Scripting Backend, change to IL2CPP
In Target Device, choose iPhone Only
In Target SDK, choose Device SDK
After importing, click on Flutter and select the Export Android Debug or Export Android Release option (will export to android/unityLibrary) or the Export iOS Debug or Export iOS Release option (will export to ios/UnityLibrary).
The "Release" export option is recommended due to optimizations.
To build for Android or iOS, follow the instructions below:
Android
6.1. Open the android/settings.gradle file and add the following:
+ include ":unityLibrary"
+ project(":unityLibrary").projectDir = file("./unityLibrary")
+ include ':unityLibrary:xrmanifest.androidlib'
6.2. The minimum SDK version required for this app is 24. Open the android/app/build.gradle file and change the following:
The code above use the debug signConfig for all buildTypes, which can be changed as you well if you need specify signConfig.
6.4. (Optional) If you use minifyEnabled true in your android/app/build.gradle file, open the android/unityLibrary/proguard-unity.txt and change the following:
+ -keep class com.xraph.plugin.** {*;}
6.5. Open the android/unityLibrary/src/main/AndroidManifest.xml and change the following:
6.6. (Optional) If you want Unity in it's own activity as an alternative, open the android/unityLibrary/src/main/AndroidManifest.xml and change the following:
6.1. Open the ios/Runner.xcworkspace (workspace, not the project) file in Xcode, right-click on the Navigator (not on an item), go to Add Files to "Runner" and add the ios/UnityLibrary/Unity-Iphone.xcodeproj file.
6.2. (Optional) Select the Unity-iPhone/Data folder and change the Target Membership for Data folder to UnityFramework.
6.3.1. If you're using Swift, open the ios/Runner/AppDelegate.swift file and change the following:
6.4. Add the UnityFramework.framework file as a library to the Runner project
6.5 If you are using Xcode 14 or a newer version, and your Unity version is older than 2021.3.17f1 or 2022.2.2f1, there is a possibility that your app may crash when running from Xcode. To resolve this issue, you need to disable the Thread Performance Checker feature in Xcode. Follow these steps:
Open Xcode and navigate to Product > Scheme > Edit Scheme...
With the "Run" option selected on the left side, go to the Diagnostics tab.
Uncheck the checkbox for Thread Performance Checker.
6.6 Open the ios/Runner/Info.plist and change the following:
<dict>
+ <key>NSCameraUsageDescription</key>
+ <string>Used for AR Content and mapping</string>
+ <key>NSLocationWhenInUseUsageDescription</key>
+ <string>Used to attach maps with global coordinates and public map searching</string>
+ <key>NSMicrophoneUsageDescription</key>
+ <string>Used for creating audio content</string>
+ <key>NSPhotoLibraryAddUsageDescription</key>
+ <string>The app requires access to Photos to save media to it.</string>
+ <key>NSPhotoLibraryUsageDescription</key>
+ <string>The app requires access to Photos to interact with it.</string>
</dict>
Sample Dart Files
We have created sample Dart files to help you get started quickly with the project.
main.dart
main.dart
import'package:flutter/material.dart';import'menu_screen.dart';import'arwaysdk_unity_screen.dart';voidmain() {runApp(MyApp());}classMyAppextendsStatelessWidget {// This widget is the root of your application.@overrideWidgetbuild(BuildContext context) {returnMaterialApp( title:'My Flutter App', theme:ThemeData.dark(), initialRoute:'/', routes: {'/': (context) =>MenuScreen(),'/unity': (context) =>ARwayKitUnityScreen(), }, ); }}
menu_screen.dart
menu_screen.dart
import'package:flutter/material.dart';classMenuScreenextendsStatefulWidget {constMenuScreen({Key? key}) : super(key: key);@override// ignore: library_private_types_in_public_api_MenuScreenStatecreateState() =>_MenuScreenState();}class_MenuScreenStateextendsState<MenuScreen> {finalString title ='Open ARway SDK';finalString route ='/unity';@overrideWidgetbuild(BuildContext context) {returnScaffold( appBar:AppBar( title:constText('ARwayKit Flutter Demo'), ), body:Center( child:Column( children: [constSizedBox( height:32, ),constPadding( padding:EdgeInsets.all(30), child:Text('Example scene to show how to link "ARwayKit SDK" scenes with ''Flutter.', style:TextStyle( fontSize:24, letterSpacing:2, wordSpacing:5, fontStyle:FontStyle.italic, ), ), ),constSizedBox( height:96, ),Padding( padding:constEdgeInsets.all(30), child:ElevatedButton( onPressed: () {Navigator.of(context).pushNamed(route); }, style:ElevatedButton.styleFrom( elevation:10, primary:Color(0xFF1AB146), minimumSize:Size(192, 64), ), child:Text( title, style:constTextStyle( fontSize:20, fontWeight:FontWeight.bold, ), ), ), ), ], ), ), ); }}
arwaysdk_unity_screen.dart
arwaysdk_unity_screen.dart
import'package:flutter/material.dart';import'package:flutter_unity_widget/flutter_unity_widget.dart';classARwayKitUnityScreenextendsStatefulWidget {ARwayKitUnityScreen({Key? key}) : super(key: key);@override_ARwayKitUnityScreenStatecreateState() =>_ARwayKitUnityScreenState();}class_ARwayKitUnityScreenStateextendsState<ARwayKitUnityScreen> {staticfinalGlobalKey<ScaffoldState> _scaffoldKey =GlobalKey<ScaffoldState>();lateUnityWidgetController _unityWidgetController;@overridevoidinitState() { super.initState(); }@overridevoiddispose() { _unityWidgetController.dispose(); super.dispose(); }@overrideWidgetbuild(BuildContext context) {returnScaffold( key: _scaffoldKey, appBar:AppBar( title:constText('Home'), ), body:Card( margin:constEdgeInsets.all(8), clipBehavior:Clip.antiAlias, shape:RoundedRectangleBorder( borderRadius:BorderRadius.circular(20.0), ), child:Stack( children: [UnityWidget( onUnityCreated: _onUnityCreated, onUnityMessage: onUnityMessage, onUnitySceneLoaded: onUnitySceneLoaded, useAndroidViewSurface:true, borderRadius:constBorderRadius.all(Radius.circular(70)), ), ], ), ), ); }voidsetRotationSpeed(String speed) { _unityWidgetController.postMessage('Cube','SetRotationSpeed', speed, ); }voidonUnityMessage(message) {print('Received message from unity: ${message.toString()}'); }voidonUnitySceneLoaded(SceneLoaded? scene) {print('Received scene loaded from unity: ${scene?.name}');print('Received scene loaded from unity buildIndex: ${scene?.buildIndex}'); }// Callback that connects the created controller to the unity controllervoid_onUnityCreated(controller) { controller.resume(); this._unityWidgetController = controller; }}
How to use ARway SDK Scenes?
For how to use the scenes in the ARwayKit SDK, kindly look at the documentation for those scenes linked below.