Skip to main content

4 posts tagged with "Updates"

Updates to the MonoGame.Extended library.

View All Tags

Version 5.1.1 Released - Ember Is Here!

· 3 min read
Christopher Whitley (AristurtleDev)
MonoGame.Extended Maintainer

Hi everyone,

I'm excited to announce the release of MonoGame Extended version 5.1.1, which officially launches Ember, the particle effect editor for MonoGame Extended!

If you've been following along, you may remember that Ember had a soft release for community feedback. Well, that feedback period is over, and I'm thrilled to share that Ember is now ready for its full public release. This 5.1.1 update to MonoGame Extended ensures full compatibility with Ember's file format and workflow.

What Is Ember?

Ember Editor

Ember is a standalone particle effect editor built specifically for the MonoGame Extended particle system. It provides a visual, real-time environment for creating, editing, and fine-tuning particle effects without having to recompile your game every time you want to tweak a value.

The editor is built using MonoGame itself (DesktopGL) with a Dear ImGui interface, which means what you see in Ember is exactly what you'll get in your game.

Key Features

  • Real-time visual editing - See your particle effects update instantly as you adjust parameters
  • Complete particle system support - Full access to all emitters, modifiers, profiles, and parameters
  • Project-based workflow - Save your effects as .ember files that can be loaded directly into your MonoGame Extended projects
  • Accurate rendering - Built on MonoGame DesktopGL to ensure perfect rendering fidelity

Getting Started with Ember

Head over to the Ember documentation to get started. The quick start guide will walk you through downloading Ember, creating your first particle effect, and loading it into your MonoGame Extended project.

For those who have been using the particle system programmatically, you'll find that Ember integrates seamlessly with your existing workflow. Effects created in Ember can be loaded using the ParticleEffect.FromFile() method that was introduced in version 5.1.0.

What's Next?

With Ember officially released and the particle system documentation complete, the particle system will be entering maintenance mode. This means I'll continue to fix bugs and address issues, but no major new features are planned for the immediate future.

My focus is now shifting to the tile map system in MonoGame Extended. There's a lot of exciting work planned there, and I'm looking forward to bringing the same level of polish and tooling to tile maps that we've achieved with the particle system.

Thank you to everyone who provided feedback during the soft release period. Your input helped shape Ember into a tool that I hope you'll find invaluable for your projects.

Happy particle creating!

- ❤️ Chris Whitley (AristurtleDev)

Version 5.1.0 Released

· 3 min read
Christopher Whitley (AristurtleDev)
MonoGame.Extended Maintainer

Hi everyone,

Quick update that MonoGame Extended version 5.1.0 has been released. This release brings some updates to the particle system refactor that was done as part of the 5.0.0 release. After working through through updating the particle documentation, I noticed that some of the implementations seemed off or didn't work as expected, so in tandem with documenting, I also did some updates.

What's Changed

Load Ember Particle Effects From File/Stream

The ParticleEffect.FromFile and ParticleEffect.FromStream methods have been implemented. This is in preparation for the full release of the Ember Particle Editor that will be coming very soon to visually create particle effects.

Reference: https://github.com/MonoGame-Extended/Monogame-Extended/pull/1023

Modifier Frequency

There was a bug in the core implementation of the modifiers where the Frequency property was not actually being used. The purpose of this property is to control the frequency in which the modifier updates particles so you can fine tune the system in performance heavy scenarios. This was a property that was in the original Mercury Particle Engine, but when that was ported over to MonoGame Extended, it was left unused.

Reference: https://github.com/MonoGame-Extended/Monogame-Extended/pull/1025

Line Profile Radiation Modes

When using the LineProfile in the particle system, there is now a Radiation property that can be set. This property allows you as the user to control how particles emissions radiate from the line itself. The default behavior before this was that particles would emit with a randomly chosen velocity from the line. This is still the default behavior for backwards compatability and is what happens when using the LineRadiation.None value. See the table below for what each radiation mode does

Line RadiationDescriptionVisual Effect
LineRadiation.NoneRandom directions regardless of line angleLineRadiation.None Example
LineRadiation.DirectionalAll particles move in the specified directionLineRadiation.Directional Example
LineRadiation.PerpendicularUpParticles move perpendicular upward from lineLineRadiation.PerpendicularUp Example
LineRadiation.PerpendicularDownParticles move perpendicular downward from lineLineRadiation.PerpendicularDown Example

Reference: https://github.com/MonoGame-Extended/Monogame-Extended/pull/1027

Vortex Modifier

While documenting the various modifiers, I noticed something strange about the VortexModifier....it didn't actually create or simulate any type of vortex. Instead it acted as a gravity well, or an acctractor that just pulled particles into its center mass and expelled them out. We can't have this, if we're going to call it a VortexModifier it needs to create a vortex. So this modifier was updated to do what it says now

VortexModifier Example

Reference: https://github.com/MonoGame-Extended/Monogame-Extended/pull/1031

Conclusion

With this release done and the documentation completed for the particle system, I can now focus on finishing up the documentation for the Ember Particle Editor to so we can do an official release of it. If you want to read the new documentation on particles, you can start with the Quick Start Guide.

Once Ember documentation is completed and a full release made, the particle system will go into maintenance mode while focus is shifted to work on tne tile map system in MonoGame Extended. Hope you all are looking forward to that.

Happy Coding,

- ❤️ Chris Whitley (AristurtleDev)

The Next Chapter for MonoGame Extended

· 5 min read
Christopher Whitley (AristurtleDev)
MonoGame.Extended Maintainer

Hi everyone,

It's been nearly a year since my last update, and I wanted to reach out to the community with some important news about the future of MonoGame.Extended. But before I get to the main announcement, I need to address a few things and share some updates on what's been happening behind the scenes.

Catching Up and Apologies

First, I owe everyone an apology for the delay in project updates and communication. I know many of you have been waiting for progress reports and wondering about the direction of MonoGame.Extended. The truth is, I've been deeply involved in other MonoGame community work that has taken significant time and focus.

Over the past year, I've been working extensively on the MonoGame 2D Onboarding Tutorial, which is now available in the official MonoGame documentation. This comprehensive tutorial series was a major undertaking aimed at helping new developers get started with MonoGame, and while it meant less visible progress on MonoGame.Extended, I believe it serves the broader community that MonoGame.Extended is part of.

What's Been Happening

Despite the quieter public presence, work on MonoGame.Extended has continued. I've been deep in the process of updating the particle system, which was one of the most requested and sponsored by a community member. This is more than just a simple update; it's a designed to be more performant, flexible, and easier to use.

Along with the particle system refactor, I've been developing Ember, a new GUI editor specifically for creating and managing particle effects. This tool will make it dramatically easier for developers to create complex particle systems without having to hand-code everything.

Ember Preview

I also want to take a moment to acknowledge and thank Jeremy (kaltinril) for his incredible effort in updating and improving our documentation. Good documentation is crucial for any library's success, and Jeremy has been working tirelessly to make sure our docs are clear, comprehensive, and helpful for both new and experienced users. His contributions have made a real difference in the project's accessibility.

A New Official Home

Now, for the main announcement. After careful consideration and valuable feedback from the community members I"ve reached out to, I'm excited to announce that MonoGame.Extended has moved to a new official home:

The repository has been transferred from the craftworkgames organization to a new dedicated organization called MonoGame-Extended on GitHub.

Why this change makes sense:

  • Clear identity and ownership - The new organization makes it immediately clear what the project is and creates an official presence in the ecosystem
  • Long-term sustainability - Rather than being tied to any individual maintainer, the project now has an organizational structure that can support leadership transitions and growth
  • Room for expansion - The organization provides space for additional repositories including samples, demos, templates, tools like Ember, and other MonoGame.Extended related projects

What this means for you:

  • Everything transfers intact - All stars, forks, issues, pull requests, and the complete project history will move with the repository
  • Seamless transition - GitHub automatically handles URL redirects, so your existing bookmarks and links will continue to work
  • Continued commitment - The same dedication to quality and community that brought you version 4.0.0 and the ongoing improvements continues unchanged

Acknowledging Our Foundation

I want to take a moment to properly acknowledge the people who made MonoGame.Extended what it is today. Dylan (craftworkgames) created something truly special when he built the original MonoGame.Extended. His vision and foundational work created a library that has served countless developers and projects over the years. When Dylan was no longer able to maintain the project, Lucas (lithiumtoast) stepped in, working to keep things moving when the project needed continuity.

Both of their contributions and other community members laid the essential groundwork that made it possible for me to pick up the project and bring it back to active development. MonoGame.Extended stands on the shoulders of their efforts, and this new chapter is built upon the solid foundation they created.

Moving Forward

This move represents the natural evolution of MonoGame.Extended as it enters a new phase of active development and community growth. With the particle system refactor and Ember nearing completion, improved documentation, and now an official organizational home, the project is positioned for continued success and expansion.

The MonoGame.Extended community has been incredible throughout this journey. Your feedback, contributions, bug reports, and continued usage of the library have been invaluable in bringing the project back to life and pushing it forward. This new foundation ensures that community energy and contribution can continue to drive the project's growth.

If you have any questions or concerns about this transition, please feel free to reach out in the comments below or find me on the MonoGame.Extended Discord.

Here's to the next chapter of MonoGame.Extended.

Thanks everyone,

- ❤️ Aris

Version 4.0.0 Initial Release

· 5 min read
Christopher Whitley (AristurtleDev)
MonoGame.Extended Maintainer

I've been working hard this past month on getting a new "stable" release of MonoGame.Extended out. Not only was there a backlog of issues that needed to be resolved, but the current released NuGets were not compatible with the current version of MonoGame (v3.8.1.303). This made it more difficult for users to actually use MonoGame.Extended if they wanted to use NuGets instead of referencing directly from source.

So why did I put the word "stable" in quotes above? While not all planned issues have been resolved for the new release, after talking another developer friend, I've made the decision to release version 4.0 as it is right now (thanks Vic). This allows users to go ahead and start using the current version which is compatible with MonoGame 3.8.1.303 and has many bug fixes already implemented. In the meantime, work will continue to resolve outstanding issues and feature requests and they will be pushed as patch or minor semver releases as they are finished.

The trade off here is more smaller but more frequent releases but consumers can roll forward with bug fixes as they get resolved.

So with that said, let's talk about some of the major changes that are coming in with this initial release and why these changes were made.

A Single Project

Well, really it's two projects, MonoGame.Extended and MonoGame.Extended.Content.Pipeline. However, the decision was made to take all the individual library projects like MonoGame.Extended.Graphics, MonoGame.Extended.Input, MonoGame.Extended.Entities, etc and move them so they are just all part of MonoGame.Extended. While each of these individual projects did add specific functionality that was separate from the core project, the majority of them were really tiny projects that just added noise both on NuGet and to the number of additional libraries to install.

So gone are the days of installing multiple NuGets to get the full benefits of MonoGame.Extended. There is now one NuGet to rule them all (and also the content pipeline one).

tip

If you have been using the prerelease versions from source before updating, ensure you delete the .artifacts directory after you update your local source so that the old project builds aren't still cached there. (thanks TurtleBaseAlpha (tigurx)).

Project Restructure

For many, updating to v4 initially is going to give you some red squigglies. This is because many parts of the project were restructured to mirror the base MonoGame project where it could. For instance, things related to graphics like Texture2DRegion, Texture2DAtlas, and SpriteSheet were moved to the MonoGame.Extended.Graphics namespace. These classes all deal with using and extending Texture2D so they are in a mirrored namespace.

For many of the errors you will have initially when updating, it will just be needing to change the namespace. Only a small handful of things were renamed to better reflect what they are (e.g. TextureRegion2D was renamed to Texture2DRegion).

Content Pipeline Woes

One of the biggest headaches was using the MonoGame.Extended.Content.Pipeline extensions and adding the dll reference in the MGCB Editor. This isn't a problem that is unique to MonoGame.Extended, all third party content pipeline extensions have to deal with this. The problem is that the NuGets are downloaded to the global nuget cache on your PC. So when you add the reference in the MGCB Editor, file path is stored as a relative path in the Content.mgcb file. This means that if you move your project folder, or if you are working with a team and sharing a repository, that relative path is going to break unless the project directory is always in the same place on every PC you use.

There have been many workarounds and suggestions on easing this for the consumer in talks between third party developers. There is no one-solution-fits-all scenario and each workaround has its tradeoffs. Previously MonoGame.Extended recommended adding a nuget.config file to your project to force the NuGets to download locally to your project directory, thus ensuring the relative path was always relative within the project directory. This isn't a bad solution, but it does mean you're altering the default way NuGet is handled for that specific project, which isn't ideal if you don't want to actually do that (it affects all NuGets for the project, not just the MonoGame.Extended.Content.Pipeline one).

With version 4, I have implemented a new workaround to ease this issue. The MonoGame.Extended.Content.Pipeline NuGet now ships with a .targets file. Whenever you do a project build, this task will execute just before the actual build occurs and also before the MonoGame content task runs to build content. The task will copy the MonoGame.Extended.Content.Pipeline.dll and its dependency assemblies to a path specified by you, the consumer, for easier referencing of the dll as well as making the relative path issue with the Content.mgcb not as brittle.

So how does this work? The documentation was updated with the new steps, but we'll cover it briefly here. After adding the MonoGame.Extended.Content.Pipeline NuGet, consumers will now need to update their project's .csproj file and add the following property manually

<PropertyGroup>
<MonoGameExtendedPipelineReferencePath>$(MSBuildThisFileDirectory)pipeline-references</MonoGameExtendedPipelineReferencePath>
</PropertyGroup>

This new MonoGameExtendedPipelineReferencePath property defines the path that the task will copy the dependency dlls too. The above snippet is the recommended default, however it was designed this way so that the consumer can choose the path instead of the library assuming the path for them.

If you use the content pipeline extensions, please give me any feedback on this new method, good or bad.

To Close Out

That's all I have for you for now. Version 4 "stable" is officially released and smaller, but more frequent, releases will follow for various bug fixes and features. If you have any questions or concerns, please let us know. You can use the comment section below which is linked with the MonoGame.Extended GitHub Discussion board, or you can come by the MonoGame.Extended Discord and yell at me.

Thanks everyone,

- ❤️ Aris