FlatRedBall support development for iOS (iPhone and iPad) using .NET 8 (as of March 2024).
To create a new iOS project, launch the FlatRedBall Editor, create a new project, and select iOS as your target platform.
You may see the following when deploying your project:
Verify that your Info.plist Deployment Target matches your csproj's SupportedOSPlatformVersion.
If you have a NullReferenceException in Microsoft.Xna.Framework.Audio.OpenALSoundController.Update, and you are playing on the simulator, verify that audio is working properly on your Mac.
For information on errors playing SoundEffects and SounEffectInstances see the SoundEffectInstance page.
FlatRedBall iOS projects (including Glue projects) can be developed in Visual Studio and deployed to an iOS device through a networked Mac using Xamarin Build Host. This is the fastest way to develop iOS gams but it does require a Xamarin Business License (which is more expensive than Xamarin Indie License).
This article shows how to use Xamarin Build Host to deploy a FlatRedBal iOS game.
Before deploying you must have your Mac and PC computers configured for Xamarin Build Host. Xamarin provides a guide for getting Xamarin Build Host set up here: http://developer.xamarin.com/guides/ios/getting_started/installation/windows/introduction_to_xamarin_ios_for_visual_studio/
Creating a FlatRedBall iOS project through Glue is nearly identical to creating a PC project:
Open Glue
Select File->"New Project"
Select "iOS" as the project type
Enter a name
Click "Make my project!"
Once the project has finished downloading it can be opened in Visual Studio. Visual Studio should display UI for the Xamarin Build Host:
As shown in the Xamarin guide above, running the app simply requires running from Visual Studio just like normal. Of course, the app will run on simulator or physical iOS device depending on your settings:
iOS development requires the use of Provisioning Profiles to deploy to iOS hardware, either for development or for final distribution. This section will discuss how to create and use provisioning profiles.
For information on using provisioning profiles, see this page.
The provisioning profile is error prone due to its complexity. If you are unable to get things to work here are some things to try:
Provisioning profiles are tied to a certain bundle identifier. Verify that the bundle identifier of your app matches the bundle identifier in the provisioning profile.
This tutorial will walk you through the steps of creating a FlatRedBall iOS project on the PC then copying it to the Mac. Note that unlike most other FlatRedBall platforms, FlatRedBall iOS requires commercial software and a computer running OSX along with a computer running Windows.
Specifically, the requirements are:
A computer running Windows. This computer will have the typical FlatRedBall installation and will run Glue.
A computer running OSX. This computer must have Xamarin.iOS intalled. The steps outlined here will work with the trial version of Xamarin.iOS as well as the full version, but will not work with the Starter (free) version of Xamarin. At least an Indie License is required. For more information about Xamarin licenses see this link.
Although this is isn't necessary, the easiest way to develop with Glue for FlatRedBall iOS is to set up your OSX computer so that your Windows computer can access its file system through the network. The Internet has many articles to get this set up. For example: http://lifehacker.com/247541/how-to-access-a-macs-files-on-your-pc. Be sure to save the credentials on your Windows machine as Glue will need to be able to access the OSX's file system.
Be sure that you can open a Windows Explorer window to view your Mac files on the PC before proceeding. If you cannot, attempt the following:
Make sure that Windows file sharing is enabled on your mac. To do this:
Click the Apple icon in the top left of the screen and select "System Preferences"
Select "Sharing"
Click "Options..."
Make sure all check boxes are checked
Click Done
Open a Windows explorer window
In the address bar type your Mac's IP as reported in the sharing window. For example, in this picture the IP is 192.168.0.15, so the address bar would have
You may be asked to log in. Use the login name as specified in the Windows File Sharing screen (including spacing). For example, the username as specified in this window is
Creating the project for iOS is identical to creating projects for other platforms:
Start Glue
Select File->New Project
Select FlatRedBall iOS as the project type
Enter the name that you want for your project
Click OK
At this point you will have a project which can be compiled and run on OSX. This tutorial shows how to copy iOS projects to Glue as the primary project, but the following tutorial also works if the iOS project is a synced project. For more information on project sync, see this page.
The next step is to set up Glue to copy the project over to your OSX computer.
Once you can access the file system on OSX, you can tell Glue to copy the project over to the desired location. To do this:
If you have a large project, you may notice that the copy process can be lengthy. Don't worry, the project copier checks the dates on files when performing copying. This means that subsequent copies will go much faster!
At this point the project is fully copied to the OSX computer and it can be run there. This assumes that you have the proper Xamarin software installed.
To do this:
Open Xamarin Studio
Since the projects are copied from Windows to OSX, if you make changes on the OSX side of things - such as by modifying .cs files, then you will need to migrate those changes back to PC.
This can be done through the Glue plugin by swapping the "Copy From" and "Copy To" folder. Note that the "Custom Folder" radio must be checked to enter a value in the "Copy From" section.
Keep in mind that the entire folder structure is copied when the "Copy Projects!" button is checked, so changes from the "From" folder will overwrite changes in the "To" folder. We recommend taking advantage of version control software to back up your project to prevent unintentional overwriting of data.
(including the space)
Click the "Copy Project" tab at the bottom of the Glue screen
Click the "..." button to select the folder where you'd like to copy the project. You may need to create a new directory. Note that if you navigated to the folder in an earlier step using the IP of the Mac, you can also paste the target directory in the text box rather than clicking the browse button.
Once you have selected the folder, click "Copy Projects!". The project will be copied and the progress bar will update to show progress.
Select "Run"->"Start Debugging"
Your program will appear in the iPhone Simulator
Once you have verified that the project runs in the iPhone simulator, you can develop normally in Glue. After making changes in Glue or on the PC, you can simply copy the project using the Copy Project tab. Unfortunately at the time of this writing, Xamarin Studio does not automatically re-load the project when files have been changed. Therefore, you will need to manually reload the project by right-clicking on the project in the OSX IDE and selecting Reload: