mirror of
https://github.com/webbukkit/dynmap.git
synced 2025-01-01 13:37:40 +01:00
Finish fixing new water
This commit is contained in:
parent
ea139caeab
commit
a18a1ddc06
@ -433,9 +433,6 @@ public class DynmapCore implements DynmapCommonAPI {
|
|||||||
defaultStorage.setLoginEnabled(this);
|
defaultStorage.setLoginEnabled(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Add options to avoid 0.29 re-render (fixes very inconsistent with previous maps) */
|
|
||||||
HDMapManager.waterlightingfix = configuration.getBoolean("correct-water-lighting", false);
|
|
||||||
HDMapManager.biomeshadingfix = configuration.getBoolean("correct-biome-shading", false);
|
|
||||||
/* Load control for leaf transparency (spout lighting bug workaround) */
|
/* Load control for leaf transparency (spout lighting bug workaround) */
|
||||||
transparentLeaves = configuration.getBoolean("transparent-leaves", true);
|
transparentLeaves = configuration.getBoolean("transparent-leaves", true);
|
||||||
/* Get default image format */
|
/* Get default image format */
|
||||||
|
@ -51,7 +51,7 @@ public class HDBlockStateTextureMap {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Shallow copy state from another state map
|
// Shallow copy state from another state map
|
||||||
public HDBlockStateTextureMap(HDBlockStateTextureMap map) {
|
public HDBlockStateTextureMap(HDBlockStateTextureMap map, BlockTransparency bt) {
|
||||||
this.faces = map.faces;
|
this.faces = map.faces;
|
||||||
this.layers = map.layers;
|
this.layers = map.layers;
|
||||||
this.blockset = map.blockset;
|
this.blockset = map.blockset;
|
||||||
@ -59,6 +59,9 @@ public class HDBlockStateTextureMap {
|
|||||||
this.custColorMult = map.custColorMult;
|
this.custColorMult = map.custColorMult;
|
||||||
this.stdrotate = map.stdrotate;
|
this.stdrotate = map.stdrotate;
|
||||||
this.colorMapping = map.colorMapping;
|
this.colorMapping = map.colorMapping;
|
||||||
|
if (bt != null)
|
||||||
|
this.trans = bt;
|
||||||
|
else
|
||||||
this.trans = map.trans;
|
this.trans = map.trans;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -143,7 +146,12 @@ public class HDBlockStateTextureMap {
|
|||||||
// Copy given block state to given state index
|
// Copy given block state to given state index
|
||||||
public static void copyToStateIndex(DynmapBlockState blk, HDBlockStateTextureMap map) {
|
public static void copyToStateIndex(DynmapBlockState blk, HDBlockStateTextureMap map) {
|
||||||
resize(blk.globalStateIndex);
|
resize(blk.globalStateIndex);
|
||||||
texmaps[blk.globalStateIndex] = new HDBlockStateTextureMap(map);
|
TexturePack.BlockTransparency trans = map.trans;
|
||||||
|
// Force waterloogged blocks to use SEMITRANSPARENT (same as water)
|
||||||
|
if ((trans == TexturePack.BlockTransparency.TRANSPARENT) && blk.isWaterlogged()) {
|
||||||
|
trans = TexturePack.BlockTransparency.SEMITRANSPARENT;
|
||||||
|
}
|
||||||
|
texmaps[blk.globalStateIndex] = new HDBlockStateTextureMap(map, trans);
|
||||||
}
|
}
|
||||||
// Copy textures from source block ID to destination
|
// Copy textures from source block ID to destination
|
||||||
public static void remapTexture(String dest, String src) {
|
public static void remapTexture(String dest, String src) {
|
||||||
@ -153,7 +161,7 @@ public class HDBlockStateTextureMap {
|
|||||||
for (int i = 0; i < mincnt; i++) {
|
for (int i = 0; i < mincnt; i++) {
|
||||||
int didx = dblk.getState(i).globalStateIndex;
|
int didx = dblk.getState(i).globalStateIndex;
|
||||||
int sidx = sblk.getState(i).globalStateIndex;
|
int sidx = sblk.getState(i).globalStateIndex;
|
||||||
texmaps[didx] = new HDBlockStateTextureMap(texmaps[sidx]);
|
texmaps[didx] = new HDBlockStateTextureMap(texmaps[sidx], null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Get by global state index
|
// Get by global state index
|
||||||
|
@ -21,9 +21,6 @@ public class HDMapManager {
|
|||||||
public HashSet<HDMap> maps = new HashSet<HDMap>();
|
public HashSet<HDMap> maps = new HashSet<HDMap>();
|
||||||
public HashMap<String, ArrayList<HDMap>> maps_by_world_perspective = new HashMap<String, ArrayList<HDMap>>();
|
public HashMap<String, ArrayList<HDMap>> maps_by_world_perspective = new HashMap<String, ArrayList<HDMap>>();
|
||||||
|
|
||||||
public static boolean waterlightingfix;
|
|
||||||
public static boolean biomeshadingfix;
|
|
||||||
|
|
||||||
public void loadHDShaders(DynmapCore core) {
|
public void loadHDShaders(DynmapCore core) {
|
||||||
Log.verboseinfo("Loading shaders...");
|
Log.verboseinfo("Loading shaders...");
|
||||||
/* Update mappings, if needed */
|
/* Update mappings, if needed */
|
||||||
|
@ -188,24 +188,24 @@ public class TexturePack {
|
|||||||
private static final int TILEINDEX_SHULKER_COUNT = 6;
|
private static final int TILEINDEX_SHULKER_COUNT = 6;
|
||||||
|
|
||||||
/* Indexes of faces in the BED format tile file */
|
/* Indexes of faces in the BED format tile file */
|
||||||
private static final int TILEINDEX_BED_HEAD_TOP = 0;
|
//private static final int TILEINDEX_BED_HEAD_TOP = 0;
|
||||||
private static final int TILEINDEX_BED_HEAD_BOTTOM = 1;
|
//private static final int TILEINDEX_BED_HEAD_BOTTOM = 1;
|
||||||
private static final int TILEINDEX_BED_HEAD_LEFT = 2;
|
//private static final int TILEINDEX_BED_HEAD_LEFT = 2;
|
||||||
private static final int TILEINDEX_BED_HEAD_RIGHT = 3;
|
//private static final int TILEINDEX_BED_HEAD_RIGHT = 3;
|
||||||
private static final int TILEINDEX_BED_HEAD_END = 4;
|
//private static final int TILEINDEX_BED_HEAD_END = 4;
|
||||||
private static final int TILEINDEX_BED_FOOT_TOP = 5;
|
//private static final int TILEINDEX_BED_FOOT_TOP = 5;
|
||||||
private static final int TILEINDEX_BED_FOOT_BOTTOM = 6;
|
//private static final int TILEINDEX_BED_FOOT_BOTTOM = 6;
|
||||||
private static final int TILEINDEX_BED_FOOT_LEFT = 7;
|
//private static final int TILEINDEX_BED_FOOT_LEFT = 7;
|
||||||
private static final int TILEINDEX_BED_FOOT_RIGHT = 8;
|
//private static final int TILEINDEX_BED_FOOT_RIGHT = 8;
|
||||||
private static final int TILEINDEX_BED_FOOT_END = 9;
|
//private static final int TILEINDEX_BED_FOOT_END = 9;
|
||||||
private static final int TILEINDEX_BED_HEAD_LEFTLEG_1 = 10;
|
//private static final int TILEINDEX_BED_HEAD_LEFTLEG_1 = 10;
|
||||||
private static final int TILEINDEX_BED_HEAD_LEFTLEG_2 = 11;
|
//private static final int TILEINDEX_BED_HEAD_LEFTLEG_2 = 11;
|
||||||
private static final int TILEINDEX_BED_HEAD_RIGHTLEG_1 = 12;
|
//private static final int TILEINDEX_BED_HEAD_RIGHTLEG_1 = 12;
|
||||||
private static final int TILEINDEX_BED_HEAD_RIGHTLEG_2 = 13;
|
//private static final int TILEINDEX_BED_HEAD_RIGHTLEG_2 = 13;
|
||||||
private static final int TILEINDEX_BED_FOOT_LEFTLEG_1 = 14;
|
//private static final int TILEINDEX_BED_FOOT_LEFTLEG_1 = 14;
|
||||||
private static final int TILEINDEX_BED_FOOT_LEFTLEG_2 = 15;
|
//private static final int TILEINDEX_BED_FOOT_LEFTLEG_2 = 15;
|
||||||
private static final int TILEINDEX_BED_FOOT_RIGHTLEG_1 = 16;
|
//private static final int TILEINDEX_BED_FOOT_RIGHTLEG_1 = 16;
|
||||||
private static final int TILEINDEX_BED_FOOT_RIGHTLEG_2 = 17;
|
//private static final int TILEINDEX_BED_FOOT_RIGHTLEG_2 = 17;
|
||||||
private static final int TILEINDEX_BED_COUNT = 18;
|
private static final int TILEINDEX_BED_COUNT = 18;
|
||||||
|
|
||||||
public static enum TileFileFormat {
|
public static enum TileFileFormat {
|
||||||
@ -421,7 +421,6 @@ public class TexturePack {
|
|||||||
private int colorMultBirch = 0x80a755; /* From ColorizerFoliage.java in MCP */
|
private int colorMultBirch = 0x80a755; /* From ColorizerFoliage.java in MCP */
|
||||||
private int colorMultPine = 0x619961; /* From ColorizerFoliage.java in MCP */
|
private int colorMultPine = 0x619961; /* From ColorizerFoliage.java in MCP */
|
||||||
private int colorMultLily = 0x208030; /* from BlockLilyPad.java in MCP */
|
private int colorMultLily = 0x208030; /* from BlockLilyPad.java in MCP */
|
||||||
private int colorMultWater = 0xFFFFFF;
|
|
||||||
|
|
||||||
private static final int IMG_GRASSCOLOR = 0;
|
private static final int IMG_GRASSCOLOR = 0;
|
||||||
private static final int IMG_FOLIAGECOLOR = 1;
|
private static final int IMG_FOLIAGECOLOR = 1;
|
||||||
@ -2103,10 +2102,6 @@ public class TexturePack {
|
|||||||
else
|
else
|
||||||
trans = BlockTransparency.OPAQUE;
|
trans = BlockTransparency.OPAQUE;
|
||||||
}
|
}
|
||||||
/* If no water lighting fix */
|
|
||||||
if((blknames.contains(DynmapBlockState.WATER_BLOCK) || blknames.contains(DynmapBlockState.FLOWING_WATER_BLOCK)) && (HDMapManager.waterlightingfix == false)) {
|
|
||||||
trans = BlockTransparency.TRANSPARENT; /* Treat water as transparent if no fix */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if(av[0].equals("colorMult")) {
|
else if(av[0].equals("colorMult")) {
|
||||||
colorMult = (int)Long.parseLong(av[1], 16);
|
colorMult = (int)Long.parseLong(av[1], 16);
|
||||||
@ -2211,10 +2206,6 @@ public class TexturePack {
|
|||||||
else
|
else
|
||||||
trans = BlockTransparency.OPAQUE;
|
trans = BlockTransparency.OPAQUE;
|
||||||
}
|
}
|
||||||
/* If no water lighting fix */
|
|
||||||
if((blknames.contains(DynmapBlockState.WATER_BLOCK) || blknames.contains(DynmapBlockState.FLOWING_WATER_BLOCK)) && (HDMapManager.waterlightingfix == false)) {
|
|
||||||
trans = BlockTransparency.TRANSPARENT; /* Treat water as transparent if no fix */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* If we have everything, build block */
|
/* If we have everything, build block */
|
||||||
@ -2336,10 +2327,6 @@ public class TexturePack {
|
|||||||
else
|
else
|
||||||
trans = BlockTransparency.OPAQUE;
|
trans = BlockTransparency.OPAQUE;
|
||||||
}
|
}
|
||||||
/* If no water lighting fix */
|
|
||||||
if((blknames.contains(DynmapBlockState.WATER_BLOCK) || blknames.contains(DynmapBlockState.FLOWING_WATER_BLOCK)) && (HDMapManager.waterlightingfix == false)) {
|
|
||||||
trans = BlockTransparency.TRANSPARENT; /* Treat water as transparent if no fix */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if(av[0].equals("colorMult")) {
|
else if(av[0].equals("colorMult")) {
|
||||||
colorMult = Integer.valueOf(av[1], 16);
|
colorMult = Integer.valueOf(av[1], 16);
|
||||||
|
@ -5,10 +5,7 @@ import java.util.BitSet;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.dynmap.hdmap.HDBlockStateTextureMap;
|
|
||||||
import org.dynmap.hdmap.TexturePack.BlockTransparency;
|
|
||||||
import org.dynmap.renderer.CustomRenderer;
|
import org.dynmap.renderer.CustomRenderer;
|
||||||
import org.dynmap.renderer.DynmapBlockState;
|
|
||||||
import org.dynmap.renderer.MapDataContext;
|
import org.dynmap.renderer.MapDataContext;
|
||||||
import org.dynmap.renderer.RenderPatch;
|
import org.dynmap.renderer.RenderPatch;
|
||||||
import org.dynmap.renderer.RenderPatchFactory;
|
import org.dynmap.renderer.RenderPatchFactory;
|
||||||
|
@ -1997,10 +1997,10 @@ texture:id=sea_pickle
|
|||||||
texture:id=conduit
|
texture:id=conduit
|
||||||
|
|
||||||
# Kelp
|
# Kelp
|
||||||
block:id=kelp,patch0-1=1000:kelp,stdrot=true,transparency=TRANSPARENT
|
block:id=kelp,patch0-1=1000:kelp,transparency=TRANSPARENT
|
||||||
|
|
||||||
# Kelp plant
|
# Kelp plant
|
||||||
block:id=kelp_plant,patch0-1=1000:kelp_plant,stdrot=true,transparency=TRANSPARENT
|
block:id=kelp_plant,patch0-1=1000:kelp_plant,transparency=TRANSPARENT
|
||||||
|
|
||||||
# Dried kelp block
|
# Dried kelp block
|
||||||
block:id=dried_kelp_block,allsides=0:dried_kelp_side,top=0:dried_kelp_top,bottom=0:dried_kelp_bottom,stdrot=true
|
block:id=dried_kelp_block,allsides=0:dried_kelp_side,top=0:dried_kelp_top,bottom=0:dried_kelp_bottom,stdrot=true
|
||||||
|
Loading…
Reference in New Issue
Block a user