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();
|
||||
md = loader.load(id, b);
|
||||
|
||||
rotate(md, object, location);
|
||||
if (object != null && location != null)
|
||||
{
|
||||
rotate(md, object, location);
|
||||
}
|
||||
|
||||
models.put(key, md);
|
||||
return md;
|
||||
|
||||
@@ -33,10 +33,12 @@ import java.io.IOException;
|
||||
import java.io.InputStreamReader;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import javax.imageio.ImageIO;
|
||||
import net.runelite.cache.definitions.KitDefinition;
|
||||
import net.runelite.cache.definitions.ModelDefinition;
|
||||
import net.runelite.cache.definitions.NpcDefinition;
|
||||
import net.runelite.cache.definitions.ObjectDefinition;
|
||||
@@ -100,6 +102,7 @@ public class ModelViewer
|
||||
options.addOption(null, "object", true, "object to render");
|
||||
options.addOption(null, "model", true, "model to render");
|
||||
options.addOption(null, "map", true, "map region to render");
|
||||
options.addOption(null, "kits", true, "kits to render");
|
||||
|
||||
CommandLineParser parser = new DefaultParser();
|
||||
CommandLine cmd = parser.parse(options, args);
|
||||
@@ -180,6 +183,21 @@ public class ModelViewer
|
||||
loadUnderlays();
|
||||
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.setTitle("Model Viewer");
|
||||
@@ -297,7 +315,9 @@ public class ModelViewer
|
||||
assert texture != null;
|
||||
|
||||
if (md.faceTextureUCoordinates == null || md.faceTextureVCoordinates == null)
|
||||
{
|
||||
md.computeTextureUVCoordinates();
|
||||
}
|
||||
|
||||
u = md.faceTextureUCoordinates[i];
|
||||
v = md.faceTextureVCoordinates[i];
|
||||
|
||||
Reference in New Issue
Block a user