kaliber/README.md

88 lines
2.7 KiB
Markdown
Raw Normal View History

2023-08-04 23:52:07 +00:00
# Kaliber
2020-12-24 23:22:41 +00:00
A simple, cross-platform 2D game engine with OpenGL and Vulkan renderers.
2023-08-12 21:30:28 +00:00
Supports Linux, Windows and Android platforms.
2020-12-24 23:22:41 +00:00
This is a personal hobby project. I've published a little game on
[Google Play](https://play.google.com/store/apps/details?id=com.woom.game)
2021-08-31 21:21:29 +00:00
based on this engine. Full game code and assets are included in this repository.
2023-08-04 08:27:13 +00:00
## Pre-requisites:
2023-08-12 21:30:28 +00:00
**GN build system** is required for all platforms except Android:\
https://gn.googlesource.com/gn/
2023-08-03 20:03:44 +00:00
2023-08-12 21:30:28 +00:00
**Build Tools** is required to build for Windows. if you prefer, you can install
**Visual Studio** which includes the **Build Tools**.
Linux is the supported host platform to build for Android. **Gradle**,
2023-08-04 08:27:13 +00:00
**Android SDK** and **NDK** are required. If you prefer, you can install
2023-08-04 23:52:07 +00:00
**Android Studio** which includes all the requirements.
## Building from the command-line:
### All platforms except Android:
Setup:
```text
gn gen out/release
2023-08-12 22:00:09 +00:00
gn gen --args="is_debug=true" out/debug
```
Building and running:
```text
ninja -C out/debug
./out/debug/hello_world
./out/debug/demo
```
2023-08-12 21:30:28 +00:00
Building and debugging from VS Code:
* Select "Debug demo - [platform]" from the "Run and Debug" drop down.
* Press F5.
### Android:
```text
cd build/android
./gradlew :app:installDebug
```
## Third-party libraries:
[glew](https://github.com/nigels-com/glew),
[jsoncpp](https://github.com/open-source-parsers/jsoncpp),
[minimp3](https://github.com/lieff/minimp3),
[oboe](https://github.com/google/oboe),
[stb](https://github.com/nothings/stb),
[texture-compressor](https://github.com/auygun/kaliber/tree/master/src/third_party/texture_compressor),
2020-12-24 23:22:41 +00:00
[minizip](https://github.com/madler/zlib/tree/master/contrib/minizip),
[glslang](https://github.com/KhronosGroup/glslang),
[spirv-reflect](https://github.com/KhronosGroup/SPIRV-Reflect),
[vma](https://github.com/GPUOpen-LibrariesAndSDKs/VulkanMemoryAllocator),
2023-05-19 12:49:33 +00:00
[vulkan-sdk](https://vulkan.lunarg.com),
2023-05-12 21:22:18 +00:00
[volk](https://github.com/zeux/volk)
## Hello World example:
Shows a smoothly rotating "Hello Wolrd!".
```cpp
class HelloWorld final : public eng::Game {
public:
~HelloWorld() final = default;
bool Initialize() final {
eng::Engine::Get().SetImageSource(
"hello_world_image",
std::bind(&eng::Engine::Print, &eng::Engine::Get(), "Hello World!",
base::Vector4f(1, 1, 1, 0)));
2023-08-04 23:52:07 +00:00
hello_world_.Create("hello_world_image").SetVisible(true);
animator_.Attach(&hello_world_);
animator_.SetRotation(base::PI2f, 3,
std::bind(base::SmootherStep, std::placeholders::_1));
animator_.Play(eng::Animator::kRotation, true);
return true;
}
private:
eng::ImageQuad hello_world_;
eng::Animator animator_;
};
2023-08-04 23:52:07 +00:00
GAME_FACTORIES{GAME_CLASS(HelloWorld)};
```