An open API service indexing awesome lists of open source software.

https://github.com/gmitch215/cmdfx

🎮 A Game Engine for your Terminal
https://github.com/gmitch215/cmdfx

c cmake cmdfx cpp game game-engine library

Last synced: 12 months ago
JSON representation

🎮 A Game Engine for your Terminal

Awesome Lists containing this project

README

          



CmdFX


A lightweight game engine for your terminal.









---

**cmdfx** is a lightweight game engine for your terminal, allowing you to create some pretty wild things. It is designed to be simple and easy to use, while still providing a powerful set of features.

It is written in C and is available cross-platform. It is licensed under the MIT license.

## 🍎 Features

- **Cross-platform**: cmdfx is available on Windows, macOS, and Linux.
- **Lightweight**: cmdfx is designed to be lightweight and fast.
- **Easy to use**: cmdfx is simple to use and easy to learn.
- **Powerful**: cmdfx provides a powerful set of features for creating terminal-based games.

### 📋 Highlighted Features

For a full method list, check out the [documentation](https://gmitch215.github.io/cmdfx/).

- **Events API**
- Handle window events such as key presses and window resizing.
- Get the current state of the keyboard.
- **Canvas API**
- Draw characters and shapes on the terminal.
- Set foreground and background colors.
- Clear the screen.
- Get the size of the terminal and the screen.
- ...and much more!
- **Sprites API**
- Load and draw sprites on the terminal.
- Set the color of a sprite.
- Create Gradients for a sprite.
- ...and much more!
- **Builder API**
- Easily build 2D arrays of characters and strings.
- Set the color of the text.
- Create gradients of text and colors!
- ...and much more!
- **Physics Engine**
- Create and manage physics objects with the Sprite API.
- Set the velocity and acceleration of a sprite.
- Detect collisions between sprites.
- ...and much more!
- **Input API**
- Get the current state of the keyboard and mouse events.
- Handle key presses and key releases.
- ..and much more!
- **Cross-Platform Exposure**
- Expose platform-specific features and utilities such as setting the title of the terminal.

## 📦 Installation

You can download the latest release of cmdfx from the [releases page](https://github.com/gmitch215/cmdfx/releases).

## 🚀 Examples

```c
#include

int main() {
// Set character at position (4, 4) to 'X'
Canvas_setChar(4, 4, 'X');

// Draw Circle with '#' at position (10, 10) with radius 5
Canvas_fillCircle(10, 10, 5, '#');

// Set Foreground to Red, then draw a line from (0, 0) to (10, 0)
Canvas_setForeground(0xFF0000);
Canvas_hLine(0, 0, 10);
}

```

```c
#include

int main() {
// (path, z-index)
CmdFX_Sprite* mySprite = Sprite_loadFromFile("sprite.txt", 0);
Sprite_setForegroundAll(mySprite, 0xFF0000); // Set Color to Red

// Draw Sprite at position (5, 5)
Sprite_draw(5, 5, mySprite);

// Move Sprite to position (10, 10)
Sprite_moveTo(mySprite, 10, 10);

// (width, height, char, ansi, z-index)
CmdFX_Sprite* background = Sprite_createFilled(10, 10, '#', 0, 0);

// Set Gradient to Foreground with Red, Green, and Gold
Sprite_setForegroundGradientAll(background, GRADIENT_ANGLE_45, 0xFF0000, 0x00FF00, 0xFFD700);
}

```

```c
#include
#include

// Detect when the terminal window is resized
int onResize(CmdFX_Event* event) {
// Get payload data
CmdFX_ResizeEvent* resizeEvent = (CmdFX_ResizeEvent*) event->data;

// Print the previous and new size of the terminal
printf("Terminal resized from %dx%d to %dx%d\n", resizeEvent->prevWidth, resizeEvent->prevHeight, resizeEvent->newWidth, resizeEvent->newHeight);

return 0;
}

int main() {
int r = 0;

Canvas_clearScreen();
addCmdFXEventListener(CMDFX_EVENT_RESIZE, onResize);

while (1) {
// Do nothing while we wait for an event
}
}
```

More examples can be found in the [samples directory](/samples).

## 📝 Contributing

If you would like to contribute to cmdfx, please see the [contributing guidelines](CONTRIBUTING.md). All contributions are welcome!