Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Typically a new platform can be added to an existing FlatRedBall project by using synced projects. However, if you want to upgrade your main project you need to do so manually. This document provides high-level steps for upgrading.
Upgrading the main project is an advanced topic requiring understanding of FlatRedBall project structure. This document provides high-level steps for upgrading your project. Before beginning, you should create a backup of your project or push a working copy to version control (such as Git).
Also, if you do run into problems as you work through these steps, please ask for help on Discord. The maintainers will be happy to help you with your upgrade process while updating this document to be easier to follow.
Before beginning the upgrade process, please follow these steps:
As mentioned above, create a backup of your project.
Upgrade your project to the latest .dlls (or NuGet packages). If you are using source, consider upgrading your project to the latest source.
Upgrade your .gluj (or .glux) to the latest version if possible. If not possible, note the version that you are on, as you may need to downgrade your newly-created project. For more information see the File Version (.gluj) page.
Verify that your project runs after performing this upgrade to avoid confusion about whether something is broken due to the new project type.
The next step is to create a new project:
Open the FlatRedBall Editor and select to create a new project
Enter the new project name
Select the desired project type
Check the option for Custom Namespace and enter the namespace of your old project. This will make it much easier to copy existing code into your newly created project
If your old project is linked to source, select the option to link this new project to source
Uncheck the option to run the wizard to prevent adding unnecessary code and content files
If you did not upgrade your project to the latest gluj version, you should open your gluj file and downgrade it. After saving the file, close and re-open the FlatRedBall Editor to verify that it has generated content correctly. If your version is old enough, you may have duplicate classes, with some using .Generated.cs
suffix and some with the .cs
suffix. You should delete duplicate files if needed.
Once you have a new project running correctly, you can copy existing files. The following files should be copied from the old project to the new project
Your old project's .gluj file (be sure to change the name to the new project name)
Your old project's EntityPerformance.json file (if it exists)
The entire Content folder except the Shader.fx and Shader.xnb files - these are platform specific and are part of the original template
The entire contents of the Entities (code) folder
The entire contents of the Screens (code) folder
The entire Forms folder
The entire GlueSettings folder
The entire GumRuntimes folder
Any custom code outside of the folders mentioned above
Any additional files such as icons or cursors
You may need to modify the following code files:
Compare your two Game1.cs, and copy code to the new file as necessary
Modify your csproj to include any <DefineConstants>
included in the old project. Exclude any constants that are not related to the new platform.
Make any changes needed to your code if necessary if you have changed .NET versions or platforms
FlatRedBall supports creating games which run on Android devices. Aside from Android-specific capabilities, FlatRedBall Android development is nearly identical to developing games for other platforms. As of April 2024 FlatRedBall Android projects use .NET 8 which provides access to a much wider set of features and nuget packages compared to the previous Xamarin-based version.
FlatRedBall Android game development requires a Windows PC just like regular PC game development as well as Visual Studio 2022 or newer.
As mentioned in the Multi-Platform page, the recommended approach for creating full game projects is to create a primary desktop project with a synced Android project. However, if you are evaluating FlatRedBall, or creating a small test project, you may want to create a primary Android project. Both approaches are discussed below.
Creating an Android project is essentially identical to creating any other platform:
Open the FlatRedBall Editor
Select File->New Project
Enter a project name
Set the Platform to Android .NET
Click Create project!
Select the desired project type in the wizard, or close the wizard to begin with an empty project. Click the Visual Studio icon to open the project in Visual Studio:
Now that the project is in Visual Studio, you can develop an Android game the same as if you were making a PC game, including using the FRB Editor. To launch the game:
Select the target device
If you have a physical phone, you can connect it to your computer. You need to enable your phone for development by turning on developer mode. For more information see the Microsoft page for setting up an Android device: https://learn.microsoft.com/en-us/dotnet/maui/android/device/setup?view=net-maui-8.0
If you do not have a physical phone, or if you prefer to use an Android emulator, see the following page on how to set up an Android emulator: https://learn.microsoft.com/en-us/dotnet/maui/android/emulator/?view=net-maui-8.0
Verify that the Play button in Visual Studio has the desired emulator or device selected. Note that if a physical Android device is connected to your computer and is set up for debugging, then Visual Studio will detect it as a deployment option.
Press the Play button
Synced Android projects are created just like any other synced project. The first step is to create a regular Windows Desktop project. Once the project is created a new synced Android project can be created as follows:
Open FlatRedBall
Select Project->View Projects
Click the New Synced Project button
Select the Android option
Enter a project name
Click Make my project!
The project will take a moment to download and be created, but once it is, you should see the Android project listed in the Androids project list. Since your FlatRedBall project now has multiple platforms, you can choose which project to open through the Projects tab.
To create an Android APK, whether for internal testing or for final release, see the Microsoft release documentation.
Unfortunately deploying to Android can be fickle at times, and sometimes no errors are provided.
If your app crashes immediately without a call stack, then you may want to try the following:
Does the app work on Android hardware? Sometimes an app will not work on emulator but will work on hardware
Have you tried creating a .NET MAUI? MAUI projects can be created with templates which are part of Visual Studio, so they are likely to eliminate common problems in template setup. If a MAUI project doesn't work, then that might mean that prerequisites are not properly installed.
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.
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 supports developing games on multiple platforms. As of the time of this writing the following platforms are supported:
Desktop
Windows
Mac
Linux
Android
iOS
Consoles (Switch, Xbox) through the use of FNA and Native AOT compilation
Web
Your project's platform is selected when first creating a new project. A newly-created project selects a primary platform, which defines the primary project.
The primary project should be a desktop-based project (either MonoGame .NET Desktop GL or FNA at the time of this writing) even if you intend to target other platforms such as Android or consoles. Selecting a Desktop project as the primary project provides a number of benefits:
Superior debugging
C# Edit-and-continue
FlatRedBall Editor Live Edit support
Faster compilation and deployment
Ability to add new platforms at any time
FlatRedBall provides the concept of synced projects - these are projects which are created by the FlatRedBall Editor which are kept synced with the primary project. In other words, whenever a new Entity, Screen, or file is added through the FlatRedBall Editor, the synced project is updated to include the same code and content files. The FRB Editor also updates the files as necessary for each platform. For example, on PC a file may be set to copy to the output folder, while on Android it is set to an Android Asset.
Files which are manually added to a project (either synced or primary) are considered platform-specific and are not automatically synced. Of course, you are free to link these files manually through Visual Studio.
For more information on creating a synced project, see the Synced Project page.
FlatRedBall attempts to be as cross platform as possible. From time to time you may encounter code which is only available on one platform, especially if you are using 3rd party nuget packages. Therefore, you may need to exclude certain code from platforms.
For example, the following code could be used to perform logic which is specific to web or desktop:
The following compilation symbols are available:
ANDROID
FNA (not a platform, but can still be checked)
DESKTOP_GL
IOS
WEB
You can also add your own conditional compilation symbols to the .csproj, and may are available automatically through .NET such as NET8_0_OR_GREATER
Synced Projects provide a way to create and keep multiple projects in sync when working with multiple platforms. Typically the main project is a DesktopGL project, and synced projects would be for other platforms such as Android or Web.
To open a project, click on the icon for the IDE for a given project. For example, the following icon can be used to open the TownRaiser XNA 4 Project:
New platforms can be added to an existing project at any point in development by adding a new synced project. To add a new synced project to an existing Glue project:
Open the Projects tab
Click the New Synced Project button
The FlatRedBall Project Creator will appear. Select the desired platform (such as Windows UWP)
Enter a name for the project. Typically the name matches the original project's name with the platform appended. For example, TownRaiserUwp.
Click the Make My Project! button.
After creating the new synced project, it appears in the Projects tab.
Since FlatRedBall is designed to be syntactically identical across all platforms, most new synced projects will compile and run with little or no modifications.
New Synced Projects are created using a standard FlatRedBall template for the given platform. In other words, a synced project references FlatRedBall for the given platform in the same way as a new project.
Synced projects can reference pre-built FlatRedBall .dlls (directly or using NuGet), or they can be linked to FlatRedBall source. The following screenshot shows a FlatRedBall Web project linking to the FlatRedBall Engine.
Synced projects automatically link all source files from the original project. This includes custom and generated code for screens, entities, and global content.
Content files are also linked by the synced project.
NuGet packages are not automatically synced across projects so if you have manually added a NuGet package to your main project, you may also need to add the same package or an alternative package to your synced projects.
Keep in mind that some NuGet packages are not available on all platforms. For example, NAudio does not work on non-windows platforms like Web. You may need to find alternative NuGet packages if one is not available on your target platform. Alternatively you can use conditional compilation symbols as explained in the Mult-Platform page.
To create FlatRedBall Android projects, you must:
Install Visual Studio as explained on the FlatRedBall Downloads page.
In the Visual Studio Installer, check Mobile development with .NET
If it isn't already installed, click the button to install
Wait for the installation to finish.
Once you have finished installing, you can verify that you have Xamarin installed:
Open Visual Studio
Select Create a new project
Search for Xamarin to make sure that Xamarin is installed. If you see search results for Android or iOS development, then it is installed
You're al set up. Now you can begin making Android applications. For information on creating a new Android project, see the main Android page.
Android builds can be distributed using a digital store (such as Google or Android), or can be manually distributed by distributing a .apk.
Before you perform any distribution, you must create a release build of your app.
The following will walk you through creating a release build. Release builds can be created for any FlatRedBall Android project, including synced Glue projects. This walkthrough assumes that you have an Android project which you have been able to successfully deploy to device through Xamarin Studio or Visual Studio.
If using Xamarin Studio, change the configuration to release:
Release builds are required for distributed .apk files.
Distributed builds also require linking against the release build of FlatRedBall. If using the .dll files which are distributed with the FlatRedBall templates (default), then your project will already have the release files downloaded.
These can be found in your project's Libraries folder:
To link the release files in Xamarin Studio:
Right-click on your game project's References
Select "Edit References..."
Select the ".Net Assembly" tab
Un-check the FlatRedBallAndroid.dll file
Click the "Browse..."
Navigate to the <project folder>/Libraries/Android/Release folder
Select FlatRedBallAndroid.dll and click Open
Verify that the release build of FlatRedBall is added and click OK
Once this library has been added, build and run your project to make sure everything is working fine.
The project needs to specify the architectures it will support. Unless you are concerned about file size, you should support all architectures. To do so:
Right-click on your project
Select "Options"
Select the "Android Build" option
Click the "Advanced" tab
Check the desired supported architectures:
The .apk file is what you need to distribute to test it on other phones. In Xamarin Studio:
Select "Project" -> "Create Android Package..."
Enter a name in the "File:" text box for the desired .apk file name
Click OK
Once the .apk file has been created it can be distributed through any digital means, such as google drive, drop box, or sending the file through email.
Xamarin's Android compiler includes a feature which allows selective inclusion of libraries, classes, and members. This feature can reduce the size of a game, but also can introduce crashes which can be difficult to diagnose - at least unless you know what to look for.
The most common type of crash occurs when deserializing XML files, such as emitter .emix files. If your program runs fine in debug but crashes in release, then it may be related to Xamarin's linking behavior. You can verify that this is the case by looking at the output window. For example, the following error appears when trying to load a .emix file.
One way to solve this problem is to adjust the linking behavior, which can be done as follows:
Right-click on the project in the Solution Pad
Select "Options"
Select the "Android Build" category
Click the "Linker" tab
Change "Link all assemblies" to either "Link SDK Assemblies only" or "Don't link"
Try running again and see if the crash occurs
The downside to this solution is that these will increase the size of your APK file.
For more information on linking, see this article.
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:
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.
FlatRedBall can be used to develop games for the Nintendo Switch. To develop games for the Nintendo Switch, your game should be using the FNA platform. To deploy to the Nintendo Switch you must:
Target .NET 7 or newer
Verify that your project compiles and runs using Native AOT
Have Nintendo Switch hardware. You must register with the Nintendo Developer Program:
Both FNA and MonoGame can technically be used to develop games for the Nintendo Switch; however, the FNA path has a number of benefits:
FNA allows the use of modern .NET versions (7+). MonoGame requires translating code to C++ using BRUTE which does not support modern .NET and C# features. This is currently being worked on by the MonoGame team, but as of May 2024 there is no AOT solution.
As of December 2023, FlatRedBall MonoGame has yet to run on the Nintendo Switch. FlatREdBall FNA demos have been successfully deployed to switch.
The MonoGame team which was responsible for console support has been less active since 2021. The FNA team continues to be active as of December 2023.
More games have been deployed to consoles recently using FNA rather than MonoGame as of December 2023.
Internally, the FlatRedBall team is testing FNA and will provide support to any games which run into problems with FNA.
FlatRedBall supports web projects using Blazor Web Assembly and WebGL. Web projects use C# just like other FlatRedBall platforms. Web projects can use the FlatRedBall Editor, almost all FlatRedBall features, and support synced projects.
FlatRedBall Web uses the Kni framwork, which is an XNA-like framework supporting Blazor WASM projects. Fortunately, this means that FlatRedBall and XNA code should work the same on Web as on other platforms, reducing the amount of code changes needed when migrating from other platforms to Web.
Before creating a FlatRedBall Web project, you must install Kni. The latest binaries can be found on the Kni release page:
Whether you create a new project or use a synced project, you can select Web as the target for your new project.
Once you have created a Web project you can use the FlatRedBall Editor as if it's a regular Desktop project. For known limitations see the section below.
To run your project:
Open the project in Visual Studio
Press the button to begin debugging your project in Visual Studio
A browser should appear running your game project
FlatRedBall Web projects can be debugged in a number of ways:
To output to the browser console, use System.Console.WriteLine
just like a normal console application. Note that output from this method appears in both the browser's console as well as Visual Studio's output window.
Breakpoints should function the same as normal FlatRedBall projects; however, as of .NET 8 at times stepover will step over a large block of code or may even freeze the application. This may be improved in future versions of .NET.
Exceptions in the Update of your game (which includes all generated and CustomActivity calls) may not result in Visual Studio breaking on exceptions. Instead, this can result in your game displaying a purple window. To solve this problem you can wrap your Game's Update call in a try/catch. If you are concerned about modifying your game for other platforms, you can do this only in web, as shown in the following block of code:
You can place a breakpoint in the catch block to also stop execution when an exception occurs.
This exception can occur when running FlatRedBall Web projects.
You can disable JavaScript exceptions to silence this error.
If you do encounter this problem, you can press F5 or continue execution and the game will run normally. This exception will not cause any problems for deployed games.
As of August 2024 FlatRedBall Web is a new platform. The following are known limitations of the platform. Over time more limitations will be discovered, while some may be solved. For more information please check the FlatRedBall Discord server.
Switch controllers are not supported. Xbox One controllers have been tested and work correctly
Setting controller vibration is not supported
The user must interact with the browser before audio plays. We recommend a loading/title screen that asks the user to click to continue
Local saving and loading of files cannot be performed with the standard System.IO.File operations
The browser determines the size of the game. Unlike regular DesktopGL projects, FlatRedBall cannot forcefully change the browser size. Of course, FlatRedBall properly reacts to resolution changes on a browser including maintaining the internal resolution and aspect ratio.
Exceptions often do not break in the debugger, so you may need to watch the browser for exceptions in the debugger console (CTRL+SHIFT+i in Chrome)
(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:
FlatRedBall Web projects can be created as standalone (primary) projects, or as synced projects. For more information on how to create a synced project, see the page. In other words, you can create a new project (File -> New Project) or you can add a new web synced project.