All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.malisis.core.renderer.RenderParameters Maven / Gradle / Ivy

Go to download

MalisisCore is a framework dedicated to simplify many processes required during a mod development.

There is a newer version: 1.12.2-6.4.0
Show newest version
/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2014 Ordinastie
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

package net.malisis.core.renderer;

import java.util.LinkedList;
import java.util.List;

import net.malisis.core.renderer.animation.transformation.ITransformable;
import net.malisis.core.renderer.icon.IIconProvider;
import net.malisis.core.renderer.icon.MalisisIcon;
import net.minecraft.util.AxisAlignedBB;
import net.minecraft.util.EnumFacing;

/**
 * @author Ordinastie
 *
 */
public class RenderParameters implements ITransformable.Color, ITransformable.Alpha, ITransformable.Brightness, Cloneable
{
	/** List of parameters inside this {@link RenderParameters}. */
	protected List listParams;

	/** Defines whether to render all faces even if shoudSideBeRendered is false */
	public Parameter renderAllFaces = new Parameter<>(false);

	/** Defines whether to use the block bounding box instead of renderBounds (Block Level) */
	public Parameter useBlockBounds = new Parameter<>(true);

	/** Defines the rendering bounds to limit the vertex inside (Block Level) */
	public Parameter renderBounds = new Parameter<>(null);

	/** Define whether a custom texture for drawing. It disable default icon behavior. A ResourceLocation need to be bound. */
	public Parameter useCustomTexture = new Parameter<>(false);

	/** Define whether to apply texture UV for the shape (Block level) */
	public Parameter applyTexture = new Parameter<>(true);

	/** Defines an {@link IIconProvider} to be used to get the icon for the faces. (Block Level) */
	public Parameter iconProvider = new Parameter<>(null);

	/** Defines a {@link MalisisIcon} to be used for the rendering. */
	public Parameter icon = new Parameter<>(null);

	/** Defines whether to use block.getIcon(world, x, y, z, side) instead of block.getIcon(side, metadata) to get the IIcon */
	public Parameter useWorldSensitiveIcon = new Parameter(true);

	/** Defines whether to use a texture (will call addVertexWithUV instead of addVertex) */
	public Parameter useTexture = new Parameter<>(true);

	/** Defines whether to calculate interpolated textures coordinates depending on block bounds (Block Level) */
	public Parameter interpolateUV = new Parameter<>(true);

	/** Defines whether to calculate ambient occlusion color or not (Block Level) */
	public Parameter calculateAOColor = new Parameter<>(true);

	/** Defines whether to calculate brightness or not (Block Level) */
	public Parameter calculateBrightness = new Parameter<>(true);

	/** Define whether to override each vertex color. If false, FaceParams.colorMultiplier will be used instead (Block Level) */
	public Parameter usePerVertexColor = new Parameter<>(false);

	/** Define whether to override each vertex alpha. If false, FaceParams.alpha will be used instead (Block Level) */
	public Parameter usePerVertexAlpha = new Parameter<>(false);

	/** Define whether to override each vertex brightness. If false, FaceParams.brightness will be used instead (Block Level) */
	public Parameter usePerVertexBrightness = new Parameter<>(false);

	/** Defines whether to use the block mixBlockBrightness (if false, RenderParameters.brightness will be used) (Block Level) */
	public Parameter useEnvironmentBrightness = new Parameter<>(true);

	/** Defines whether to use the defined normals */
	public Parameter useNormals = new Parameter<>(false);

	/**
	 * Defines the color to apply to the face (useful for grass and leaves) usePerVertexColor must be false (Block Level).
* Overrides the Block.colorMultiplier() and Block.getRenderColor() */ public Parameter colorMultiplier = new Parameter<>(null); /** * Defines the color factor for the face (Block Level). Used for shading the faces depending on their orientation :
* - NORTH/SOUTH : 0.8
* - EAST/WEST : 0.6
* - TOP : 1
* - BOTTOM : 0.5
*/ public Parameter colorFactor = new Parameter<>(1.0F); /** Defines brightness of the face (only used if useBlockBrightness = false) (Block Level) */ public Parameter brightness = new Parameter<>(15728640); // 983055 - 15728640 /** Defines alpha transparency for the face (GL11.GL_BLEND needs to be set before). usePerVertexAlpha must be false (Block Level) */ public Parameter alpha = new Parameter<>(255); /** Defines the general direction of a face. Used for normals, and offset for AO and brightness calculation (Face Level) */ public Parameter direction = new Parameter<>(null); /** Defines which direction will be used to get the block icon. If ForgeDirection.UNKNOWN, no texture will be used (Face Level) */ public Parameter textureSide = new Parameter<>(null); /** Defines which block to take into account for AO calculation (Face Level) */ public Parameter aoMatrix = new Parameter<>(null); /** Defines whether to flip the texture on the U coordinates (Face Level) */ public Parameter flipU = new Parameter<>(false); /** Defines whether to flip the texture on the U coordinates (Face Level) */ public Parameter flipV = new Parameter<>(false); /** * Instantiates a new {@link RenderParameters}. */ public RenderParameters() { buildList(); } /** * Instantiates a new {@link RenderParameters} with the {@link Parameter} values inside params. * * @param params the params */ public RenderParameters(RenderParameters params) { this(); merge(params); } /** * Builds the list of {@link Parameter} in this {@link RenderParameters}. */ protected void buildList() { listParams = new LinkedList<>(); listParams.add(renderAllFaces); listParams.add(useBlockBounds); listParams.add(renderBounds); listParams.add(useCustomTexture); listParams.add(applyTexture); listParams.add(icon); listParams.add(iconProvider); listParams.add(useWorldSensitiveIcon); listParams.add(useTexture); listParams.add(interpolateUV); listParams.add(calculateAOColor); listParams.add(calculateBrightness); listParams.add(usePerVertexColor); listParams.add(usePerVertexAlpha); listParams.add(usePerVertexBrightness); listParams.add(useEnvironmentBrightness); listParams.add(useNormals); listParams.add(colorMultiplier); listParams.add(colorFactor); listParams.add(brightness); listParams.add(alpha); listParams.add(direction); listParams.add(textureSide); listParams.add(aoMatrix); listParams.add(flipU); listParams.add(flipV); } /** * Gets the {@link Parameter} at index. * * @param index the index * @return the parameter */ private Parameter getParameter(int index) { if (index < 0 || index >= listParams.size()) return null; return listParams.get(index); } /** * Resets all {@link Parameter parameters} to their default value. */ public void reset() { for (Parameter param : listParams) param.reset(); } /** * Merges all the values of params inside this {@link RenderParameters} {@link Parameter parameters}. * * @param params the params */ public void merge(RenderParameters params) { if (params == null) return; for (int i = 0; i < listParams.size(); i++) getParameter(i).merge(params.getParameter(i)); } @Override public void setAlpha(int alpha) { this.alpha.set(alpha); } @Override public void setColor(int color) { this.colorMultiplier.set(color); } @Override public void setBrightness(int brightness) { this.brightness.set(brightness); } /** * Merges rp1 and rp2 into a new {@link RenderParameters}. * * @param rp1 the rp1 * @param rp2 the rp2 * @return the render parameters */ public static RenderParameters merge(RenderParameters rp1, RenderParameters rp2) { if (rp1 == null) return rp2 == null ? new RenderParameters() : rp2.clone(); RenderParameters rp = rp1.clone(); rp.merge(rp2); return rp; } @Override public RenderParameters clone() { try { RenderParameters rp = (RenderParameters) super.clone(); rp.renderAllFaces = renderAllFaces.clone(); rp.useBlockBounds = useBlockBounds.clone(); rp.renderBounds = renderBounds.clone(); rp.useCustomTexture = useCustomTexture.clone(); rp.applyTexture = applyTexture.clone(); rp.iconProvider = iconProvider.clone(); rp.icon = icon.clone(); rp.useWorldSensitiveIcon = useWorldSensitiveIcon.clone(); rp.useTexture = useTexture.clone(); rp.interpolateUV = interpolateUV.clone(); rp.calculateAOColor = calculateAOColor.clone(); rp.calculateBrightness = calculateBrightness.clone(); rp.usePerVertexColor = usePerVertexColor.clone(); rp.usePerVertexAlpha = usePerVertexAlpha.clone(); rp.usePerVertexBrightness = usePerVertexBrightness.clone(); rp.useEnvironmentBrightness = useEnvironmentBrightness.clone(); rp.useNormals = useNormals.clone(); rp.colorMultiplier = colorMultiplier.clone(); rp.colorFactor = colorFactor.clone(); rp.brightness = brightness.clone(); rp.alpha = alpha.clone(); rp.direction = direction.clone(); rp.textureSide = textureSide.clone(); rp.aoMatrix = aoMatrix.clone(); rp.flipU = flipU.clone(); rp.flipV = flipV.clone(); rp.buildList(); return rp; } catch (CloneNotSupportedException e) { e.printStackTrace(); } return null; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy