api: Add support for verbose inventory quantities (#2814)

* -

-

* Add VerboseInventoryQuantitiesMixin with changes.

* Fix checkstyle and add copyright header.

* Remove unused imports

* Checkstyle hotfix

* Checkstyle

* Checkstyle2

* Change Internal name to itemQuantitiesVerbose
This commit is contained in:
ImNoOSRS
2020-09-24 13:41:12 +02:00
committed by GitHub
parent 4668ed6251
commit e5a74473fd
4 changed files with 68 additions and 2 deletions

View File

@@ -1704,6 +1704,13 @@ public interface Client extends GameShell
*/
void setCompass(Sprite Sprite);
/**
* Sets whether inventory quantity is verbose.
*
* @param state verbose state
*/
void setItemQuantitiesVerbose(boolean state);
/**
* Returns widget sprite cache, to be used with {@link Client#getSpriteOverrides()}
*

View File

@@ -0,0 +1,57 @@
/*
* Copyright (c) 2020, ImNoOSRS <https://github.com/ImNoOSRS>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.runelite.mixins;
import net.runelite.api.mixins.Copy;
import net.runelite.api.mixins.Inject;
import net.runelite.api.mixins.Mixin;
import net.runelite.api.mixins.Replace;
import net.runelite.rs.api.RSClient;
@Mixin(RSClient.class)
public abstract class VerboseInventoryQuantitiesMixin implements RSClient
{
@Inject
private static boolean itemQuantitiesVerbose;
@Inject
@Override
public void setItemQuantitiesVerbose(boolean state)
{
itemQuantitiesVerbose = state;
}
@Copy("inventoryQuantityFormat")
@Replace("inventoryQuantityFormat")
public static String getInventoryQuantityFormat(int n)
{
if (itemQuantitiesVerbose)
{
return String.valueOf(n);
}
return getInventoryQuantityFormat(n);
}
}

View File

@@ -188,7 +188,7 @@ public class ChatChannel {
}
if (var4 == 1 || var4 == 2 && var9.isStackable == 1) { // L: 409
ScriptEvent.ItemDefinition_fontPlain11.draw(class194.method3712(var1), 0, 9, 16776960, 1); // L: 410
ScriptEvent.ItemDefinition_fontPlain11.draw(class194.inventoryQuantityFormat(var1), 0, 9, 16776960, 1); // L: 410
}
if (!var5) { // L: 412

View File

@@ -1,3 +1,4 @@
import net.runelite.mapping.Export;
import net.runelite.mapping.ObfuscatedName;
import net.runelite.mapping.ObfuscatedSignature;
@@ -79,7 +80,8 @@ public class class194 {
descriptor = "(IS)Ljava/lang/String;",
garbageValue = "4096"
)
static final String method3712(int var0) {
@Export("inventoryQuantityFormat")
static final String inventoryQuantityFormat(int var0) {
if (var0 < 100000) { // L: 421
return "<col=ffff00>" + var0 + "</col>";
} else {