model-viewer: render kits too
This commit is contained in:
@@ -0,0 +1,64 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2017, Adam <Adam@sigterm.info>
|
||||||
|
* 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.modelviewer;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import net.runelite.cache.definitions.KitDefinition;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
public class KitManager
|
||||||
|
{
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(KitManager.class);
|
||||||
|
|
||||||
|
private static Map<Integer, KitDefinition> kits = new HashMap<>();
|
||||||
|
|
||||||
|
public static KitDefinition getKit(int id)
|
||||||
|
{
|
||||||
|
KitDefinition def = kits.get(id);
|
||||||
|
if (def != null)
|
||||||
|
{
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
|
||||||
|
try (FileInputStream in = new FileInputStream(new File("kits/" + id + ".json")))
|
||||||
|
{
|
||||||
|
def = new Gson().fromJson(new InputStreamReader(in), KitDefinition.class);
|
||||||
|
kits.put(id, def);
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
catch (IOException ex)
|
||||||
|
{
|
||||||
|
logger.warn(null, ex);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -68,7 +68,10 @@ public class ModelManager
|
|||||||
ModelLoader loader = new ModelLoader();
|
ModelLoader loader = new ModelLoader();
|
||||||
md = loader.load(id, b);
|
md = loader.load(id, b);
|
||||||
|
|
||||||
rotate(md, object, location);
|
if (object != null && location != null)
|
||||||
|
{
|
||||||
|
rotate(md, object, location);
|
||||||
|
}
|
||||||
|
|
||||||
models.put(key, md);
|
models.put(key, md);
|
||||||
return md;
|
return md;
|
||||||
|
|||||||
@@ -33,10 +33,12 @@ import java.io.IOException;
|
|||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import javax.imageio.ImageIO;
|
import javax.imageio.ImageIO;
|
||||||
|
import net.runelite.cache.definitions.KitDefinition;
|
||||||
import net.runelite.cache.definitions.ModelDefinition;
|
import net.runelite.cache.definitions.ModelDefinition;
|
||||||
import net.runelite.cache.definitions.NpcDefinition;
|
import net.runelite.cache.definitions.NpcDefinition;
|
||||||
import net.runelite.cache.definitions.ObjectDefinition;
|
import net.runelite.cache.definitions.ObjectDefinition;
|
||||||
@@ -100,6 +102,7 @@ public class ModelViewer
|
|||||||
options.addOption(null, "object", true, "object to render");
|
options.addOption(null, "object", true, "object to render");
|
||||||
options.addOption(null, "model", true, "model to render");
|
options.addOption(null, "model", true, "model to render");
|
||||||
options.addOption(null, "map", true, "map region to render");
|
options.addOption(null, "map", true, "map region to render");
|
||||||
|
options.addOption(null, "kits", true, "kits to render");
|
||||||
|
|
||||||
CommandLineParser parser = new DefaultParser();
|
CommandLineParser parser = new DefaultParser();
|
||||||
CommandLine cmd = parser.parse(options, args);
|
CommandLine cmd = parser.parse(options, args);
|
||||||
@@ -180,6 +183,21 @@ public class ModelViewer
|
|||||||
loadUnderlays();
|
loadUnderlays();
|
||||||
loadOverlays();
|
loadOverlays();
|
||||||
}
|
}
|
||||||
|
if (cmd.hasOption("kits"))
|
||||||
|
{
|
||||||
|
String kits = cmd.getOptionValue("kits");
|
||||||
|
Integer[] kitIds = Arrays.stream(kits.split(",")).map(s -> Integer.parseInt(s)).toArray(Integer[]::new);
|
||||||
|
|
||||||
|
for (int kitId : kitIds)
|
||||||
|
{
|
||||||
|
KitDefinition kit = KitManager.getKit(kitId);
|
||||||
|
for (int model : kit.modelIds)
|
||||||
|
{
|
||||||
|
ModelDefinition md = ModelManager.getModel(model, null, null);
|
||||||
|
models.add(md);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Display.setDisplayMode(new DisplayMode(800, 600));
|
Display.setDisplayMode(new DisplayMode(800, 600));
|
||||||
Display.setTitle("Model Viewer");
|
Display.setTitle("Model Viewer");
|
||||||
@@ -297,7 +315,9 @@ public class ModelViewer
|
|||||||
assert texture != null;
|
assert texture != null;
|
||||||
|
|
||||||
if (md.faceTextureUCoordinates == null || md.faceTextureVCoordinates == null)
|
if (md.faceTextureUCoordinates == null || md.faceTextureVCoordinates == null)
|
||||||
|
{
|
||||||
md.computeTextureUVCoordinates();
|
md.computeTextureUVCoordinates();
|
||||||
|
}
|
||||||
|
|
||||||
u = md.faceTextureUCoordinates[i];
|
u = md.faceTextureUCoordinates[i];
|
||||||
v = md.faceTextureVCoordinates[i];
|
v = md.faceTextureVCoordinates[i];
|
||||||
|
|||||||
Reference in New Issue
Block a user