Our near-term plans for MuseScore Studio

• ธ.ค. 23, 2024 - 09:50

Now that we're pretty deep into releases of MuseScore Studio 4 (version 4.5 is currently in development and is slated for release at the end of February 2025) we thought it was a good time to share some of our plans for the coming 1-2 years.

These are ideas that we (the internal team) plan to focus on while the community continues adding various improvements of their own. The ideas mentioned here aren't exhaustive, and we always leave room in our plans to act quickly on new opportunities when they arise, such as adding relevant features for potential new users (see "Focus on Finale users" below), or when a community developer introduces something valuable that can be readily incorporated into a forthcoming release.

For those who haven't been following the progress of MuseScore Studio, it's worth providing some context behind how we got to where we are now, before we lay out our ideas for the next couple of years.

How we work

For the last four years, our mission has been to establish MuseScore Studio as a modern, professional application. This has largely meant matching the essential features of Finale (RIP), Dorico and Sibelius. The teams working on these apps have their own development challenges, including the need for codebase improvements and feature expansions. Our particular development challenge has been the need to divide our time and resources across three distinct priorities:

1. Building new features and improvements

This is the easiest part of the job: creating new capabilities that MuseScore Studio is missing, which don't require major under the hood changes or refactoring of our codebase. At the moment, around a third our focus is on this aspect. We aim to bring it up to around 75% within the next 18 months.

2. Improving older features

When our team began working on MuseScore in 2018/2019, there were very few aspects of the app that didn't require a major rethink. Therefore, with each release, we've been gradually replacing or updating core aspects of the app's functionality.

We've been doing this work to provide a solid foundation that can be reliably built upon in the future, when we want to introduce far more ambitious, modern improvements.

To give one example: it was clear that our system for positioning and playing back dynamics and line objects (like hairpins) had to be completely replaced. So we made it possible to let these objects anchor to non-arbitrary positions on the stave. This has dramatically improved consistency when the score layout changes, ensuring hairpins no longer fly all over the place without knowing where to go! This has also greatly improved usability and playback too.

Although we are not yet done fixing up many of these older issues with MuseScore, we feel we're about 75% there.

3. Refactoring the codebase to unblock new capabilities

This is the real demon.

There remains a large area of the codebase that requires refactoring in order to enable future capabilities that are currently blocked.

When we released MuseScore 4.0, we took the opportunity to address our overall architecture, UI framework and audio engine. Since then, we've been completely reimagining our notation system itself.

The problem we knew we needed to address was MuseScore's measure-based approach, a problem those who have followed the development blogs of Sibelius or Dorico will be familiar with. Put simply, when the underlying architecture of your notation requires all notated elements to be contained within a measure, it has far-reaching implications that go beyond simple problems like, for example, tuplets not being able to cross bar lines (a problem that can be hack-fixed to a reasonably satisfactory degree anyway).

By replacing the old measure-based architecture with a more flexible system, we unlock many of the new features described below. This also allows us to create a truly fluid playback system, where durations can exist at any point in time. It will open the doors to a properly capable piano roll. In addition, it will also allow people to make major alterations to time signatures without the score saying "no" because it causes durations to go beyond the boundaries of a measure.

Our next big update: 4.5

Some of you will have already started using the master/nightly builds, in which case you may have noticed a number of exciting new features we're bringing to this release.

Version 4.5 has three main areas of focus:

  • Upgrading MuseScore's percussion notation capabilities
  • Expanding the engraving module's capacity to meet professional publishing standards
  • Introducing workflows that are essential for Finale users, which we also think will benefit all users of the app.

New percussion system

As promised, we'll be delivering a new percussion system in version 4.5.

This is the second update in a multi-stage plan for percussion, which is so ambitious in its scope that we are forced to realise our vision for an industry-leading percussion system in incremental stages.

The first stages took place earlier this year, when in MuseScore 4.3 and 4.4 we introduced sound flags to stave text, and added support for Muse Drumline. Part of this work involved making the existing percussion panel responsive to the sound library chosen in the mixer, allowing it will display available notes at pre-mapped staff positions as determined by the chosen sound library.

We did this because we believe that an optimal percussion experience in MuseScore is one where the relationship between notation and playback is as seamless as possible.

But as many of you know, percussion music presents additional challenges to a computer-based notation system, including the lack of a common notation standard, the challenge of mapping diverse instrument sets onto a single stave, a sprawling myriad of playback libraries with unique mapping conventions, and so on. Percussion is, in short, incredibly complex.

In version 4.5, we'll be introducing a new percussion panel to enable faster note input, greater flexibility and customisability, and enhanced readability and accessibility.

New percussion panel (animated image)

To achieve some of these benefits, we've had to increase the size of the panel. While this won't adversely affect orchestral percussion instruments, it may make very large libraries – including drumlines and expanded drum kits – initially less convenient when used on small screens.

For this reason, we'll continue to support the legacy panel together with new panel, until we can realise the next stage in our percussion story: a universal mapping system.

Universal mapping for percussion in MuseScore has already been designed, but will require extensive refactoring of our percussion standard to bring to fruition. The benefits, however, will be immense. We'll be moving to a hierarchical structure of instruments and sub-instruments which will not only save on UI space, but which will also enable seamless switching and combining of percussion sound libraries while not adversely affecting the notation. Of course, this will also enable virtually limitless customisation of mapping across sound libraries.

The evolution of percussion is going to be a long journey for MuseScore Studio, so we're grateful for your patience and feedback as this system continues to evolve.

Engraving updates

We'll be introducing two highly requested engraving features in version 4.5: laissez vibrer ties, and large time signatures.

In addition, we'll be giving you more control over where system markings like bar numbers, tempo markings, rehearsal marks, and more appear.

And thanks in part to the efforts of one of our community contributors, we'll be bringing the use of custom SMuFL fonts to 4.5.

We've also been working closely with the engraving department of Hal Leonard to better understand the pain points they experience in other notation apps, and to design new solutions for these problems that don't already exist in the market.

One example is how objects like ties, slurs, clefs, and key and time signatures behave at repeats and jumps (including "da capo", "dal segno" and "to coda" marks). In MuseScore 4.5, these elements will get created automatically, based on the presence of musically sensible conditions (E.g. a note of equivalent pitch existing at the start of a repeated section). Where a note can be tied to more than one other note, we'll also provide a nifty way of allowing people to chose which notes it gets tied to.

New feature for partial ties and more (animated image)

As always, our engraving specialist Simon Smith will publish a detailed article describing all engraving updates when the next version is ready.

Focus on Finale users

With MakeMusic's announcement in August that it will be discontinuing Finale's development, we understood the need to provide a free and attractive alternative to people wanting to migrate to a different application. We took the opportunity to reach out to Finale users to learn what features they couldn't live without, and have set about making our own equivalents – tweaking them here and there to ensure they integrate comfortably with our own app.

In MuseScore 4.5, we'll be introducing:

  • The ability to move measures to the previous/next system (using shortcuts or the Properties panel), allowing you to fit as many measures as you want within the same system
  • The ability to lock systems so they remain as a single unit without reflowing when you make changes elsewhere on the score
  • The ability to drag measures (or range selections) to quickly copy and paste them to other measures
  • A new note input mode comparable to Finale's popular "Speedy Entry" system, which provides people with another way to quickly enter pitches and durations using their keyboard and (optionally) their MIDI keyboard too.

New moving measures feature (animated image)

Not only are these features beloved by Finale users, we also think they'll greatly enhance the workflow of all MuseScore Studio users too.

And more!

Complementing the new drag-to-copy-and-paste functionality will be a suite of improvements to copy and paste behaviours more generally. For example, when copying a list selection of dynamics and pasting them somewhere else, the relative metrical positions of the dynamics will be retained. It'll also be possible to make proper range selections when starting from something that's not a note or rest.

Before (current in released versions)

Copy and paste dynamics: behaviour before (animated image)

After (coming soon in 4.5!)

Copy and paste dynamics: behaviour after (animated image)

Version 4.6

While most of the team starts preparing major new features for version 5.0 (see below), we intend to release one more update in the version 4 series that will include a couple of small features and improvements. You can look forward to enhanced features for chord symbols and fretboard diagrams, as well as updates to our selection filter that will speed up your workflow.

Version 5.0 and beyond

From version 5.0 onwards, we'll be setting our sights on a mixture of more ambitious and innovative features that will significantly enhance the way you use MuseScore Studio to create music. Here's a high-level summary of some of our development aims.

Playback

Sitting at the top of our priority list is the eagerly anticipated automation feature, which will finally unlock DAW-like control over dynamics and other playback parameters via intuitive and customizable over-the-stave curve lines.

Having recently introduced the possibility for segment-based notation layout (see above), we're finally in a position to unlock highly valuable note input requirements. This includes placing tuplets across barlines, and moving a range of notes forwards or backwards in time while maintaining their rhythmic integrity. And of course, you'll get more granular control over the timing of each note, enabling more expressive and customizable playback. Once these changes are complete, this will also unlock a new feature we aim to introduce in 2025: a new, multi-capable piano roll.

Another one of our ambitions is to introduce audio staves, which can seamlessly interweave real audio tracks with the playback generated from your notation. Using a time-stretching technology we recently introduced to Audacity, audio staves will retain their relative length even when you change the tempo of your score.

We know how important a flexible MIDI mapping system is to our users, and so designs for this are already in a well-advanced state. This is quite an extensive feature that may end up being rolled out in stages, but we are aware that this is particularly crucial for VST users who need more control over how their plugins perform in MuseScore.

With VST in mind, and with so many new sounds libraries becoming available from MuseSounds, we've also planned a playback profiles system that will allow people to create defaults that map their preferred sound libraries to specific instruments.

Shared framework

An under the hood piece we've started working on is an integrated framework with Audacity, which allows us to share parts of our codebase – a system we are planning to expand until both applications share the same audio engine. When this is in place, we can all look forward to more rapid feature integration as improvements to playback in Audacity get assimilated into MuseScore Studio, and vice versa. This will also make many of Audacity's native effects available for MuseScore Studio users too.

Workflow and UI

We know that people using MuseScore Studio on laptops have to negotiate some fairly tight space constraints. With this in mind, we've now started designing a minimal UI mode that will reduce the amount of screen space taken up by controls, allowing more room for the score.

We also have plans to modernise the increasingly ageing styles dialog, which suffers from accessibility issues, outdated components, and usability problems.

And finally, we know that an in-app video player is a crucial part of our scoring crowd's workflow, and have started investigating solutions for this too.

Engraving

One of the biggest pieces of work for our engraving team will to enable proper instrument stave sharing. For example, imagine two flutes sharing a single stave in the score, but with the possibility of creating an independent part for each of them. Achieving this is currently possible only by writing music in different voices and hiding those that shouldn't appear in each part. Such a workaround is no replacement for a more capable system, but achieving this will require a major overhaul of how instruments, staves, and voices currently work. As part of this, we will implement a much more sophisticated system for instrument labelling and numbering.

We’re also planning a major overhaul of grace notes. Currently, they’re treated as add-ons to real notes, which causes significant engraving issues. To address this, we’ll rework grace notes so they function just like other notes on the stave.

At a macro level, we'll be building new capabilities into the Instruments panel (being renamed to Layout panel in version 4.5) that will enable the creation of larger sections of music – think movements of a sonata or symphony, acts of an opera, and even songs in a songbook. This is currently only partially achievable with page breaks, but requires awkward hackery of objects like clefs, and time and key signatures. Defining the score into proper sections will overcome these problems and more.

A more flexible and intuitive way to control the visibility of staves and measures is also in the pipeline, enabling an improved way of displaying cutouts, among other things. We're also planning a dynamic system for adding cues which will do away with the currently clunky process of needing to create secondary instruments that span the whole score and hiding them.

Extensions framework

Earlier in 2024, we started developing a new extensions framework to replace the existing plugins system. This ended up being a complex piece of work, so we put it aside to focus on more urgent priorities with the intention of coming back to it in 2025.

Aleatoric mode

Another possibility of laying out notation on a per-segment, rather than per-measure basis, is the ability to open up our playback engine to enable multiple simultaneous playback points and a properly fragmented layout. This is a long-term goal, but one which we're ultimately aiming towards as our engraving and playback modules continue to mature.

There's a lot more to come

As mentioned, this is not an exhaustive list, but it hopefully gives you a sense of the big-ticket items that are in our sights.

While pretty much all of the above will be developed by the internal team, it's worth mentioning that a multitude of smaller and medium-sized tasks always needs attention. We've curated a selection of these in our community projects board on GitHub, and invite any interested developers from the community to tackle these.

As always, we're extremely grateful for the support of our developer community, particularly when it comes to testing our nightly and beta builds, and for helping us improve the overall quality of the app by contributing bug fixes and feature improvements.

We hope you continue to enjoy creating music in MuseScore Studio.


Comments

This is truly amazing work! Thank you development and teams for continuing a great software that is improving! Looking forward to the automation feature and playback features. Re-imagining and upgrading an entire software from scratch sounds to be a wild process.

Very glad to read that the measure based data structure will finally be redesigned.
This is indeed a major blocker for evolution.
But of course a huge piece of work as that's the fundation of the musescore data system.

In reply to by bradleykunda

HI Bradley and thanks. No, i'm well aware of the free MuseSounds in Staffpad (although some of them don't work very well). My question was about the paid libraries on both Staffpad & MuseScore. I was under the impression that at some point all the libraries would be shared between MS & SP. Even in the intro to the new pipe organ, the narrator says 'for staffpad & Musescore'. is this no longer happening?

I'm proud to say I've been on the Musescore Studio train since 2014. Never have I been more excited to see the unparalleled evolution of notation software (AND FOR FREE)!

Thank you for sharing with us all these fine plans, in details! I'm very glad that you are aware how many features are still needed to make MuseScore 4 what it should be. I'm very excited about automation/piano roll, and also many others. Audio staves where entirely unexpected, but great news for me. If I may suggest, it would be great to support both "time-stretchable" and "non time-stretchable" audio staves. Non-stretchable audio staff would be great for synchronizing/mixing the MuseScore's performance with the real recorded performance.

In reply to by Asher S.

I can understand that it might work really rather well for that particular application. - so will be useful for you, and maybe others.
I have used time stretching - of various sorts - and also pitch shifting, but fot the highest qualilty I prefer not to use any of those methods.
As better algorithms come along my concerns might become less significant to me.

In reply to by dave2020X

All depends on your usage. But minor time stretching of samples to match tempo changes (when one decides to try out a faster pulse, for example) is highly valuable. I wouldn't personally worry about deformation. Then again, I'd never use a notation app to produce final music. Great for demos.

That said, Audacity's time-stretching is really excellent. It's an in house technology that took a long time to build. We open-sourced it in 2023.

Regarding the example using wood blocks, will there be an option to use separate one-line staves to represent the individual wood blocks (high, mid, low) and to group those staves using a named bracket like this here:
example.png

Thanks you for your work, please consider to reimplement some lost features:
- metronome count-in
- general pitch settings
- image capture
- jackd support for Linux
The lack of these features prevent a lot of people to upgrade to MS 4.X

All the future improvements sounds very good!, but:
Taking advantage of the new stave design, it would be desirable to have the lines that make up a staff be able to be coloured as desired, or at least that in a three-line staff, the middle line could be made invisible, but the musical notes, pauses and other musical elements would remain visible. Although this request may seem stupid, it is essential for castanets composers to be able to use MuseScore and to be able to compose their pieces for "solo concert castanets" and also to be able to print the score according to current standards. "Solo concert castanets" produce at least 7 different strikes that can be represented on a three-line staff, but the middle one must be invisible. Although there are probably not many MuseScore users who work with castanets, this improvement could change the situation. Actually the implemented castanets in Musescore only produce 2 sounds (strikes), but my created "solo concert castanets" instrument produces the 7 strikes. At least MuseScore 3.6.2 and all the MuseScore 4.X.X are able to produce already a 3 Lines staff and one can draw an auxiliary white line over the 2nd. staff-line, but this procedure is very painful if the score is more than 1 page long.

In reply to by puggbma

Future developments look good, and maybe the changes to using measure based underlying structures will lead to significant benefits.

For me the biggest improvements - perhaps not included in the plans - would be:
1. A usable Album or Movements feature - I know this was dropped between MU2 and MU3 as it was unreliable. I'm still hoping that something workable will eventually reappear.
2. A more streamlined Mixer - to allow grouping of sections.
3. Grouping of sections in large scores - also linked to the Mixer - not just a simple extension of Parts - though I'm very grateful that Parts now seem more reliable.

I don't use Piano Roll Editors too much, though I note that there are many who now seem to work almost exclusively in PREs and DAWs. Some DAWs offer a compromise, but the notation features are generally nothing like as good as MuseScore. Maybe this is an area where more can be done - though it's not a very high priority for me.

I note the intention to enhance video integration - though that might require the use of a new structures - such as Timelines with time codes - similar to video editors. Possibly that might make things too complicated - at least in the short term.

Time stretching of audio - mentioned as something new to be introduced - is interesting, though most time stretching methods compromise audio quallity - sometimes very significantly - if pitches are to be maintained. I would hope that new features such as time stretching would not distort the possible very high quality audio which can be generated by. MuseScore for users who don't need or want to use features which might impact on the sound quality.

It'll be really interesting to see how the Finale inspired note editing features work - and if they help. One thing which is a real pain in MU4 at the moment is that if a change is made in one measure, then sometimes the whole page is reformatted, and it can be very hard to spot the point of focus which gets changed by the new layout. I think the proposed Lock feature for formatting might help, though it would also be very useful to have a lock on notes, to make sure that notes don't get changed by accident.

Maybe also for the future, support for surround sound could be built into the Mixer - but it's something which could come later.

Musescore is clearly a very complicated and intricate system to develop, so features which may seem simple to do from a high level may in fact not be when one gets down to the nitty gritty data structures and code fragments. It is amazing that it works at all! Thank you.

In reply to by puggbma

@puggbma • Dec 27, 2024 - 19:50
"It would be desirable to have the lines that make up a staff be able to be coloured as desired."

This would indeed be a useful feature. I typically colour the 4th line (=string) of guitar tab in brown as it helps me to differentiate quickly between strings 3 and 4, (since there is no center line on a six line stave).

I have a workaround to achieve this in MS3 which may also work in MS4. I won't link a score here because it will embed a huge visual and I don't want to clutter this thread, so, (in case you do not have a workaround of your own), if you start a new post I can explain how it works.

In reply to by yonah_ag

Thank You very much for your ofer. I have a workaround also in MS3, but it does not work very well in MS4. Any way, your workaround in MS3 may be better as mine. So, if you like, you can explain me what you do. The real solution would to be able to coloured the satff lines according to the needs.

In reply to by Tau_03

That would have to be equally a question for Wallander.
Personally, I don’t think they will. But seeing how they are making monetized Muse Sounds packs, maybe they’ll be up for collaborating with the makers of paid software.

Edit: However, the same fact could suggest that they won’t. I honestly don’t care.

Something I have an increasing need for is the ability to have branching stems to notate alternate unisons (F and F#). The existing solutions for this--notating them with enharmonic equivalents, having two note heads side by side with both accidentals to the left of the chord, or manually pasting in lines--are less clear, do not work in all circumstances, or are extremely time consuming. This would be a nice feature to have (which as far as I know is only fully extant in Dorico).

Thank you for all the effort. But please implement a tuning system and improve the microtonal integration. I think some of us have to emigrate to another app if this continues without these functions :(

Very good planning, however, I would like to offer you some suggestions:
1. In non-standard aspect ratios (16:9), sometimes the UI appears cramped (see details at https://github.com/musescore/MuseScore/issues/25823), I hope you can consider us users.
2. I hope to see the addition of more microtonal music systems, such as 19-tone equal temperament, 22-tone equal temperament, etc.
3. The current mixer seems to have tools for adjusting the stereo image, but it can only adjust stereo (i.e., two channels) and cannot create mixes for special channels like 5.1, 7.1, 2.1, 7.1.2, 7.1.4, etc. As a user who enjoys creating Dolby Atmos music, I would prefer to integrate the Dolby Renderer API into MuseScore, which would allow mixing Dolby Atmos projects within MuseScore without having to switch to other host software (DAW). If you believe this would affect the size of the application, it could be made as a free plugin for users to download.
Finally, I hope MuseScore continues to improve and becomes the preferred choice for musicians to create sheet music by 2025! I hope the Musescore team will consider my suggestions!

It's really exciting to read all of what's planned! Kudos to the team. I have been a user since version 3 and although updating to 4 was kind of a bumpy ride, I have seen lots of improvements in the latest releases.
Hope 2025 is a great year for MuseScore!

Wow! This is seriously an amazing roadmap—Thank you and this is very exciting!

Meanwhile, I’d like to propose a feature request. Currently, Sibelius and Dorico can be effectively connected to StreamDeck, enabling users to seamlessly utilize tools like Notation Express from NYC Music Services. Would it be possible for the MuseScore team to implement WebSocket support? This would allow for better integration between MuseScore and StreamDeck, significantly enhancing workflow efficiency and accessibility for users.

Do you still have an unanswered question? Please log in first to post your question.