You are viewing a potentially older version of this package. View all versions.
PXC-ShipLootPlus-1.0.7 icon

ShipLootPlus

Rewrite of the OG ShipLoot and enhanced with more customization

Date uploaded 4 months ago
Version 1.0.7
Download link PXC-ShipLootPlus-1.0.7.zip
Downloads 55471
Dependency string PXC-ShipLootPlus-1.0.7

This mod requires the following mods to function

BepInEx-BepInExPack-5.4.2100 icon
BepInEx-BepInExPack

BepInEx pack for Mono Unity games. Preconfigured and ready to use.

Preferred version: 5.4.2100
AinaVT-LethalConfig-1.4.0 icon
AinaVT-LethalConfig

Provides an in-game config menu for players to edit their configs, and an API for other mods to use and customize their entries.

Preferred version: 1.4.0

README

ShipLoot Plus (+)

Rewrite and enhancement to the original ShipLoot with a ton customization.

This started as a fork but I ended up rewriting 99% of it to allow for more dynamic customization.

IMPORTANT: With v1.0.1 there has been some changes which will reset any custom line formats and colors. You do not need to regenerate your configs and these settings will still be in your config file, its just that the line names and categories have changed (though now you would have extra data in the files). Please review the Change Log for more information on what has changed as you may want to have new customizations anyway.

Key Features

This mod adds three customizable HUD elements which allow you to display many different data points. This is expanded from the original ShipLoot which only showed the value of scrap in the ship.

  • Show more game information easily
  • Highly customizable
    • Colors (including Rich Text support)
    • Information format
  • Conditional display
    • Default (on scan only)
    • Always Shown
    • Allow it to be shown when outside the ship and/or inside the dungeon

This is what the HUD looks like with its default data points.

NOTE: You can see what the different parts mean in the breakdown below

Feature Breakdown

DataPoint patterns and information

Below are the full list of what I call "DataPoints", essentially these DataPoints are basically replaced in the format string with the corresponding information from the game

  %ShipLootValue%      = Value of all scrap on the ship
  %MoonLootValue%      = Value of all scrap on the moon (excluding the ship)
  %AllLootValue%       = Value of all scrap (ship and moon)
  %ShipLootCount%      = Count of scrap items in the ship (excluding the moon)
  %MoonLootCount%      = Count of scrap items on the moon (excluding the ship)
  %AllLootCount%       = Count of scrap items (ship and moon)
  %FulfilledValue%     = Value of turned in scrap for quota
  %QuotaValue%         = Value of current quota
  %CompanyRate%        = Current company buy rate
  %ExpectedProfit%     = Expected profit from scap on ship at current company buy rate
  %Deadline%           = Days until quota is due
  %DeadlineWithColors% = Quota deadline in days but changes colors based on value (color thresholds will be customizable in the future)
  %DayNumber%          = Integer of days in the ship/save (E.g. 1, 3 ,10)
  %DayNumberHuman%     = Human friendly days in the ship/save (E.g. 1st, 3rd, 10th)
  %Weather%            = Current moons weather full name
  %WeatherShort%       = Current moons weather short name (Default is first 3 characters)
  %MoonLongName%       = Current moons full name
  %MoonShortName%      = Current moons short name (Default is first 3 characters)

Example Breakdown

Default Lines:

Ship: $%ShipLootValue%(%ShipLootCount%)/$%MoonLootValue%(%MoonLootCount%) [%MoonShortName%:%Weather%]
Quota: $%FulfilledValue%/$%QuotaValue% - Prof: $%ExpectedProfit%(%CompanyRate%%)
Deadline: %Deadline% - %DayNumberHuman% day

Translated Lines:

Ship: $209(2)/$0(0) [Com:Clear]
Quota: $0/$229 - Prof: $63(30%)
Deadline: 3 - 5th day

Rich Text Support

You can introduce further customizations inline with your formats.

Here are some resources to understand Rich Text and what tags are available (not every tag will work as the font that the game uses lacks some support)

Inline Rich Text formatting will override the text color for the specific word or DataPoint in the line, they are applied after the text line color configuration.

The %DeadlineWithColors% DataPoint uses this internally to change the color of the deadline day number from Green (2+ days) => Orange (1 day) => Red (0 days)

Configuration

Text Line Format Configuration
  [Line #1]
  ## Line #1 text format.
  ## [Lists each DataPoint but omitted here for space reasons]
  # Setting type: String
  # Default value: Ship: $%ShipLootValue%(%ShipLootCount%)/$%MoonLootValue%(%MoonLootCount%)
  Format = Ship: $%ShipLootValue%(%ShipLootCount%)/$%MoonLootValue%(%MoonLootCount%) - $%InventoryLootValue%(%InventoryLootCount%)

  [Line #2]
  ## Line #2 text format.
  ## [Lists each DataPoint but omitted here for space reasons]
  # Setting type: String
  # Default value: Ship: Quota: $%FulfilledValue%/$%QuotaValue% - $%ExpectedProfit%(%CompanyRate%%)
  Format = Quota: $%FulfilledValue%/$%QuotaValue% - $%ExpectedProfit%(%CompanyRate%%)

  [Line #3]
  ## Line #3 text format.
  ## [Lists each DataPoint but omitted here for space reasons]
  # Setting type: String
  # Default value: Deadline: %Deadline% - %DayNumberHuman% day
  Format = Deadline: %DeadlineWithColors% - %DayNumberHuman% day (%Weather%)

NOTE: The available data points show in the right panel in LethalConfig


Display Conditions and Settings

There are several conditions which change when or how the GUI is shown.

[Always Show]

This setting basically makes it so that the GUI will always be shown to the user and will updated data in real time

Configuration
  ## Should the hud elements be decoupled from the scanner? (Meaning it will always be shown on screen)
  # Setting type: Boolean
  # Default value: false
  Always Show = false

[Allow Outside]

Enables or Disables the GUI from being seen when Outside (not in the ship and not in the dungeon)

Configuration
  ## Should the scanner hud be shown when scanning outside the ship?
  # Setting type: Boolean
  # Default value: false
  Allow Outside = false

[Allow Inside]

Enables or Disables the GUI from being seen when inside the dungeon

Configuration
  ## Should the scanner hud be shown when scanning inside the dungeon?
  # Setting type: Boolean
  # Default value: false
  Allow Inside Dungeon = false

On Scan Settings

[Display Duration]

Sets the timeout for the GUI when a scan is initiated

Configuration
  ## How long in seconds should the items stay on screen. (This is ignored if Always Show is true)
  # Setting type: Single
  # Default value: 5
  Display Duration = 5

[Reset Duration Timer On Scan]

This will keep the UI timeout on scan active if the scanner is activated again.

Configuration
  ## Should the duration timer get reset if you scan?
  # Setting type: Boolean
  # Default value: false
  Reset Duration Timer On Scan = true

[Refresh Data On Scan]

Forces the scanner to do a data refresh when its active. This is not really needed as every data point is updated by event triggers but can allow you to on demand updated data.

WARNING: This can cause lag and potentially crashes if you are using macros to spam the scanner and/or are using mods which do it (like Hold Scan Button)

Configuration
  ## Should a data refresh be forced when scanning?
  ## 
  ## All data is kept updated when events are triggered (player grabs an item, items get moved into the ship, etc.) so this isn't required.
  ## 
  ## <b>IMPORTANT</B>: This could cause issues with any mod that makes the scanner always on
  # Setting type: Boolean
  # Default value: false
  Refresh Data On Scan = false

GUI Breakdown and Configuration

The GUI consists of 4 elements, a Line Graphic and three Text fields. Each one has some common configurations

[Line Graphic]

This element is used to frame the data on the screen.

Enable/Disable: Line Graphic
  ## Shows the line element
  # Setting type: Boolean
  # Default value: true
  Show Line = true
Color: Line Graphic

NOTE: Uses standard HTML Hexadecimal color codes (Can be with or with out the # sign)

  ## Line color (hex code)
  # Setting type: String
  # Default value: 2D5122
  Line Color = 2D5122

[All Caps]

Force all text to be capitalized.

Enable/Disable: All Caps
  ## Should text be in all caps?
  # Setting type: Boolean
  # Default value: false
  All Caps = false

[Short Character Count]

This is the amount of characters to return for the various "Short" data point variants

Short Character Count
  ## How many characters to show for the following data points:
  ## 
  ## %WeatherShort%
  ## Current moons weather (short name)
  ## 
  ## %MoonShortName%
  ## Current moons short name
  ## 
  ## 
  # Setting type: Int32
  # Default value: 3
  Short Character Count = 3

NOTE: "Experimentation" becomes "Exp"

[Text Line #1]

This is the first (top) text line element

Enable/Disable: Text Line
  ## Shows Line #1 on the hud.
  # Setting type: Boolean
  # Default value: true
  Show = true
Color: Text Line

NOTE: Uses standard HTML Hexadecimal color codes (Can be with or with out the # sign)

  ## Line #1 text color. (hex code)
  # Setting type: String
  # Default value: 19D56C
  Color = 19D56C

[Text Line #2]

This is the second (middle) text line element

Enable/Disable: Text Line
  ## Shows Line #2 on the hud.
  # Setting type: Boolean
  # Default value: true
  Show = true
Color: Text Line

NOTE: Uses standard HTML Hexadecimal color codes (Can be with or with out the # sign)

  ## Line #2 text color. (hex code)
  # Setting type: String
  # Default value: 19D56C
  Color = 19D56C

[Text Line #3]

This is the last (bottom) text line element

Enable/Disable: Text Line
  ## Shows Line #3 on the hud.
  # Setting type: Boolean
  # Default value: true
  Show = true
Color: Text Line

NOTE: Uses standard HTML Hexadecimal color codes (Can be with or with out the # sign)

  ## Line #3 text color. (hex code)
  # Setting type: String
  # Default value: 19D56C
  Color = 19D56C

Custom Colors Example

All Caps Example


Dynamic text line scaling

The default layout is three lines of custom data, but sometimes that may be too much information, so you can disable any or all text lines if you want.

Since disabling them would normally mean a gap with whitespace, I built in dynamic scaling so that it will scale up the text lines based on how many are enabled. The only down side to this is it gives you less characters per line.

NOTE: If the line is too long it will be truncated with ellipses

NOTE: This is the closest to the original ShipLoot

Alternatively you could just disable the Line Graphic and set the Format for the line you don't want to see to an empty string (blank) to keep the original scale.


Planned and Potential Future Features

Planned Features
  • Expand what data is able to be set in each line
    • [x] Ship scrap count
    • [x] Moon scrap value and count
    • [x] All scrap (ship + moon) value and count
    • [x] Color coded deadline (change text color based on value, 0 = red, 1 = orange, 2+ = green)
    • [x] Number of days in the ship(save)
    • [x] Same as above but human friendly format (1st, 3rd, 10th, etc.)
    • [x] Expected profit (scrap value - quota * buy rate)
    • [ ] Total Value of scrap in player inventory
    • [ ] Total Value of scrap in crew inventories
    • [ ] scrap value to meet quota
    • [x] Company buying percentage
    • [x] Weather
    • [ ] "InsideLoot" value/count (Loot only inside the dungeon)
    • [ ] "OutsideLoot" value/count (Loot only not inside the dungeon and not in the ship)
    • [ ] Current time
    • [ ] Countdown until midnight
    • [ ] Available money
    • [ ] Probably more...
  • [x] Refactor the code to be more dynamic and reliable
  • [x] Optimize scrap calculation methods for performance
  • [x] Option to disable the bounding line entirely
  • [x] Option to make the HUD elements not tied to scanning so they are always shown
    • [x] Make this honor the allow outside setting, if not allowed outside then only always show while on the ship
  • [x] Enable Rich Text support for each text field (override text formatting and color for specific elements instead of just the whole line)
  • [ ] Option to change the HUD elements position (so it could be moved anywhere on screen)
    • [ ] Once this is working, remove the original ShipLoot incompatibility (so both could be ran together if desired)
  • [ ] Option to change the HUD elements size/scaling (so it can be resized as well)
  • [ ] Option to customize the color coded deadline colors and thresholds
  • [ ] Option to change font
  • [x] Configurable timeout so you can customize how long it shows
  • [x] Expand the width of the text elements so more data can be shown before it truncates
  • [ ] Expand the amount of lines that can be enabled (from a default of 3, up to 5) with auto scaling
  • [x] Remove the "Position" drop down as its not needed since any data can be set on any line
  • [x] Rename the different line names from [Ship, Quota, Days left] => [Line1, Line2, Line3, etc]
  • [x] Make LethalConfig a soft dependency in the plugin so it can be uninstalled and ShipLootPlus still be functional
Potential Future Features (Suggestions that I may or may not do)
  • Add an additional hud element that allows you to see the exact scrap list and which items you need to make quota (would be disabled by default)
    • Make this new HUD element position configurable
    • Make this new HUD element scale configurable
  • Add the ability to send data updates to a configurable websocket endpoint via serialized json (would be disabled by default)

Dependencies

NOTE: With v1.0.1+ LethalConfig is a soft dependency but to get the best experience it is still required by the Thunderstore package. It allows you to change any setting for ShipLootPlus at any time, even landed on a moon, and it will update everything in real time. If do not want LethalConfig in your pack, you can safely remove it and this mod will still work just fine.

  • LethalConfig: Used to configure the mod while in-game with a friendly user interface
    • Soft Dependency => I have made it a soft dependency so it can be removed if desired with out breaking ShipLootPlus

Compatibility

The following are mods either tested to be compatible or not

Incompatible

  • ShipLoot: Since this is basically a full rewrite of ShipLoot, it is not compatible with it. This mod will disable the original ShipLoot if it is found.
  • Likely other mods that add similar HUD elements (at least until I add the custom position and scaling features)

Compatible (Tested by me or the community)

Other Mods

EnhancedSpectator PrideSuits PrideSuitsAnimated PrideCosmetics

CHANGELOG

v1.1.0

  • Refactored the data refresh method to handle when the scrap list is null and/or a scrap item is missing required properties (should fix Issue #9)
  • Moved all Unity GameObject manipulation (changing/updating) to the main thread during data refresh
  • Added a slight delay when new scrap is brought onto the ship to avoid a race condition where the moons scrap list became desynced
  • Now correctly unloads the font asset bundle after the assets have been loaded
  • Some minor code cleanup
  • Compiled with the latest version of LethalConfig and updated the dependency version in the mod manifest
  • Compiled with the latest version of Lethal Company (v50 public release)

v1.0.9

  • Cleaned up some of the code and fixed a couple misspellings
  • Added additional null checks in every patch method to ensure nothing is used when objects are unexpectedly null
  • Added configuration option to disable all RPC hooks
    • This will impact how often the data points are updated, but it should stop any errors happening when RPC messages are received and objects aren't ready for it.
  • Added Debug Mode configuration to enable verbose logging
    • IMPORTANT this will cause performance degradation unless you are using AsyncLoggers!
  • Updated readme

v1.0.8

  • Changed most of the UI element code to be better aligned and scaled
    • Also modified the character and word spacing to be nicer
    • I also changed which HUD element my UI elements are parented to - It is now higher in the object hierarchy and directly under the "IngamePlayerHUD" object.
  • Added layout config options - You can now set the following:
    • Change the X (Left/Right) position and Scaling
    • Change the Y (Up/Down) position and Scaling
    • Change the Z (Tilt) rotation
    • Change the text field width offset (allows it to show more or less text before truncating)
  • Added font config options - You can now set the following:
    • Moved All Caps from the General section into this section
    • Change the font - I have added a font bundle for the 3 current versions of the "3270Fonts" font that the game uses (bundle includes embedded license and I added the license to my mod package)
      • Vanilla = Normal game font
      • Fixed = Currently available version of the font (fixes the dollar sign and other special characters)
      • Fixed-Semi-Condensed = Same as Fixed but slightly more condensed
      • Fixed-Condensed = Same as Fixed but more condensed

      Note: If you are a mod developer and want to use this font asset bundle, please read the "Font Asset Bundle Information" section in the readme

    • Change the font size - IMPORTANT: I must stress that changing the font size could cause the layout spacing to have unwanted outcomes
    • Change the character spacing
    • Change the word spacing
    • Change the text element alignments - IMPORTANT: I must stress that changing this will DEFINITELY have unwanted outcomes to the layout
    • Change the text transparency (alpha)
  • Changed how short data points are handled
    • You can now make any data point short by adding a ":#" inside the percent signs (e.g. %Weather:4%)
    • Renamed %MoonLongName% to %MoonName%
    • Removed the Short Character Count config setting
    • Removed the %MoonShortName% and the %WeatherShort% data points
  • Changed how the Deadline color coding works
    • There is now a whole section for the Deadline data point
    • You can enable/disable the color coding
    • You can enable/disable replacing zero with a custom string (Default: <b>NOW!</b>)
    • Set the color for each threshold (2+ days left, 1 day left, 0 days left)
    • Removed the %DeadlineWithColors% data point
  • Added a config section for the MoonName data point
    • You can enable/disable showing the full moon name (e.g. 21 Offense vs Offense)
    • You can enable/disable replacing the company moons name with a custom string (Default: Company Building)
  • Added a clear/none weather custom text string configuration - Make it blank to keep it as None (Default: Clear)
  • Added color coding with customization for the Weather data point
    • You can enable/disable color coding for the %Weather% data point
      • Support was added for the HellWeather mod so its 'Hell' weather variant can have its own color
    • You can set a custom color for each type of weather
  • Added a configuration converter so that old settings get migrated to new settings
    • This includes automatically converting any short data point that was used before to the new format using the old short character count value
    • This should also clean up the config file so there are no orphaned config entries
  • Since the layout changes made the scaling better and more concise I have changed the following default Line formats:
    • Line #1: Ship: $%ShipLootValue%(%ShipLootCount%) / $%MoonLootValue%(%MoonLootCount%) <i>[%MoonName%:%Weather%]</i>
    • Line #2: Quota: $%FulfilledValue% / $%QuotaValue% - Profit: $%ExpectedProfit%(%CompanyRate%%)

v1.0.7

  • Fixed an issue where a players dead body counted in the scrap calculation, they are now ignored.
  • Fixed a rare error when leaving a lobby after having just scanned causing the mod to stop working until a game restart

v1.0.6

  • Fixed a compatibility issue with MelonLoader where it would throw an error causing ShipLootPlus to not load correctly
  • Changed how the original ShipLoot is handled if its found, ShipLootPlus will now disable the original if its found

v1.0.5

  • Actually fixed joining a server as a client mid-round with scrap already on the ship not calculating correctly for the joined player
  • Fixed scrap values not updating correctly when placing scrap items on the counter at the company
  • Balanced the rate limiting to make it feel better when interacting with scrap

v1.0.4

  • Fixed an issue where joining a server as a client mid-round with scrap already on the ship was not calculating correctly for the joined player.
  • Fixed an issue where spamming the grab button many times a second causing the same issues as the perpetual scan which caused a game crash (buffer overrun).
  • Fixed an issue where selling items at the company would'nt refresh the data on occasion
  • Fixed an issue where moon scrap value/count wasn't updating for all players on level load until the ship had fully landed
  • Fixed patching methods that were some how not actually patching correctly
    • I also deep dived the hooked events and realized that I could remove some after I got these patches to actually apply
  • Changed the refresh method to be rate limited so if an event wants to update the values but the values are already being refreshed it will skip triggering another refresh (this should add performance in the situations where multiple hooked events trigger a data refresh concurrently)
  • Removed a left over ForceMeshUpdate() call which was not needed

v1.0.3

  • Hopefully fixed a compatibility issue with mods that modify the scanner to be able to perpetually scan (like Hold Scan Button)
  • Added a new configuration section for "On Scan"
    • Moved "Display Duration" into this new section
    • Added "Reset Duration Timer On Scan" option which will reset the timer of the UI when a scan is initialized, which keeps the UI always on screen if scanning is active (defaults to disabled).
    • Added "Refresh Data On Scan" option which will force a data update on scan, this is not really needed as all data is updated via event triggers, but it was left in the last two releases as a way to force refresh on demand. This is what is incompatible with mods like Hold Scan Button (defaults to disabled).
  • Fixed an issue where moon scrap count was showing as 1 item while in space.

v1.0.2

  • Fixed an issue where "Always On" mode did not function correctly when "Allow Outside" and/or "Allow Inside" was disabled.
  • Fixed an issue where the "On Scan" timeout didn't get reset when scanning again
  • Updated readme with better Rich Text resource links (thanks persondatlovesgames)

v1.0.1

IMPORTANT: With v1.0.1 there has been some changes which will reset any custom line formats and colors. You do not need to regenerate your configs and these settings will still be in your config file, its just that the line names and categories have changed (though now you would have extra data in the files).

  • Refactored and abstracted most of the code to be more dynamic, performant, and reliable
  • Optimized the calculation methods for getting scrap items and values

  • Changed how the data is refreshed, it is now event driven so that the data is always updated even when not being shown
    • I only hooked events that affect the data point values but it will also trigger a refresh on scan. The end result is the data will always be current.
  • Changed LethalConfig to a soft dependency so it can safely be removed (if desired) and not break ShipLootPlus
    • The Thunderstore package will still have it as a dependency as using it is the intended way to configure ShipLootPlus
  • Changed the %LootValue% replacement pattern to %ShipLootValue%
  • Changed the %DaysLeft% replacement pattern to %Deadline%
  • Changed the different line names from [Ship, Quota, Days left] to [Line #1, Line #2, Line #3] since all data points are available to all lines.

  • Added a slight angle to the UI elements so they better match other HUD elements
  • Added width to the text field so it can be longer with out truncating
    • This is dynamic based on which lines are enabled due to scaling (when I make the custom scaling system it will be configurable)
  • Added "Allow Inside" setting which works like "Allow Outside" but for inside the dungeon
  • Added "Always On" mode - Decouples it from the scanner so you can always have it on screen
    • This mode will honor the "Allow Outside" setting => False means the UI will not show outside the ship or dungeon
    • This mode will honor the "Allow Inside" setting => False means the UI will not show inside the dungeon
  • Added a configuration for duration timing (how long the UI shows after right clicking to scan. Range: 1 - 60 seconds. Default: 5 seconds)
  • Added the ability to hide the line graphic
  • Added a config for how many characters the "Short" data point variants return (Default: 3)
  • Added support for Rich Text formatting. The line color in the config is applied to the line element first, meaning rich text formatting is applied after
    • Refer to This Guide on how to use rich text formatting
  • Added the following data points:
     %MoonLootValue%      = Value of all scrap on the moon (excluding the ship)
     %AllLootValue%       = Value of all scrap (ship and moon)
     %ShipLootCount%      = Count of scrap items in the ship (excluding the moon)
     %MoonLootCount%      = Count of scrap items on the moon (excluding the ship)
     %AllLootCount%       = Count of scrap items (ship and moon)
     %CompanyRate%        = Current company buy rate
     %ExpectedProfit%     = Expected profit from scap on ship at current company buy rate
     %DeadlineWithColors% = Quota deadline in days but changes colors based on value (color thresholds will be customizable in the future)
     %DayNumber%          = Integer of days in the ship/save (E.g. 1, 3 ,10)
     %DayNumberHuman%     = Human friendly days in the ship/save (E.g. 1st, 3rd, 10th)
     %Weather%            = Current moons weather full name
     %WeatherShort%       = Current moons weather short name (Default is first 3 characters)
     %MoonLongName%       = Current moons full name
     %MoonShortName%      = Current moons short name (Default is first 3 characters)
    

  • Removed the Position drop down configuration item as it is no longer needed
    • This will be replaced with a coordinate based position system in a later update

v1.0.0

  • Release