Merge pull request #189 from tylerthardy/spriteManager
Add item image fetching to ItemManager
This commit is contained in:
@@ -33,4 +33,6 @@ public interface SpritePixels
|
|||||||
int getWidth();
|
int getWidth();
|
||||||
|
|
||||||
int getHeight();
|
int getHeight();
|
||||||
|
|
||||||
|
int[] getPixels();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -25,9 +25,16 @@
|
|||||||
package net.runelite.client.game;
|
package net.runelite.client.game;
|
||||||
|
|
||||||
import com.google.common.cache.CacheBuilder;
|
import com.google.common.cache.CacheBuilder;
|
||||||
|
import com.google.common.cache.CacheLoader;
|
||||||
import com.google.common.cache.LoadingCache;
|
import com.google.common.cache.LoadingCache;
|
||||||
|
|
||||||
|
import java.awt.image.BufferedImage;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.ExecutionException;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import net.runelite.api.Client;
|
||||||
|
import net.runelite.api.SpritePixels;
|
||||||
import net.runelite.client.RuneLite;
|
import net.runelite.client.RuneLite;
|
||||||
import net.runelite.http.api.item.ItemClient;
|
import net.runelite.http.api.item.ItemClient;
|
||||||
import net.runelite.http.api.item.ItemPrice;
|
import net.runelite.http.api.item.ItemPrice;
|
||||||
@@ -44,15 +51,30 @@ public class ItemManager
|
|||||||
*/
|
*/
|
||||||
static final ItemPrice NONE = new ItemPrice();
|
static final ItemPrice NONE = new ItemPrice();
|
||||||
|
|
||||||
private final ItemClient client = new ItemClient();
|
|
||||||
|
private final ItemClient itemClient = new ItemClient();
|
||||||
private final LoadingCache<Integer, ItemPrice> itemPrices;
|
private final LoadingCache<Integer, ItemPrice> itemPrices;
|
||||||
|
|
||||||
|
private static LoadingCache<Integer, BufferedImage> itemImages;
|
||||||
|
|
||||||
public ItemManager(RuneLite runelite)
|
public ItemManager(RuneLite runelite)
|
||||||
{
|
{
|
||||||
itemPrices = CacheBuilder.newBuilder()
|
itemPrices = CacheBuilder.newBuilder()
|
||||||
.maximumSize(512L)
|
.maximumSize(512L)
|
||||||
.expireAfterAccess(1, TimeUnit.HOURS)
|
.expireAfterAccess(1, TimeUnit.HOURS)
|
||||||
.build(new ItemPriceLoader(runelite, client));
|
.build(new ItemPriceLoader(runelite, itemClient));
|
||||||
|
|
||||||
|
itemImages = CacheBuilder.newBuilder()
|
||||||
|
.maximumSize(200)
|
||||||
|
.expireAfterAccess(1, TimeUnit.HOURS)
|
||||||
|
.build(new CacheLoader<Integer, BufferedImage>()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public BufferedImage load(Integer itemId) throws Exception
|
||||||
|
{
|
||||||
|
return loadImage(itemId);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -88,7 +110,7 @@ public class ItemManager
|
|||||||
return itemPrice == NONE ? null : itemPrice;
|
return itemPrice == NONE ? null : itemPrice;
|
||||||
}
|
}
|
||||||
|
|
||||||
itemPrice = client.lookupItemPrice(itemId);
|
itemPrice = itemClient.lookupItemPrice(itemId);
|
||||||
itemPrices.put(itemId, itemPrice);
|
itemPrices.put(itemId, itemPrice);
|
||||||
return itemPrice;
|
return itemPrice;
|
||||||
}
|
}
|
||||||
@@ -113,4 +135,48 @@ public class ItemManager
|
|||||||
|
|
||||||
return "" + quantity;
|
return "" + quantity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads item sprite from game, makes transparent, and generates image
|
||||||
|
* @param itemId
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private BufferedImage loadImage(int itemId)
|
||||||
|
{
|
||||||
|
Client client = RuneLite.getClient();
|
||||||
|
SpritePixels sprite = client.createItemSprite(itemId, 1, 1, SpritePixels.DEFAULT_SHADOW_COLOR, 0, false);
|
||||||
|
int[] pixels = sprite.getPixels();
|
||||||
|
int[] transPixels = new int[pixels.length];
|
||||||
|
BufferedImage img = new BufferedImage(sprite.getWidth(), sprite.getHeight(), BufferedImage.TYPE_INT_ARGB);
|
||||||
|
|
||||||
|
for (int i = 0; i < pixels.length; i++)
|
||||||
|
{
|
||||||
|
if (pixels[i] != 0)
|
||||||
|
{
|
||||||
|
transPixels[i] = pixels[i] | 0xff000000;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
img.setRGB(0, 0, sprite.getWidth(), sprite.getHeight(), transPixels, 0, sprite.getWidth());
|
||||||
|
|
||||||
|
return img;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get item sprite image as BufferedImage
|
||||||
|
*
|
||||||
|
* @param itemId
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static BufferedImage getImage(int itemId)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return itemImages.get(itemId);
|
||||||
|
}
|
||||||
|
catch (ExecutionException ex)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ public enum FishingSpot
|
|||||||
private static final Map<Integer, FishingSpot> fishingSpots = new HashMap<>();
|
private static final Map<Integer, FishingSpot> fishingSpots = new HashMap<>();
|
||||||
|
|
||||||
private final String name;
|
private final String name;
|
||||||
private final int itemSpriteId;
|
private final int fishSpriteId;
|
||||||
private final int[] spots;
|
private final int[] spots;
|
||||||
|
|
||||||
static
|
static
|
||||||
@@ -109,10 +109,10 @@ public enum FishingSpot
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
FishingSpot(String spot, int itemSpriteId, int... spots)
|
FishingSpot(String spot, int fishSpriteId, int... spots)
|
||||||
{
|
{
|
||||||
this.name = spot;
|
this.name = spot;
|
||||||
this.itemSpriteId = itemSpriteId;
|
this.fishSpriteId = fishSpriteId;
|
||||||
this.spots = spots;
|
this.spots = spots;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -121,9 +121,9 @@ public enum FishingSpot
|
|||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getItemSpriteId()
|
public int getFishSpriteId()
|
||||||
{
|
{
|
||||||
return itemSpriteId;
|
return fishSpriteId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int[] getIds()
|
public int[] getIds()
|
||||||
|
|||||||
@@ -28,14 +28,15 @@ import com.google.common.primitives.Ints;
|
|||||||
import java.awt.Color;
|
import java.awt.Color;
|
||||||
import java.awt.Dimension;
|
import java.awt.Dimension;
|
||||||
import java.awt.Graphics2D;
|
import java.awt.Graphics2D;
|
||||||
|
import java.awt.image.BufferedImage;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import net.runelite.api.Client;
|
import net.runelite.api.Client;
|
||||||
import net.runelite.api.GameState;
|
import net.runelite.api.GameState;
|
||||||
import net.runelite.api.NPC;
|
import net.runelite.api.NPC;
|
||||||
import net.runelite.api.SpritePixels;
|
|
||||||
import net.runelite.api.queries.NPCQuery;
|
import net.runelite.api.queries.NPCQuery;
|
||||||
import net.runelite.client.RuneLite;
|
import net.runelite.client.RuneLite;
|
||||||
|
import net.runelite.client.game.ItemManager;
|
||||||
import net.runelite.client.ui.overlay.Overlay;
|
import net.runelite.client.ui.overlay.Overlay;
|
||||||
import net.runelite.client.ui.overlay.OverlayPosition;
|
import net.runelite.client.ui.overlay.OverlayPosition;
|
||||||
import net.runelite.client.ui.overlay.OverlayUtil;
|
import net.runelite.client.ui.overlay.OverlayUtil;
|
||||||
@@ -81,10 +82,10 @@ class FishingSpotOverlay extends Overlay
|
|||||||
Color color = npc.getId() == FishingSpot.FLYING_FISH ? Color.RED : Color.CYAN;
|
Color color = npc.getId() == FishingSpot.FLYING_FISH ? Color.RED : Color.CYAN;
|
||||||
if (config.showIcons())
|
if (config.showIcons())
|
||||||
{
|
{
|
||||||
SpritePixels fishSprite = getFishSprite(spot);
|
BufferedImage fishImage = getFishImage(spot);
|
||||||
if (fishSprite != null)
|
if (fishImage != null)
|
||||||
{
|
{
|
||||||
OverlayUtil.renderActorOverlaySprite(graphics, npc, fishSprite, color.darker());
|
OverlayUtil.renderActorOverlayImage(graphics, npc, fishImage, color.darker());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -97,9 +98,10 @@ class FishingSpotOverlay extends Overlay
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private SpritePixels getFishSprite(FishingSpot spot)
|
private BufferedImage getFishImage(FishingSpot spot)
|
||||||
{
|
{
|
||||||
return client.createItemSprite(spot.getItemSpriteId(), 5, 1, SpritePixels.DEFAULT_SHADOW_COLOR, 0, false);
|
BufferedImage fishImage = ItemManager.getImage(spot.getFishSpriteId());
|
||||||
|
return fishImage;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateConfig()
|
public void updateConfig()
|
||||||
|
|||||||
@@ -40,4 +40,8 @@ public interface RSSpritePixels extends SpritePixels
|
|||||||
@Import("width")
|
@Import("width")
|
||||||
@Override
|
@Override
|
||||||
int getWidth();
|
int getWidth();
|
||||||
|
|
||||||
|
@Import("pixels")
|
||||||
|
@Override
|
||||||
|
int[] getPixels();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user