1. StarMade
  2. News

StarMade News

StarMade 0.203.101

Greetings citizens,

as announced this is a minor update by the community, already using the opened codebase.

It fixes a few bugs, as well adds a mod-loader.

Bug fixes:

  • Fixed AI leading beam shots
  • Fixed the "Require authentication" being enabled by default, making people unable to log into single player without uplink.
  • Made factory progress bars not factoring in the Factory Bake Time chamber
  • New UI for the blueprint manager
  • Effects and defenses now use a more straightforward formula, where the defense rating subtracts a percentage of incoming damage in the corresponding offensive effect type
  • Fixed an issue where all defense ratings were multiplied by zero. Defensive effects (such as armor chambers and innate defenses from the BlockBehaviorConfig) are now functional.


There is also an addition of an in-development mod loader. Note that there may be some bugs, please report these to the StarLoader discord

Joining modded servers will automatically download the mods needed to join. Servers may still experience a few bugs, however, but hopefully not many.

The modding API is a work in progress and subject to change, but many of the core systems are in place. Check the StarLoader discord for tutorials.

The code is currently open on an invite-based system until we made sure that everything is in order. If you like to contribute, please feel free to send me (schema) a PM in the StarMade discord.

(special thanks to all the people working on the code already, enabling new updates. Special thanks to the StarLoader Team & Community as well.)

Thanks for playing the game,
- schema, the Schine crew, and the StarLoader Team & Community.

Fixed Launcher Login

A SSL cache issue has caused the launcher to think that the certificate is expired.
The update should fix that.

There will be an actual game update and more news within the next few days.

The summery of that:

  • StarMade will go Open Source for the community. (since I can't work on it until I have enough money to not have to work on other projects for a while)
  • Community mod launcher
  • Balance updates and bugfixes


Sorry for the long wait without update. I'm still alive and want to finish the game, but I'll leave the source for the community for now.

- schema

STARMADE V0.202.86 - BALANCE CHANGES

Hello players,



The universe update is well underway and the code bases are now so different that any change on the old version takes a lot of time because of migrating. For this reason, this will probably be the last update on the non-universe-update version of StarMade.



It introduces balance changes that the Quickfire initiative developed and tested.

[h2]Unobfuscation[/h2]
To make modding and general extensions of the game easier the game's code is now unobfuscated.


[h2]Quickfire[/h2]
The Quickfire Initiative configs are very different from the old defaults. The config set was created by Quickfire's core team of configurators, with input from other members of the community, including PvP enthusiasts, creative builders, and others.

This is a complete overhaul of the game's configs. Most systems are balanced very differently than they were previously, including power consumption, mass, potency per block, and even some aspects of mechanics. As such, you should expect that most ships will require refits to function.

The Quickfire team is available for any support, question, suggestion for changes, or barrage of rotten tomatoes on their thread here https://starmadedock.net/threads/the-quickfire-initiative-rebalancing-starmade.31326/ , or in their discord server https://discordapp.com/invite/45zmQBe




[h3]OVERVIEW[/h3]​


The Quickfire config changes cover a broad spectrum of StarMade's systems, which have been determined to be broken or imbalanced in the vanilla game. The following is a short overview of the most important changes, with a more comprehensive document of all changes available via a link below.



Power:

-Disabled stabilizer distance.

-Set maximum power from stabilization to 100%. (25% was pointlessly unintuitive)

Chambers:

-Rebalanced chamber capacity requirements across the board (see document below)

-Changed chamber size formula, to not force certain reactor sizes for optimal mass efficiency

Thrusters:

-Nerfed thruster scaling overall. There should be more variance in ship maneuverability and top speeds now depending on ship size and design.

-Made diminishing returns on thrust harsher.

-Increased TWR cap for max speed to 5.0

Armor:

-Made armor lighter and more effective.

-Made armor layering/stacking significantly more effective. (should make thick or slanted armor more viable)

Shields:

-Buffed shields relative to weapons overall

-Nerfed/adjusted Anti Low Damage chamber to only block actual low damage relative to shield capacity

-Buffed Anti High Damage chamber, lowered threshold for "High Damage" to better protect against large hits.

Weapons:

-Rebalanced weapons across the board

-Removed cursor recoil on cannons

-Helped to track down and resolve the infamous 'tunnelling' bug with cannon projectiles

-Replaced the broken Doom Beam with a high-range pulse laser

-Worked with Schine to fix missile guidance

-Made missile capacity less restrictive

-Adjusted bomb to hopefully be more usable (see document below)

Other:

-Buffed Tractor Beam

-Adjusted some chamber abilities, such as scanning and Thrust Burst.



A more detailed document is available here: https://docs.google.com/document/d/1qrqa4wB13Djx09Ql1atWfHxKD7MJCubFsidHwQgV3x4/edit



Additional notes are available here:

https://docs.google.com/document/d/1ilNdPmw-8wMq2nooUcBZhrYG3Z1IWA59vwSo8hhF9Js/edit

Thanks to all the quifire members who developed and tested these changes.

This will also likely be the last major change to balance for ships. Unless it’s absolutely necessary, changes after this will only affect smaller aspects.



Thanks for playing StarMade,

- The Schine Team

Big performance increases (I/O) - Universe update dev dump 4 [30 OCT - 7 NOV]

Screenshot and station build by SkylordLuke.

This is the fourth universe update dump copied from our official Discord server, in the channel #universe-update-dev-news-dump. To receive universe update news as it happens, join our Discord channel here: Join the StarMade Discord Server!

Previous Discord dumps:


TL;DR

Between the dates of the 30th of October - 7th of November, the following was done:

Write/read overhaul, the goal being to eliminate lag caused by sector changes entirely. Sector changes would be hidden internally, and we'll switch to a more straightforward region system. This is split up into three main parts.
  • Decoupling of data accumulation and the actual writing. Essentially we no longer need to synchronise the writing thread during writing, making I/O operations not affect performance.
  • System to mark objects in a sector for writing, as well as a spawn/cleanup system for new sectors and for sectors no longer loaded.
  • Sector change performance tweaks to make switching sectors a seamless experience.
Further information:

As part of the decoupling, we've switched block data to off-heap memory (unsafe native memory). This is a lot faster in pretty much all operations. Memory for block chunks is preallocated in one big chunk of memory. This is so the access speed is as fast as possible by reducing cache misses.

It is then segmented for maximum optimisation for memory I/O. For writing, a second chunk is allocated as a buffer and memory can be copied over and queued up to be written. That copy operation is extremely fast, and that subsequent disk I/O operation would be done completely independently in another thread without the need to sync. The only thing we need to make sure of is that the object does not get unloaded while it's writing. This wouldn't cause a bad write (the data is already copied), but a load would read old data. The current system already has the same conditions, so nothing actually changes there.

The drawbacks for this are that if something does go wrong, it goes spectacularly wrong. So far, there does not seem to be any issues since switching to unsafe native memory. Excitingly this same procedure can be used to speed up other aspects of the game, such as lighting calculations. And since the new planet generation is written in C++, we can potentially eliminate overhead of passing arrays back and forth, since we can just tell the C++ library the memory address to store a chunk in.


What's coming up:
  • New universe creation details, creating an ultimate goal for the game, conquer the galaxy! This would be a separate gamemode from our standard sandbox experience. Compacting resources and gameplay into a central area.
  • Population system plans. A new "resource" to fuel and grow an empire, represented by physical NPCs!
  • New planet discussion and screenshots of some of the planet work we've currently got in development! 🪐

--- Below is the more detailed discord posts about development done ---

October 30th

likely starting on the write/read overhaul now. The goal is to eliminate lag etc from sector changes, making sector changes in general something that can be hidden internally, and instead use a more simple region system for the game (as was planned)
This update would incorporate different things
step one would be the decoupling of data accumulation and the actual writing. Doing that will enable putting removing any necessity to synchronize the writing thread during the actual writing, making I/O operations not affect the game at all.
The second one is the system that marks objects of a sector for writing as well as the spawn/cleanup system for new sectors and for sectors no longer loaded
The third one would be the actual sector change, making that as smooth as possible for the player.
This is likely one of the biggest parts of the universe update. because once that is in, i'll be able to restructure the universe.
After that I'll likely work on the new planets. I'm aiming to have both done so I can give a small snapshot this year. This snapshot version would be completely dysfunctional of course, but hopefully people could test out some of the new stuff under the hood.


October 31st

as part of the uncoupling, I'm switching block data to off heap memory. This is a ton faster in pretty much all operations. it's pretty unsafe in case of mistake. However it is worth it. So the plan is that memory for block-chunks is preallocated in one big chunk of memory which is then segmented for the maximum optimization for memory I/O. For writing, a second chunk is allocated as a buffer and memory can be copied over and queued up to be written. That copy operation is extremely fast, and that subsequent disk I/O operation would be done completely independenly in another thread without the need to synch (only thing is to make sure the object doesn't get unloaded while it's writing. not because that would cause a bad write since the data already copied, but because a load would read old data. However, the current system already has the same conditions anyways, so nothing really changes there)

Happy Halloween!


1st of November

Alright, chunk data is now running on unsafe native memory. So far there seems to be no issues. I added a manual range check just for debugging, which can be deactivated later for another little performance boost. It's now also possible to speed up some other aspects using the same tech (e.g. the lighting calculations)


4th of November

Still in the middle of memory stuff. But this is the kind of stuff i love doing most in programming.


7th of November

Ok. Got a nice manager going for the chunks stored in native memory. Memory will be reused as chunks get unloaded. Also protection against leaks my making sure that every chunk unregisters itself from that page.
This is also one huge chunk of memory, which means that access speed is as fast as it can be, by reducing cache misses.
Wouldn't get the same result with a heap array, since it is not guaranteed to be one continuous chunk of memory even. There is a flag for java to use big memory pages, which helps a little. This flag of course is only relevant for the heap. However, the chunks are now outside of the heap in spooky scary manually managed memory.
Using this kind of memory completely bypasses all java heap functionality, including garbage collection. The advantage is of course a fastest possible access speed, the disadvantage is that IF something goes wrong, it goes wrong spectacularly. With raw data as blocks, the potential of complete meltdown is relatively simple, as long as you make sure you only address the memory you allocated.
You could also store whole objects etc on there in which case any misstep would lead to catastrophe from random fields changing to complete object corruption.
Another nice side effect is, that since the new planet generation is written in C++, we can potentially eliminate the overhead of passing arrays back and forth since we can just tell C++ library the memory address to store the chunk in.

Audio system finished, GUI scaling and better resource loader! [11 OCT - 29]

Image is of USS Endeavor, by Wilavid7. You can check out the progress of his ship here. Background image taken by 12yanogden.


This is the third universe update dump copied from our official Discord server, in the channel #universe-update-dev-news-dump. To receive universe update news as it happens, join our Discord channel here: Join the StarMade Discord Server!

Previous Discord dumps:
TL;DR

Between the dates of the 21st of October - 29th, the following was done:
  • Audio system finished.
    • Remote audio events now implemented, allowing the server to send an audio event. These events are only sent to players in range of the actual source of the audio (with the option of sending globally). Saving bandwidth and removing a potential area for bugs.
    • Advanced audio events implemented.
    • New audio settings integrated. SFX is split up into sub mixers for GUI and in-game (engines, explosions etc.) allowing more control over audio volumes.
    • The only thing that's left is bugfixing and actually creating a soundtrack and SFX to put into the game and subsequently assigning them to audio events.
  • Settings redesign, cleaner code, slightly faster access to settings and a ton more versatility. Since the system has been changed, settings will reset when this update hits. Old settings.cfg files will not be compatible (server.cfg will be compatible). This is needed to integrate audio settings into the game and also paves the way for GUI scaling.
  • GUI scaling work began, updating the settings system makes it a lot easier to handle. Settings menus now have GUI scaling (see images below).
  • Refactored and modernised the resource loader (for loading audio, images, meshes, textures etc.) Now more modularised and robust.

What's coming up:
  • Overhaul of the individual block system. Putting all block variants into a better structure (wedges etc.), and an LoD system! LoD (level of detail) system basically decreases the complexity of a 3D object, for StarMade this would simplify a cube mesh to make a low poly representation of chunks. This should drastically increase rendering thoroughput, giving a performance boost and potentially allowing us to scale new planets up a bit.
  • Write/read overhaul, massive performance increases! Moving chunk data to unsafe native memory.
  • New universe creation.
Looking for screenshots!

We're looking for StarMade screenshots to use in promotional materials and on the Steam library/store/news. Post your screenshots here: https://starmadedock.net/threads/screenshots-for-official-use.31422/


--- Below is the more detailed discord posts about development done ---

October 21st

The integration of the settings redesign is still in progress. Still gotta adapt a good chunk of settings references. Payoff is a much cleaner code, as well as a slightly faster access to settings, as well as a ton more versatility (settings can be any type now)
This of course will mean that all settings will reset when the update hits, but they would anyways. old settings.cfg files will not be compatible, server.cfg will be compatible however (even though it now runs on the new system)


October 22nd

Not much news. Still adapting the code. SHould be done with that today or tomorrow

Had to switch to a different IDE, as my current one keeps freezing on a class.

Once i adapted it, it was all fine again


October 23rd

Yeah looks like eclipse does NOT like enums using lambdas in the constructor.
However. I'm all done with the settings refactor
spread over 4 commits it was quite sizable
713 additions and 420 deletions.
1,233 additions and 657 deletions.
152 additions and 278 deletions.
2,590 additions and 3,487 deletions.


October 24th

updating the setting system made it a lot easier to handle the GUI scaling. This is the gui scaled for 4k (in 2k resolution, so it looks a bit oversized). There is also a scaling in between.




October 25th

Just spent about 3 hours on a bug involving clip areas checking in drop down menus. The problem was that the newly integrated graphics framework GLFW uses mouse Y positions counting from the top of the screen while the old lwjgl counted from the bottom.

Good results though. Now got nice drop downs and sliders in the options instead of having to click though every single selection.



(which was basically the requirement for the audio settings, so now i can include the audio mixer into the settings)


October 26th



the new audio settings. I split up SFX into sub mixers for GUI and ingame (engines, explosions etc) (to have more control over audio)


October 27th

Refactored and modernized the resource loader (for audio, images, meshes, textures, etc). Much more modularized, and robust.
Implemented the last steps for the audio mixers and successfully assigned the first few sounds and it works as intended ingame.
Only thing left is to test out the more complex sounds ingame as well as remotely triggered sounds.


October 28th

Advanced audio events are now implemented


October 29th

Remote audio events are now implemented (Server can send audio events. Those events are only sent to players in range of the actual source of the audio (with the option to send it globally, although it probably isn't needed since global event usually have a trigger on the clients anyways, so it can just fire directly).
This saves on bandwidth, and removes a possible source of bugs (sounds from distant parts in the universe playing).

This pretty much concludes the implementation of the sound system (minus possible bugs and actually assigning sounds for all the events. Assigning can be done by anyone (which was the goal here))