-
Notifications
You must be signed in to change notification settings - Fork 4
OLC PGE Mobile 2.0
This wiki gives a full overview of every function and method used in the OLC PGE Mobile 2.0.
Acronym | Definition |
---|---|
OLC | One Lone Coder |
PGE | Pixel Game Engine |
TODO | I am working on it |
OS | Operating System, Such as Microsoft Windows, Apple MAC, Linux, Google Android |
iOS | Apple Operating System for iPhone & iPad devices |
.h | C file extension to denote a header file |
.c | C file extension to denote a C file than contains C code only |
.cpp | C++ file extension to denote a C++ file than contains both C & C++ code |
.hpp | C++ file extension to denote that this file both contains C Header code and C++ code |
SIMD | Single Instruction Multiple Data for x86/64 Architecture |
NEON | Single Instruction Multiple Data for ARM/ARM64 Architecture |
TODO : Each function and method within the olcPixelGameEngine_Mobile.cpp
will have a link back to this page, so that the developer can access more information on what the function/method does. Add more verbiage
This is the main entry point for any application that uses 'olcPixelGameEngine_Mobile.cpp'. It is from this class you start and create all our your amazing PGE mobile games.
To get our OLC PGE Engine up and running on both Android & iOS we need a few headers and some #define
. These work together to allow you to just development your application/game using the amazing PGE 2.0 and C++ without having to handle all complicitly under the hood to get your code to work smoothly on both operating systems.
We like to keep things super simple here at the One Lone Coder Community so this is all done and dusted for you :)
-
pch.h
Pre-Complied Header, this is used to setup and complied required headers, makes comply times faster, and helps us to ensure the correct sub headers for Android & iOS are complied and ready for you to use. NOTE the iOSpch.h
file is handled within the Objective C -
#include "../_ProjectName_/pch.h"
the ProjectName is auto generated, do not change, well you can, but I wouldn't ;) -
#if defined (__ANDROID__)
Complier Talk Tells the complier to use this block of code to for Android Devices
#if defined (__ANDROID__)
#include "../<ProjectName>/pch.h"
#endif //__ANDROID__
-
#if defined (__APPLE__)
Complier Talk Tells the complier to use this block of code to for APPLE iOS Devices -
ios_native_app_glue.h
the is a GLUE interface between the PGE Mobile 2.0 and the iOS application. -
#include <memory>
there are a few Smart Pointers needed to get thing running and linking, therefore we include thememory.h
here
#if defined (__APPLE__)
#include "ios_native_app_glue.h"
#include <memory>
#endif
-
#define STBI_NO_SIMD
Complier Talk Tells the complier not to use SIMD. This is commented out by default. - SIMD/NEON greatly improves the speed of your game
- NOTE Mobile devices CPU/GPU are very weak compared to their big sisters in Computers. SIMD/NEON technology is used to greatly reduce this gap.
//#define STBI_NO_SIMD // Removes SIMD Support
// SIMD greatly improves the speed of your game
To ensure proper cross platform support between Android and iOS it is recommended to keep the class name as PGE_Mobile, This will ensure the iOS can launch the engine correctly, if you change it make the required changes in <TODO: Link> GameViewController.mm in the iOS app to suit.
class PGE_Mobile : public olc::PixelGameEngine {
public:
PGE_Mobile() {
sAppName = "Android/iOS Demo";
}
}
There are two entry points for Android and iOS respectfully. in order to maintain cross platform compatibility the entry points for both operating systems are different, as both Operation Systems work completely different.
The good news is once you have your entry point setup correctly, as detailed below, everything after this is the same for both Operating Systems.
We like to keep things super simple here at the One Lone Coder Community
Android:
-
#if defined (__ANDROID__)
Complier Talk Tells the complier to use this block of code to for Android Devices
#if defined (__ANDROID__)
/*
* Code stuff
*/
#endif //__ANDROID__
-
void Android_main()
this is the main entry point of a native application - It runs in its own thread, with its own event loop for receiving input events and doing other things.
- This is now what drives the engine, the thread is controlled from the OS
void android_main(struct android_app* initialstate) {
/*
* Code stuff
*/
}
-
struct android_app* initialstate
initalstate allows you to make some more edits to your app before the PGE Engine starts - Recommended just to leave it at its defaults, but change it at your own risk
- to access the Android directly in your code
android_app* pMyAndroid = this->pOsEngine.app;
void android_main(struct android_app* initialstate) {
/*
* initialstate stuff
* <TODO> : Create a section for explaining intialstate
*/
}
-
PGE_Mobile demo
class instantiation, starts up the PGE Engine -
demo.Construct(1280, 720, 2, 2, true, false, false);
Note it is best to use HD(1280, 720, ? X ? pixel, Fullscreen = true) the engine can scale this best for all screen sizes, without affecting performance... well it will have a very small affect, it will depend on your pixel size. Note: cohesion is currently not working. -
demo.Start();
Start the application
PGE_Mobile demo;
demo.Construct(1280, 720, 2, 2, true, false, false);
demo.Start(); // Lets get the party started
- Example:
#if defined (__ANDROID__)
void android_main(struct android_app* initialstate) {
PGE_Mobile demo;
demo.Construct(1280, 720, 2, 2, true, false, false);
demo.Start(); // Lets get the party started
}
#endif
iOS:
-
#if defined (__APPLE__)
Complier Talk Tells the complier to use this block of code to for APPLE iOS Devices
#if defined (__APPLE__)
/*
* Code stuff
*/
#endif //__APPLE__
-
int ios_main(IOSNativeApp* pIOSNatvieApp)
The is the entry point from the iOS Objective C, called during the start-up of your application - Use the objects defined in IOSNativeApp to pass data to the Objective C
- By Default you must at minimum pass the game construct vars, pIOSNatvieApp->SetPGEConstruct
- iOS runs in its own threads, with its own event loop for receiving input events and doing other things.
- This is now what drives the engine, the thread is controlled from the OS
int ios_main(IOSNativeApp* pIOSNatvieApp) {
/*
* Code Stuff
*/
}
-
int ios_main(IOSNativeApp* pIOSNatvieApp)
pIOSNatvieApp allows access to the OS App options - The iOS will instance your app differently to how Android does it
- In the iOS it will automatically create the required classes and pointers to get the PGE up and running successfully.
- IMPORTANT: You must set your class name to PGE_Mobile (see above) always for iOS
- Don't worry it will not conflict with any other apps that use the same base class name of PGE_Mobile
- To access the iOS directly in your code
auto* pMyApple = this->pOsEngine.app;
int ios_main(IOSNativeApp* pIOSNatvieApp) {
/*
* pIOSNatvieApp-> <TODO> Create section explaining options
*/
}
-
pIOSNatvieApp->SetPGEConstruct(0, 0, 2, 2, true, true, false);
Note it is best to use HD(0, 0, ? X ? pixel, Fullscreen = true) the engine can scale this best for all screen sizes, without affecting performance... well it will have a very small affect, it will depend on your pixel size Note: cohesion is currently not working. -
return EXIT_SUCCESS;
You must return EXIT_SUCCESS in order to tell the iOS to start up the engine, you can return EXIT_FAILURE, error codes etc will stop the startup of the engine and the app will exit gracefully
pIOSNatvieApp->SetPGEConstruct(0, 0, 2, 2, true, true, false);
return EXIT_SUCCESS;
- Example:
#if defined(__APPLE__)
int ios_main(IOSNativeApp* pIOSNatvieApp)
{
pIOSNatvieApp->SetPGEConstruct(0, 0, 2, 2, true, true, false);
return EXIT_SUCCESS;
}
#endif
Please Note: Although this is considered to be the main entry point, under the hood it is not, the main entry point comes from the phone OS and is used to start up all the threads, memory, smart pointers etc in order for the PGE Engine to start up. The reason we state that main.cpp is the main entry point is to allow cross compatibility with the OLC PGE 2.0 engine for Windows, MAC, Linux, PlayStation and the list goes on.
- For Visual Studio All In One Android and iOS (Windows) Project Template: OLC Pixel Game Engine Mobile 2.2.8 Visual Studio for Android and iOS
- For Visual Studio Android Only (Windows) Use this project: OLC Pixel Game Engine Mobile 2.2.8 for Android Visual Studio
- For Android Studio (Windows/Linux/MAC) Use this project: OLC Pixel Game Engine Mobile 2.2.8 for Android Studio
- For Xcode (MAC) Use this project: OLC Pixel Game Engine Mobile 2.2.8 for Xcode