Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/irishbruse/ldtkmonogame
Monogame importer, renderer and code generator for LDtk Level editor
https://github.com/irishbruse/ldtkmonogame
dotnet ldtk level-editor monogame wiki
Last synced: 1 day ago
JSON representation
Monogame importer, renderer and code generator for LDtk Level editor
- Host: GitHub
- URL: https://github.com/irishbruse/ldtkmonogame
- Owner: IrishBruse
- License: mit
- Created: 2021-01-24T00:21:06.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-14T19:09:15.000Z (3 months ago)
- Last Synced: 2024-12-29T17:14:28.050Z (8 days ago)
- Topics: dotnet, ldtk, level-editor, monogame, wiki
- Language: C#
- Homepage: http://ldtk.ethanconneely.com/
- Size: 22.7 MB
- Stars: 96
- Watchers: 2
- Forks: 19
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
LDtkMonogame is an level importer for the LDtk level editor
# Getting Started
The easiest way to start using LDtkMonogame is to import it into the project using [NuGet package](https://www.nuget.org/packages/LDtkMonogame/).
- [LDtkMonogame](https://www.nuget.org/packages/LDtkMonogame/)
- [LDtkMonogame.ContentPipeline](https://www.nuget.org/packages/LDtkMonogame.ContentPipeline/)
- [LDtkMonogame.Codegen](https://www.nuget.org/packages/LDtkMonogame.Codegen/)Make sure to import the namespace at the top
```cs
using LDtk;
// Optional
using LDtk.Renderer;
```LDtk.Renderer is a premade renderer for the levels, you can create your own if you have more specific needs
[ExampleRenderer.cs](https://github.com/IrishBruse/LDtkMonogame/blob/main/LDtk/Renderer/ExampleRenderer.cs)
is an example of how to make one. Or you can inherit it and extend it.To get started loading ldtk files load the file in `Initialize`.
```cs
LDtkFile file = LDtkFile.FromFile("World", Content);
LDtkFile file = LDtkFile.FromFile("Data/World.ldtk");
```Then load the world right after for now ldtk only supports one file but make sure to enable the multiworlds flag in the project settings under advanced.
```cs
LDtkWorld world = file.LoadWorld(Worlds.World.Iid);
```The `Worlds.World.Iid` is generated from the ldtkgen tool and is recommended that you use it for static typing of entities and levels.
It is a class within in a class that represents the world name and the levels name and holds the iid you can use to load that specific level.Create the renderer in `Initialize`.
```cs
ExampleRenderer renderer = new ExampleRenderer(spriteBatch, Content);
ExampleRenderer renderer = new ExampleRenderer(spriteBatch);
```Prerender Levels
```cs
foreach (LDtkLevel level in world.Levels)
{
renderer.PrerenderLevel(level);
}
```Now to render the level and entities we loaded in `Draw`
```cs
GraphicsDevice.Clear(world.BgColor);spriteBatch.Begin(samplerState: SamplerState.PointClamp);
{
foreach (LDtkLevel level in world.Levels)
{
renderer.RenderPrerenderedLevel(level);
}
}
spriteBatch.End();
```# Showcase
## Unnamed
![screenshot](https://raw.githubusercontent.com/IrishBruse/LDtkMonogame/main/docs/Unnamed.png)
> by Fypur
[Play the game on Itch](https://fypur.itch.io/unnamed)
## Example Game
![screenshot](https://raw.githubusercontent.com/IrishBruse/LDtkMonogame/main/LDtk.Example/Screenshot.png)
> by IrishBruse
[Source code here](./LDtk.Example/)