sparker256 / imgui4xp

Imgui Template For X-Plane 11 Also Showing How To Support Multi Platform From Linux

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

imgui4xp

Imgui Template For X-Plane 11 Also Showing How To Support Multi Platform From Linux

I am documenting the process I took to get a multiplatform stand alone plugin that supports imgui on X-Plane built on Ubuntu 18.04 LTS. My goal it to make it easier for the next developer to accomplish the same task. With this template you should be able to develop an idea on FlyWithLua NG using its new support for imgui and when developed far enough then convert it to a stand alone plugin with no need for lua. I hope someone will find this useful.

Thanks to kuroneko on x-plane.org and his repository at https://github.com/xsquawkbox/xsb_public we have added the ability to select the font you want to use and also use the ImGui::SetWindowFontScale(1.00) function to set the size you want your fonts to be. You first pick the font you want for the project then using the ImGui::SetWindowFontScale(1.00) function you can change the size of the font on any line you chose.

First clone imgui4xp using this command "git clone https://github.com/sparker256/imgui4xp.git" and put the resulting imgui4xp folder wherever you like. I normally put myself in the folder where I want the repository folder to reside first.

Multi Platform Build from Linux

Since I develop on Linux my IDE of choice is QT Creator which is installed from my package manager.

I have scripts and make files that allow me to click on one button on my desktop and automatically build for all three platforms.

You will need a compiler to build the Linux files and the following command will get that for you.

sudo apt-get install build-essential

To build for Windows on Ubuntu you will need to use this command:

sudo apt-get install mingw-w64

To build the Mac files on Ubuntu you need to go to the osxcross GitHub site found here.

https://github.com/tpoechtrager/osxcross

And follow there instructions and then you will need to install the clang compiler using this command.

sudo apt-get install clang-3.8

With all this correctly installed you to should be able to build for all three platforms on Ubuntu using Cmake.

Multi Platform Build using Docker

I have now also added the ability of using Docker to build for all three platforms. Find more information in docker/README.md.

Windows: Visual Studio

On Windows, you can use Visual Studio's "Open Folder" feature to open the project's src folder and build the plugin based on its CMake configuration.

Results will be in src/build-win.

Mac OS: Xcode

An Xcode project is provided as imgui4xp.xcodeproj.

You may want to change the value of the user-defined build macro XPLANE11_ROOT in the build settings to point to your X-Plane 11 installation. Then the resulting binary is installed there right away.

Imgui4xp

Imgui4xp

About

Imgui Template For X-Plane 11 Also Showing How To Support Multi Platform From Linux

License:MIT License


Languages

Language:C++ 53.1%Language:C 38.5%Language:Pascal 6.1%Language:Objective-C++ 1.3%Language:Makefile 0.3%Language:Objective-C 0.3%Language:CMake 0.1%Language:Batchfile 0.1%Language:Shell 0.0%Language:Dockerfile 0.0%Language:HTML 0.0%Language:QMake 0.0%Language:GLSL 0.0%