Skip to content

Integration example of the Unity engine in a SwiftUI-based application

License

Notifications You must be signed in to change notification settings

el-sapo/unity-swiftui-example

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

unity-swiftui-example

This repository demonstrates how to integrate Unity 2020.2.1f1 into a Swift iOS app based on SwiftUI and built with XCode 12.

Example of Unity running in a native SwiftUI app

This repository is heavily based on the example published by Unity Technologies available here.

Features

  • Unity integration into SwiftUI
  • Communication from Unity to native code
  • Communication from native code to Unity without SendMessage()

The last point will allow you to transfer heavy data without the need to serialize it to a string beforehand.

Build

1, Unity Project

  • Open the Unity project located in the unitapp/ folder
  • Select the scene SampleScene.unity
  • In File > Build Settings..., select the iOS target
  • Click the Build button and build in the director UnityBuild (so, [REPO]/UnityBuild)

Screenshot showing where I build the Unity package

2. XCode Project

  • Open the workspace unitysandbox.xcworkspace file, and not the .xcodeproj file
  • Ensure the UnityFramework framework is listed

Screenshot showing where to add the UnityFramework entry

How

For a complete explanation of the architecture of this example, please have a look at my two blog posts:

The second link is an improvement of the first one. The main branch of this repository is in the same state as the second blog post.

FAQ

Unity doesn't render to my app

Between the moment you create the UnityFramework instance, and the moment you can display it, it seems like there is an issue. Some people try to add a delay, but this is definitely a hack.

In this example, it is assumed that whenever the API script starts, the Unity window should be ready to be shown. This is achieved by sending a first message from Unity to the native code. Whether this will work in every cases or not is questionable, but for now it has done a good job for me.

About

Integration example of the Unity engine in a SwiftUI-based application

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Swift 53.0%
  • C# 38.5%
  • Objective-C 4.7%
  • Objective-C++ 3.8%