A fairly simple mod that allows you to heavily customize the appearance of hit scores.
This mod requires a few other mods in order to work.
- BeatSaberMarkupLanguage v1.3.4 or higher
- BSIPA v4.0.5 or higher
- SiraUtil v1.0.2 or higher
The installation is fairly simple.
- Grab the latest plugin release from BeatMods/ModAssistant (once it's available) or from the releases page (once there is actually a release)
- Drop the .dll file in the "Plugins" folder of your Beat Saber installation.
- Boot it up (or reboot)
Having it all installed, you might wonder how you actually use this version compared to the original one. The first important thing that you'll need to know, is that it now has support for multiple configs which means that you won't have to restart your game anymore in order to change a config.
On the first run, it will create a new folder UserData\HitScoreVisualizer
(and a default config for those who didn't have one yet).
In that folder, you can drop all your HSV config files. It doesn't even matter if you create new folders in that folder, HSV will still be able to find them all. One remark about this though... while
you can have config files with the same name when using folder structures, I still strongly advise you to use unique config filenames because, despite HSV being able to handle them just fine, config
files will appear in-game with only their filename, and you might end up with several files in the list that have the same one.
Having dropped your config files in the folder doesn't mean you're ready to go yet as you still need to select it in-game. It's pretty straight-forward to do so, but follow the steps below if you really want to be sure.
- You'll need to start up Beat Saber (you don't have to restart it if it was still running though)
- Select HitScoreVisualizer in the mod list on the left side.
- Push the 'SELECT' button
- Profit I guess?
As you might have noticed, each config has a text below its name that describes it current state. You can find all the possible config states in the table below.
State (internal) | Text shown in-game | Description |
---|---|---|
Broken | Invalid config. Not selectable... | Means that the file cannot be loaded, it's either not a valid HSV config file or not a config file at all. |
Incompatible | Config is too old. Targets version {Version} | The config is too old and therefore can't be migrated to the newer format automagically. |
ValidationFailed | Validation failed, please check the file again. | You made an error in the config itself, you can check the logs to see what might be wrong (will be logged as a warning). |
NeedsMigration | Config made for HSV {Version}. Migration possible. | The config is valid, but still needs a migration to the newer format, this can be done automagically though. |
Compatible | OK - {Version} | The config file is just fine, nothing special needs to happen. Shows the version for which it was originally made. |
NewerVersion | Config is too new. Targets version {Version} | The config file is made for a newer version of HSV and therefore won't be allowed to be loaded in as it's correct workings cannot be guaranteed. |
When first running the game, it will create a default config which can be found at UserData\HitScoreVisualizer\HitScoreVisualizerConfig-default.json
.
You can use that file as a starting point in case you want to customize it. Just make sure to set isDefaultConfig
to false
.
Property name(s) | Explanation / Info | Example or possible values |
---|---|---|
majorVersion minorVersion patchVersion |
Indicates the version of HSV that the config is made for specifically. | N/A |
isDefaultConfig | Indicates whether this file is a default config file. This also means that it will be overwritten by the built-in default config if migration is required. | true or false |
displayMode | - "format": Allows you to use format tokens in the Judgment texts. (More info later on) - "numeric": Displays only the note score. (Eg: 115) - "textOnly": Displays only the Judgment text. (Eg: Purrfect) - "scoreOnTop": Displays both (numeric score above Judgment text). - Anything else or empty: Displays both (Judgment text above numeric score). |
"format" "numeric" "textOnly" "scoreOnTop" "" |
useFixedPos | Whether or not to display the hit scores on a fixed position. When enabled, this will also hide the previous score if a new one appears. | true or false |
fixedPosX fixedPosY fixedPosZ |
The coordinate where the hit scores should be shown when useFixedPos is set to true |
floats |
doIntermediateUpdates | When enabled, Judgments will be updated multiple times. This will make score popups more accurate during a brief period before the note's score is finalized, at some cost of performance. | true or false |
Judgments | The list of Judgments that can be used to customize the Judgments in general. | Uses Judgment objects. More info below. |
beforeCutAngleJudgments | The list that can be used to customize the Judgments for the part of the swing before cutting the block (score is from 0 - 70). Format token: %B * Can only be used when displayMode is set to "format" |
Uses JudgmentSegments objects. More info below. |
accuracyJudgments | The list that can be used to customize the Judgments for the accuracy of the cut. How close was the cut to the center of the block? (score is from 0 - 15). Format token: %C * Can only be used when displayMode is set to "format" |
Uses JudgmentSegments objects. More info below. |
afterCutAngleJudgments | The list that can be used to customize the Judgments for the part of the swing after cutting the block (score is from 0 - 30). Format token: %A * Can only be used when displayMode is set to "format" |
Uses JudgmentSegments. More info below. |
- The
text
property of both Judgment and JudgmentSegment also has support for TextMeshPro formatting!. - The order of Judgments and JudgmentSegments in the list doesn't matter anymore from version 3.0.0 and onwards. However, it's still advised to keep a descending order if you plan on targetting older versions of HSV as well.
- To prevent unexpected issues down the road, the validation will also check within each list whether there are Judgments or JudgmentSegments that share a threshold. Validation will mark the config is failed if when this is detected.
Property name(s) | Explanation / Info | Example or possible values |
---|---|---|
threshold | The threshold that defines whether this Judgment will be used for a given score. The Judgment will be used if it is the one with the highest threshold that's either equal or smaller than the score the given hit score. It can also be omitted when it's the Judgment for the lowest scores. | 110 |
text | The text to display (if Judgment text is enabled). This can contain the formatting tokens (explained later on) if displayMode is set to "format" |
"%BFantastic%A%n%s" |
color | An array that specifies the color. Consists of 4 floating numbers ranging between (inclusive) 0 and 1. Red, Green, Blue and Glow. | [0, 0.5, 1, 0.75] |
fade | If true, the text color will be interpolated between this Judgment's color and the Judgment with the next highest threshold based on how close to the next threshold it is. Remark: If your config still targets older, but compatible versions, then don't specify it on the Judgment with the highest threshold or the game and plugin will be burned to a crisp. This is mitigated from 3.0.0 and onwards. |
true or false |
Property name(s) | Explanation / Info | Example or possible values |
---|---|---|
threshold | The threshold that defines whether this JudgmentSegment will be used for a given score. The JudgmentSegment will be used if it is the one with the highest threshold that's either equal or smaller than the score the given part score. It can also be omitted when it's the JudgmentSegment for the lowest scores. | 30 |
text | The text to display. Remark: Format tokens can't be used in this text... or better, they can be used, but won't be replaced with the actual value. |
"+++" |
Token | Explanation / Info |
---|---|
%b | The score contributed by the swing before cutting the block. |
%c | The score contributed by the accuracy of the cut. |
%a | The score contributed by the part of the swing after cutting the block. |
%B, %C, %A | Uses the Judgment text that matches the threshold as specified in either beforeCutAngleJudgments , accuracyJudgments or afterCutAngleJudgments (depending on the used token). |
%s | The total score of the cut. |
%% | A literal percent symbol. |
%n | A newline. |
To build this project you will need to create a HitScoreVisualizer/HitScoreVisualizer.csproj.user
file specifying where the game is located:
<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<!-- Change this path if necessary. Make sure it ends with a backslash. -->
<GameDirPath>D:\Program Files (x86)\Steam\steamapps\common\Beat Saber\</GameDirPath>
</PropertyGroup>
</Project>
x.x.x: Probably created and such, no clue here...
2.0.2: Bug fixes and performance improvements. If you've been noticing lag, try disabling the fade option on all Judgments in the config.
2.1.0: Added display mode "format" (see below).
2.1.2: Actually bump version number this time; minor fixes to default config
2.1.3: Minor bug fix
x.x.x: Probably a few more changes and such, no clue here either...
3.0.0: Big rewrite! Support for changing configs at runtime, better validation, ...
Credit where credit is due:
- @artemiswkearney for writing the original mod
- @AntRazor for the mod idea/request and default config input in the original mod
- @wulkanat for the default config input in the original mod
- Everyone in #pc-mod-dev (and the rest of the server) for the love and support. ❤