Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alaingalvan/CrossWindow
๐ป๐ฑ A cross platform system abstraction library written in C++ for managing windows and performing OS tasks.
https://github.com/alaingalvan/CrossWindow
android cmake cocoa cross-platform emscripten ios linux macos main mir uikit uwp wayland webassembly win32 windows xcb xlib
Last synced: 3 months ago
JSON representation
๐ป๐ฑ A cross platform system abstraction library written in C++ for managing windows and performing OS tasks.
- Host: GitHub
- URL: https://github.com/alaingalvan/CrossWindow
- Owner: alaingalvan
- License: mit
- Created: 2018-04-17T17:48:40.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-06-03T03:09:05.000Z (8 months ago)
- Last Synced: 2024-08-02T07:13:42.320Z (6 months ago)
- Topics: android, cmake, cocoa, cross-platform, emscripten, ios, linux, macos, main, mir, uikit, uwp, wayland, webassembly, win32, windows, xcb, xlib
- Language: C++
- Homepage: https://alain.xyz/libraries/crosswindow
- Size: 4.34 MB
- Stars: 579
- Watchers: 18
- Forks: 49
- Open Issues: 19
-
Metadata Files:
- Readme: readme.md
- License: license.md
Awesome Lists containing this project
- awesome-game-engine-dev - Cross Window - Platform library for managing windows and other OS tasks. (Libraries / C++)
- awesome-audio-plugin-framework - CrossWindow
- AwesomeCppGameDev - CrossWindow
README
CrossWindow
[![cmake-img]][cmake-url]
[![License][license-img]][license-url]
[![Appveyor Tests][appveyor-img]][appveyor-url]
[![Coverage Tests][codecov-img]][codecov-url][Documentation](/docs) | [Demos](https://github.com/alaingalvan/crosswindow-demos) | [Other Libraries](https://github.com/alaingalvan/CrossWindow-Graphics)
**Cross Window** is a cross platform system abstraction library for managing windows and performing OS tasks. It's designed to be easy to integrate, intuitive, and support everything you might need for your apps.
## Features
- ๐ Simple Window, File Dialog, and Message Dialog Creation.
- โจ๏ธ ๐ฑ๏ธ ๐ ๐ฎ Basic Input (Keyboard, Mouse, Touch, and Gamepad).
- ๐ป Platform specific features (Mac Transparency, Mobile Accelerometer, etc.).
- ๐ Unit Tests + Test Coverage ([Appveyor][appveyor-url] for **Windows**, [CircleCI][circleci-url] for **Android / MacOS / iOS**, [Travis][travis-url] for **Linux/Noop**).
### Supported Platforms
- ๐ผ๏ธ Windows - `Win32`
- ๐ Mac - `Cocoa`
- ๐ฑ iOS - `UIKit`
- ๐ง Linux - `XCB` or `XLib`
- ๐ค Android (In Progress)
- ๐ WebAssembly - `Emscripten`
- โ Noop (Headless)
## Installation
First add the **repo as a submodule** in your dependencies folder such as `external/`:
```bash
# โคต๏ธ Add your dependency as a git submodule:
git submodule add https://github.com/alaingalvan/crosswindow.git external/crosswindow
```Then in your `CMakeLists.txt` file, include the following:
```cmake
# โคต๏ธ Add to your CMake Project:
add_subdirectory(external/crosswindow)# โ When creating your executable use CrossWindow's abstraction function:
xwin_add_executable(
# Target
${PROJECT_NAME}
# Source Files (make sure to surround in quotations so CMake treats it as a list)
"${SOURCE_FILES}"
)# ๐ Link CrossWindow to your project:
target_link_libraries(
${PROJECT_NAME}
CrossWindow
)
```Fill out the rest of your `CMakeLists.txt` file with any other source files and dependencies you may have, then in your project root:
```bash
# ๐ผ๏ธ To build your Visual Studio solution on Windows x64
cmake -B build -A x64# ๐ To build your XCode project On Mac OS for Mac OS
cmake -B build -G Xcode# ๐ฑ To build your XCode project on Mac OS for iOS / iPad OS / tvOS / watchOS
cmake -B build -G Xcode -DCMAKE_SYSTEM_NAME=iOS# ๐ง To build your .make file on Linux
cmake -B build# ๐จ Build on any platform:
cmake -B build --build
```For WebAssembly you'll need to have [Emscripten](http://kripken.github.io/emscripten-site/docs/getting_started/downloads.html) installed. Assuming you have the SDK installed, do the following to build a WebAssembly project:
```bash
# ๐ For WebAssembly Projects
mkdir webassembly
cd webassembly
cmake .. -DXWIN_OS=WASM -DCMAKE_TOOLCHAIN_FILE="$EMSDK/emscripten/1.38.1/cmake/Modules/Platform/Emscripten.cmake" -DCMAKE_BUILD_TYPE=Release# Run emconfigure with the normal configure command as an argument.
$EMSDK/emscripten/emconfigure ./configure# Run emmake with the normal make to generate linked LLVM bitcode.
$EMSDK/emscripten/emmake make# Compile the linked bitcode generated by make (project.bc) to JavaScript.
# 'project.bc' should be replaced with the make output for your project (e.g. 'yourproject.so')
$EMSDK/emscripten/emcc project.bc -o project.js
```For more information visit the [Emscripten Docs on CMake](https://kripken.github.io/emscripten-site/docs/compiling/Building-Projects.html#using-libraries).
For **Android Studio** you'll need to make a project, then edit your `build.gradle` file.
```groovy
// ๐ค To build your Android Studio project
android {
...
externalNativeBuild {
cmake {
...
// Use the following syntax when passing arguments to variables:
// arguments "-DVAR_NAME=ARGUMENT".
arguments "-DXWIN_OS=ANDROID",
// The following line passes 'rtti' and 'exceptions' to 'ANDROID_CPP_FEATURES'.
"-DANDROID_CPP_FEATURES=rtti exceptions"
}
}
buildTypes {...}// Use this block to link Gradle to your CMake build script.
externalNativeBuild {
cmake {...}
}
}
```for more information visit [Android Studio's docs on CMake](https://developer.android.com/ndk/guides/cmake).
## Usage
Then create a main delegate function `void xmain(int argc, const char** argv)` in a `.cpp` file in your project (for example "`XMain.cpp`") where you'll put your application logic:
```cpp
#include "CrossWindow/CrossWindow.h"void xmain(int argc, const char** argv)
{
// ๐ผ๏ธ Create Window Description
xwin::WindowDesc windowDesc;
windowDesc.name = "Test";
windowDesc.title = "My Title";
windowDesc.visible = true;
windowDesc.width = 1280;
windowDesc.height = 720;bool closed = false;
// ๐ Initialize
xwin::Window window;
xwin::EventQueue eventQueue;if (!window.create(windowDesc, eventQueue))
{ return; }// ๐ Engine loop
bool isRunning = true;while (isRunning)
{
// โป๏ธ Update the event queue
eventQueue.update();// ๐ Iterate through that queue:
while (!eventQueue.empty())
{
const xwin::Event& event = eventQueue.front();if (event.type == xwin::EventType::MouseInput)
{
const xwin::MouseInputData mouse = event.data.mouseInput;
}
if (event.type == xwin::EventType::Close)
{
window.close();
isRunning = false;
}eventQueue.pop();
}
}
}
```This `xmain` function will be called from a _platform specific main function_ that will be included in your main project by CMake. If you ever need to access something from the platform specific main function for whatever reason, you'll find it in `xwin::getXWinState()`.
## Development
Be sure to have [CMake](https://cmake.org) Installed.
| CMake Options | Description |
| :-----------: | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| `XWIN_TESTS` | Whether or not unit tests are enabled. Defaults to `OFF`, Can be `ON` or `OFF`. |
| `XWIN_API` | The OS API to use for window generation, defaults to `AUTO`, can be can be `NOOP`, `WIN32`, `COCOA`, `UIKIT`, `XCB` , `ANDROID`, or `WASM`. |
| `XWIN_OS` | **Optional** - What Operating System to build for, functions as a quicker way of setting target platforms. Defaults to `AUTO`, can be `NOOP`, `WINDOWS`, `MACOS`, `LINUX`, `ANDROID`, `IOS`, `WASM`. If your platform supports multiple apis, the final api will be automatically set to CrossWindow defaults ( `WIN32` on Windows, `XCB` on Linux ). If `XWIN_API` is set this option is ignored. |First install [Git](https://git-scm.com/downloads), then open any terminal in any folder and type:
```bash
# ๐ Clone the repo
git clone https://github.com/alaingalvan/crosswindow.git --recurse-submodules# ๐ฟ go inside the folder
cd crosswindow# ๐ฏ If you forget to `recurse-submodules` you can always run:
git submodule update --init```
From there we'll need to set up our build files. Be sure to have the following installed:
- [CMake](https://cmake.org/)
- An IDE such as [Visual Studio](https://visualstudio.microsoft.com/downloads/), [XCode](https://developer.apple.com/xcode/), or a compiler such as [GCC](https://gcc.gnu.org/).
Then type the following in your terminal from the repo folder:
```bash
# ๐ผ๏ธ To build your Visual Studio solution on Windows x64
cmake -B build -A x64 -DXWIN_TESTS=ON# ๐ To build your XCode project on Mac OS
cmake -B build -G Xcode -DXWIN_TESTS=ON# ๐ง To build your .make file on Linux
cmake -B build -DXWIN_TESTS=ON# ๐จ Build on any platform:
cmake -B build --build
```Whenever you add new files to the project, run `cmake ..` from your solution/project folder `/build/`, and if you edit the `CMakeLists.txt` file be sure to delete the generated files and run Cmake again.
## License
CrossWindow is licensed as either **MIT** or **Apache-2.0**, whichever you would prefer.
[cmake-img]: https://img.shields.io/badge/cmake-3.18-1f9948.svg?style=flat-square
[cmake-url]: https://cmake.org/
[license-img]: https://img.shields.io/:license-mit-blue.svg?style=flat-square
[license-url]: https://opensource.org/licenses/MIT
[appveyor-img]: https://img.shields.io/appveyor/ci/alaingalvan/CrossWindow.svg?style=flat-square&logo=windows
[appveyor-url]: https://ci.appveyor.com/project/alaingalvan/crosswindow
[circleci-img]: https://img.shields.io/circleci/project/github/alaingalvan/CrossWindow.svg?style=flat-square&logo=appveyor
[circleci-url]: https://circleci.com/gh/alaingalvan/CrossWindow
[codecov-img]: https://img.shields.io/codecov/c/github/alaingalvan/CrossWindow.svg?style=flat-square
[codecov-url]: https://codecov.io/gh/alaingalvan/CrossWindow