Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/isadorasophia/murder
Murder is a pixel art ECS game engine.
https://github.com/isadorasophia/murder
fna game-engine gamedev monogame multi-platform
Last synced: 6 days ago
JSON representation
Murder is a pixel art ECS game engine.
- Host: GitHub
- URL: https://github.com/isadorasophia/murder
- Owner: isadorasophia
- License: mit
- Created: 2022-10-23T07:26:28.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2025-01-02T05:30:58.000Z (13 days ago)
- Last Synced: 2025-01-03T02:17:44.365Z (12 days ago)
- Topics: fna, game-engine, gamedev, monogame, multi-platform
- Language: C#
- Homepage: https://isadorasophia.com/murder/
- Size: 16 MB
- Stars: 2,518
- Watchers: 39
- Forks: 63
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-monogame - **Murder** - ![GitHub stars](https://img.shields.io/github/stars/isadorasophia/murder.svg) - Murder is a pixel art ECS game engine. (Engines)
- awesome-game-engine-dev - Murder - Pixel-art, ECS game engine built on _MonoGame_. [[Docs](https://isadorasophia.com/murder/)] (Libraries / C#)
README
Welcome to Murder Engine!
This is the source for Murder Engine, a pixel art ECS game engine built on top of FNA.
> 🚧👷 **Warning** Proceed at your own risk. This is an in-development engine, which is another way of saying that it will change _quite a lot_. We do our best to keep release branches stable, but expect a lot of breaking changes and things that are not perfect (yet!).
### How to build it?
If you're good at just digging examples and figuring things out, I recommend starting out with our [game jam project](https://github.com/isadorasophia/neocityexpress) or the [Hello World project](https://github.com/isadorasophia/hellomurder). These projects show what to expect from the Murder architecture and how to create a world, entities and components, which ECS is all about.
> ...I realize this is quite redundant because the Hello World references this repository as a documentation source, but hang with me.
This is what the architecture looks like:
```
└── root
└── resources
└── src
├── game
│ ├── bin (final game)
│ ├── packed
│ └── resources
└── game.editor
├── bin (game editor)
└── resources
```You may notice that **there is no external editor.exe**, only your own project. This is so you can have full control of your project! Very similar of what you expect developing a [MonoGame](https://www.monogame.net/) or a [FNA](https://fna-xna.github.io/) project, for example.
The idea of a separate project for the editor is that editor code never touches your beautiful and efficient game code, and you can do whatever you want on the editor side.
There is no nuget package for Murder yet, so the recommended way is to keep a git submodule to reference in your .csproj, [see example](https://github.com/isadorasophia/hellomurder/blob/main/src/HelloMurder/HelloMurder.csproj).
For more information on how the ECS applies to the engine, I recommend checking out the documentation for [Bang](https://github.com/isadorasophia/bang), the framework that Murder uses.
### Requirements
We support developing (which means, running the editor) on **Linux, MacOS, Windows** and even **SteamDeck**. All you really need is .NET 8 SDK installed. The game obviously also ships to all these architectures.Console support is still on progress.
### Contributing
This is still super early, but feel free to contact me or [saint11](http://saint11.org/) if you have any suggestions. I am very interested in people trying it out and any feedback you may have!### ✨ Editor examples