Merge pull request #5295 from deathbeam/sprite-overrides-flexible

Make sprite and widget sprite overrides more flexible
This commit is contained in:
Tomas Slusny
2018-09-28 22:11:53 +02:00
committed by GitHub
7 changed files with 96 additions and 51 deletions

View File

@@ -1394,24 +1394,20 @@ public interface Client extends GameEngine
void queueChangedSkill(Skill skill); void queueChangedSkill(Skill skill);
/** /**
* Sets a mapping of sprites to override. * Gets a mapping of sprites to override.
* <p> * <p>
* The key value in the map corresponds to the ID of the sprite, * The key value in the map corresponds to the ID of the sprite,
* and the value the sprite to replace it with. * and the value the sprite to replace it with.
*
* @param overrides the sprites to override
*/ */
void setSpriteOverrides(Map<Integer, SpritePixels> overrides); Map<Integer, SpritePixels> getSpriteOverrides();
/** /**
* Sets a mapping of widget sprites to override. * Gets a mapping of widget sprites to override.
* <p> * <p>
* The key value in the map corresponds to the packed widget ID, * The key value in the map corresponds to the packed widget ID,
* and the value the sprite to replace the widgets sprite with. * and the value the sprite to replace the widgets sprite with.
*
* @param overrides the sprites to override
*/ */
void setWidgetSpriteOverrides(Map<Integer, SpritePixels> overrides); Map<Integer, SpritePixels> getWidgetSpriteOverrides();
/** /**
* Sets the compass sprite. * Sets the compass sprite.
@@ -1420,6 +1416,13 @@ public interface Client extends GameEngine
*/ */
void setCompass(SpritePixels spritePixels); void setCompass(SpritePixels spritePixels);
/**
* Returns widget sprite cache, to be used with {@link Client#getSpriteOverrides()}
*
* @return the cache
*/
NodeCache getWidgetSpriteCache();
/** /**
* Gets the current server tick count. * Gets the current server tick count.
* *

View File

@@ -0,0 +1,36 @@
/*
* Copyright (c) 2018, Tomas Slusny <slusnucky@gmail.com>
* 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.api;
/**
* Represents a doubly linked node cache.
*/
public interface NodeCache
{
/**
* Resets cache.
*/
void reset();
}

View File

@@ -32,8 +32,6 @@ import java.awt.image.BufferedImage;
import java.awt.image.PixelGrabber; import java.awt.image.PixelGrabber;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;
import javax.imageio.ImageIO; import javax.imageio.ImageIO;
import javax.inject.Inject; import javax.inject.Inject;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
@@ -80,13 +78,7 @@ public class InterfaceStylesPlugin extends Plugin
@Override @Override
protected void startUp() throws Exception protected void startUp() throws Exception
{ {
clientThread.invoke(() -> clientThread.invoke(this::updateAllOverrides);
{
overrideSprites();
overrideWidgetSprites();
restoreWidgetDimensions();
adjustWidgetDimensions();
});
} }
@Override @Override
@@ -104,14 +96,7 @@ public class InterfaceStylesPlugin extends Plugin
{ {
if (config.getGroup().equals("interfaceStyles")) if (config.getGroup().equals("interfaceStyles"))
{ {
clientThread.invoke(() -> clientThread.invoke(this::updateAllOverrides);
{
removeGameframe();
overrideSprites();
overrideWidgetSprites();
restoreWidgetDimensions();
adjustWidgetDimensions();
});
} }
} }
@@ -121,10 +106,17 @@ public class InterfaceStylesPlugin extends Plugin
adjustWidgetDimensions(); adjustWidgetDimensions();
} }
private void updateAllOverrides()
{
removeGameframe();
overrideSprites();
overrideWidgetSprites();
restoreWidgetDimensions();
adjustWidgetDimensions();
}
private void overrideSprites() private void overrideSprites()
{ {
Map<Integer, SpritePixels> overrides = new HashMap<>();
for (SpriteOverride spriteOverride : SpriteOverride.values()) for (SpriteOverride spriteOverride : SpriteOverride.values())
{ {
for (Skin skin : spriteOverride.getSkin()) for (Skin skin : spriteOverride.getSkin())
@@ -139,19 +131,25 @@ public class InterfaceStylesPlugin extends Plugin
} }
else else
{ {
overrides.put(spriteOverride.getSpriteID(), spritePixels); client.getSpriteOverrides().put(spriteOverride.getSpriteID(), spritePixels);
} }
} }
} }
} }
}
client.setSpriteOverrides(overrides); private void restoreSprites()
{
client.getWidgetSpriteCache().reset();
for (SpriteOverride spriteOverride : SpriteOverride.values())
{
client.getSpriteOverrides().remove(spriteOverride.getSpriteID());
}
} }
private void overrideWidgetSprites() private void overrideWidgetSprites()
{ {
Map<Integer, SpritePixels> widgetOverrides = new HashMap<>();
for (WidgetOverride widgetOverride : WidgetOverride.values()) for (WidgetOverride widgetOverride : WidgetOverride.values())
{ {
if (widgetOverride.getSkin() == config.skin()) if (widgetOverride.getSkin() == config.skin())
@@ -162,13 +160,22 @@ public class InterfaceStylesPlugin extends Plugin
{ {
for (WidgetInfo widgetInfo : widgetOverride.getWidgetInfo()) for (WidgetInfo widgetInfo : widgetOverride.getWidgetInfo())
{ {
widgetOverrides.put(widgetInfo.getPackedId(), spritePixels); client.getWidgetSpriteOverrides().put(widgetInfo.getPackedId(), spritePixels);
} }
} }
} }
} }
}
client.setWidgetSpriteOverrides(widgetOverrides); private void restoreWidgetSprites()
{
for (WidgetOverride widgetOverride : WidgetOverride.values())
{
for (WidgetInfo widgetInfo : widgetOverride.getWidgetInfo())
{
client.getWidgetSpriteOverrides().remove(widgetInfo.getPackedId());
}
}
} }
private SpritePixels getFileSpritePixels(String file, String subfolder) private SpritePixels getFileSpritePixels(String file, String subfolder)
@@ -292,8 +299,8 @@ public class InterfaceStylesPlugin extends Plugin
private void removeGameframe() private void removeGameframe()
{ {
client.setSpriteOverrides(null); restoreSprites();
client.setWidgetSpriteOverrides(null); restoreWidgetSprites();
BufferedImage compassImage = spriteManager.getSprite(SpriteID.COMPASS_TEXTURE, 0); BufferedImage compassImage = spriteManager.getSprite(SpriteID.COMPASS_TEXTURE, 0);

View File

@@ -25,6 +25,7 @@
*/ */
package net.runelite.mixins; package net.runelite.mixins;
import java.util.HashMap;
import java.util.Map; import java.util.Map;
import net.runelite.api.SpritePixels; import net.runelite.api.SpritePixels;
import net.runelite.api.mixins.Copy; import net.runelite.api.mixins.Copy;
@@ -39,24 +40,23 @@ import net.runelite.rs.api.RSSpritePixels;
public abstract class SpriteMixin implements RSClient public abstract class SpriteMixin implements RSClient
{ {
@Inject @Inject
private static Map<Integer, SpritePixels> spriteOverrides; private static final Map<Integer, SpritePixels> spriteOverrides = new HashMap<Integer, SpritePixels>();
@Inject @Inject
private static Map<Integer, SpritePixels> widgetSpriteOverrides; private static final Map<Integer, SpritePixels> widgetSpriteOverrides = new HashMap<Integer, SpritePixels>();
@Inject @Inject
@Override @Override
public void setSpriteOverrides(Map<Integer, SpritePixels> overrides) public Map<Integer, SpritePixels> getSpriteOverrides()
{ {
getWidgetSpriteCache().reset(); return spriteOverrides;
spriteOverrides = overrides;
} }
@Inject @Inject
@Override @Override
public void setWidgetSpriteOverrides(Map<Integer, SpritePixels> overrides) public Map<Integer, SpritePixels> getWidgetSpriteOverrides()
{ {
widgetSpriteOverrides = overrides; return widgetSpriteOverrides;
} }
@Copy("getSpriteAsSpritePixels") @Copy("getSpriteAsSpritePixels")
@@ -68,14 +68,11 @@ public abstract class SpriteMixin implements RSClient
@Replace("getSpriteAsSpritePixels") @Replace("getSpriteAsSpritePixels")
public static RSSpritePixels rl$loadSprite(RSIndexDataBase var0, int var1, int var2) public static RSSpritePixels rl$loadSprite(RSIndexDataBase var0, int var1, int var2)
{ {
if (spriteOverrides != null) SpritePixels sprite = spriteOverrides.get(var1);
{
SpritePixels sprite = spriteOverrides.get(var1);
if (sprite != null) if (sprite != null)
{ {
return (RSSpritePixels) sprite; return (RSSpritePixels) sprite;
}
} }
return rs$loadSprite(var0, var1, var2); return rs$loadSprite(var0, var1, var2);

View File

@@ -49,7 +49,7 @@ public abstract class WidgetSpriteMixin implements RSWidget
@Replace("getWidgetSprite") @Replace("getWidgetSprite")
public RSSpritePixels rl$getWidgetSprite(boolean var1) public RSSpritePixels rl$getWidgetSprite(boolean var1)
{ {
if (getSpriteId() != -1 && widgetSpriteOverrides != null) if (getSpriteId() != -1)
{ {
SpritePixels sprite = widgetSpriteOverrides.get(getId()); SpritePixels sprite = widgetSpriteOverrides.get(getId());

View File

@@ -645,6 +645,7 @@ public interface RSClient extends RSGameEngine, Client
void setCompass(SpritePixels spritePixels); void setCompass(SpritePixels spritePixels);
@Import("widgetSpriteCache") @Import("widgetSpriteCache")
@Override
RSNodeCache getWidgetSpriteCache(); RSNodeCache getWidgetSpriteCache();
@Import("oculusOrbState") @Import("oculusOrbState")

View File

@@ -24,9 +24,10 @@
*/ */
package net.runelite.rs.api; package net.runelite.rs.api;
import net.runelite.api.NodeCache;
import net.runelite.mapping.Import; import net.runelite.mapping.Import;
public interface RSNodeCache public interface RSNodeCache extends NodeCache
{ {
@Import("get") @Import("get")
RSCacheableNode get(long id); RSCacheableNode get(long id);