2016-06-23 03:49:47 +00:00
|
|
|
/*
|
|
|
|
* Minecraft Forge
|
2020-07-02 17:49:11 +00:00
|
|
|
* Copyright (c) 2016-2020.
|
2016-06-23 03:49:47 +00:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation version 2.1
|
|
|
|
* of the License.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
2014-06-04 20:32:55 +00:00
|
|
|
package net.minecraftforge.client.event;
|
|
|
|
|
2019-12-11 02:27:07 +00:00
|
|
|
import net.minecraft.client.Minecraft;
|
2019-05-23 23:02:15 +00:00
|
|
|
import net.minecraft.client.renderer.ActiveRenderInfo;
|
2019-12-11 02:27:07 +00:00
|
|
|
import net.minecraft.client.renderer.FogRenderer.FogType;
|
|
|
|
import net.minecraft.client.renderer.GameRenderer;
|
2018-06-11 01:12:46 +00:00
|
|
|
import net.minecraftforge.eventbus.api.Cancelable;
|
2018-09-22 10:40:22 +00:00
|
|
|
|
2014-06-04 20:32:55 +00:00
|
|
|
/**
|
2019-02-14 23:08:53 +00:00
|
|
|
* Event that hooks into GameRenderer, allowing any feature to customize visual attributes
|
2016-02-16 13:52:41 +00:00
|
|
|
* the player sees.
|
2014-06-04 20:32:55 +00:00
|
|
|
*/
|
2018-06-11 01:12:46 +00:00
|
|
|
public abstract class EntityViewRenderEvent extends net.minecraftforge.eventbus.api.Event
|
2014-06-04 20:32:55 +00:00
|
|
|
{
|
2019-02-14 23:08:53 +00:00
|
|
|
private final GameRenderer renderer;
|
2019-05-23 23:02:15 +00:00
|
|
|
private final ActiveRenderInfo info;
|
2016-03-01 17:52:19 +00:00
|
|
|
private final double renderPartialTicks;
|
2014-06-04 20:32:55 +00:00
|
|
|
|
2019-05-23 23:02:15 +00:00
|
|
|
public EntityViewRenderEvent(GameRenderer renderer, ActiveRenderInfo info, double renderPartialTicks)
|
2014-06-04 20:32:55 +00:00
|
|
|
{
|
|
|
|
this.renderer = renderer;
|
2019-05-23 23:02:15 +00:00
|
|
|
this.info = info;
|
2014-06-04 20:32:55 +00:00
|
|
|
this.renderPartialTicks = renderPartialTicks;
|
|
|
|
}
|
|
|
|
|
2019-02-14 23:08:53 +00:00
|
|
|
public GameRenderer getRenderer()
|
2016-03-01 17:52:19 +00:00
|
|
|
{
|
2019-05-23 23:02:15 +00:00
|
|
|
return renderer;
|
2016-03-01 17:52:19 +00:00
|
|
|
}
|
|
|
|
|
2019-05-23 23:02:15 +00:00
|
|
|
public ActiveRenderInfo getInfo()
|
2018-12-21 22:45:35 +00:00
|
|
|
{
|
2019-05-23 23:02:15 +00:00
|
|
|
return info;
|
2018-12-21 22:45:35 +00:00
|
|
|
}
|
2016-03-01 17:52:19 +00:00
|
|
|
|
|
|
|
public double getRenderPartialTicks()
|
|
|
|
{
|
|
|
|
return renderPartialTicks;
|
|
|
|
}
|
2019-05-23 23:02:15 +00:00
|
|
|
|
2018-12-21 22:45:35 +00:00
|
|
|
private static class FogEvent extends EntityViewRenderEvent
|
|
|
|
{
|
2019-12-11 02:27:07 +00:00
|
|
|
private final FogType type;
|
|
|
|
protected FogEvent(FogType type, ActiveRenderInfo info, double renderPartialTicks)
|
2018-12-21 22:45:35 +00:00
|
|
|
{
|
2019-12-11 02:27:07 +00:00
|
|
|
super(Minecraft.getInstance().gameRenderer, info, renderPartialTicks);
|
|
|
|
this.type = type;
|
2018-12-21 22:45:35 +00:00
|
|
|
}
|
2019-05-23 23:02:15 +00:00
|
|
|
|
2019-12-11 02:27:07 +00:00
|
|
|
public FogType getType() { return type; }
|
2018-12-21 22:45:35 +00:00
|
|
|
}
|
2016-03-01 17:52:19 +00:00
|
|
|
|
2019-05-23 23:02:15 +00:00
|
|
|
/**
|
2014-06-04 20:32:55 +00:00
|
|
|
* Event that allows any feature to customize the fog density the player sees.
|
|
|
|
* NOTE: In order to make this event have an effect, you must cancel the event
|
|
|
|
*/
|
|
|
|
@Cancelable
|
2018-12-21 22:45:35 +00:00
|
|
|
public static class FogDensity extends FogEvent
|
2014-06-04 20:32:55 +00:00
|
|
|
{
|
2016-03-24 08:44:52 +00:00
|
|
|
private float density;
|
2014-06-04 20:32:55 +00:00
|
|
|
|
2019-12-11 02:27:07 +00:00
|
|
|
public FogDensity(FogType type, ActiveRenderInfo info, float partialTicks, float density)
|
2014-06-04 20:32:55 +00:00
|
|
|
{
|
2019-12-11 02:27:07 +00:00
|
|
|
super(type, info, partialTicks);
|
2016-03-24 08:44:52 +00:00
|
|
|
this.setDensity(density);
|
|
|
|
}
|
|
|
|
|
|
|
|
public float getDensity()
|
|
|
|
{
|
|
|
|
return density;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setDensity(float density)
|
|
|
|
{
|
2014-06-04 20:32:55 +00:00
|
|
|
this.density = density;
|
|
|
|
}
|
|
|
|
}
|
Initial update to 1.8, Super beta. Most rendering related hooks are out due to major changes in 1.8.
Some notes:
Almost all int x, int y, int z parameters have been changed to BlockPos class
ForgeDirection has been removed, replaced by net.minecraft.util.EnumFacing.
All FML classes have moved from packet cpw.mods.fml to net.minecraftforge.fml
Fluid Rendering has been disabled for the time being, to be re-evaulated and a test mod created for it.
Minecraft now uses a Model based system for rendering blocks and Items. The intention is to expand the model format to better suit modder's needed once it is evaulated.
As such, The model loaders from Forge have been removed, to be replaced by expanding vanilla's model format.
Metadata has been extracted out in Minecraft to IBlockState, which holds a list of properties instead of magic number metadata. DO NOT listen to the fearmongering, you can do EVERYTHING with block states you could previously with metadata.
Stencil Bits are disabled entirely by for the main Display, Modders must enable and recreate the FrameBuffer if they wish to use Stencil Bits.
2014-11-26 03:56:35 +00:00
|
|
|
|
2014-07-27 05:20:42 +00:00
|
|
|
/**
|
|
|
|
* Event that allows any feature to customize the rendering of fog.
|
|
|
|
*/
|
|
|
|
@HasResult
|
2018-12-21 22:45:35 +00:00
|
|
|
public static class RenderFogEvent extends FogEvent
|
2014-07-27 05:20:42 +00:00
|
|
|
{
|
2016-03-24 08:44:52 +00:00
|
|
|
private final float farPlaneDistance;
|
Initial update to 1.8, Super beta. Most rendering related hooks are out due to major changes in 1.8.
Some notes:
Almost all int x, int y, int z parameters have been changed to BlockPos class
ForgeDirection has been removed, replaced by net.minecraft.util.EnumFacing.
All FML classes have moved from packet cpw.mods.fml to net.minecraftforge.fml
Fluid Rendering has been disabled for the time being, to be re-evaulated and a test mod created for it.
Minecraft now uses a Model based system for rendering blocks and Items. The intention is to expand the model format to better suit modder's needed once it is evaulated.
As such, The model loaders from Forge have been removed, to be replaced by expanding vanilla's model format.
Metadata has been extracted out in Minecraft to IBlockState, which holds a list of properties instead of magic number metadata. DO NOT listen to the fearmongering, you can do EVERYTHING with block states you could previously with metadata.
Stencil Bits are disabled entirely by for the main Display, Modders must enable and recreate the FrameBuffer if they wish to use Stencil Bits.
2014-11-26 03:56:35 +00:00
|
|
|
|
2019-12-11 02:27:07 +00:00
|
|
|
public RenderFogEvent(FogType type, ActiveRenderInfo info, float partialTicks, float distance)
|
2016-03-24 08:44:52 +00:00
|
|
|
{
|
2019-12-11 02:27:07 +00:00
|
|
|
super(type, info, partialTicks);
|
|
|
|
this.farPlaneDistance = distance;
|
2016-03-24 08:44:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public float getFarPlaneDistance()
|
|
|
|
{
|
|
|
|
return farPlaneDistance;
|
|
|
|
}
|
2014-07-27 05:20:42 +00:00
|
|
|
}
|
2014-06-04 20:32:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Event that allows any feature to customize the color of fog the player sees.
|
|
|
|
* NOTE: Any change made to one of the color variables will affect the result seen in-game.
|
|
|
|
*/
|
2019-12-11 02:27:07 +00:00
|
|
|
public static class FogColors extends EntityViewRenderEvent
|
2019-05-23 23:02:15 +00:00
|
|
|
{
|
2016-03-24 08:44:52 +00:00
|
|
|
private float red;
|
|
|
|
private float green;
|
|
|
|
private float blue;
|
2014-06-04 20:32:55 +00:00
|
|
|
|
2019-12-11 02:27:07 +00:00
|
|
|
public FogColors(ActiveRenderInfo info, float partialTicks, float red, float green, float blue)
|
2014-06-04 20:32:55 +00:00
|
|
|
{
|
2019-12-11 02:27:07 +00:00
|
|
|
super(Minecraft.getInstance().gameRenderer, info, partialTicks);
|
2016-03-24 08:44:52 +00:00
|
|
|
this.setRed(red);
|
|
|
|
this.setGreen(green);
|
|
|
|
this.setBlue(blue);
|
2014-06-04 20:32:55 +00:00
|
|
|
}
|
2016-03-24 08:44:52 +00:00
|
|
|
|
|
|
|
public float getRed() { return red; }
|
|
|
|
public void setRed(float red) { this.red = red; }
|
|
|
|
public float getGreen() { return green; }
|
|
|
|
public void setGreen(float green) { this.green = green; }
|
|
|
|
public float getBlue() { return blue; }
|
|
|
|
public void setBlue(float blue) { this.blue = blue; }
|
2014-06-04 20:32:55 +00:00
|
|
|
}
|
2019-05-23 23:02:15 +00:00
|
|
|
|
|
|
|
/**
|
2015-05-08 14:31:23 +00:00
|
|
|
* Event that allows mods to alter the angles of the player's camera. Mainly useful for applying roll.
|
|
|
|
*/
|
|
|
|
public static class CameraSetup extends EntityViewRenderEvent
|
|
|
|
{
|
2016-03-24 08:44:52 +00:00
|
|
|
private float yaw;
|
|
|
|
private float pitch;
|
|
|
|
private float roll;
|
2015-05-08 14:31:23 +00:00
|
|
|
|
2019-05-23 23:02:15 +00:00
|
|
|
public CameraSetup(GameRenderer renderer, ActiveRenderInfo info, double renderPartialTicks, float yaw, float pitch, float roll)
|
2015-05-08 14:31:23 +00:00
|
|
|
{
|
2019-05-23 23:02:15 +00:00
|
|
|
super(renderer, info, renderPartialTicks);
|
2016-03-24 08:44:52 +00:00
|
|
|
this.setYaw(yaw);
|
|
|
|
this.setPitch(pitch);
|
|
|
|
this.setRoll(roll);
|
2015-05-08 14:31:23 +00:00
|
|
|
}
|
2016-03-24 08:44:52 +00:00
|
|
|
|
|
|
|
public float getYaw() { return yaw; }
|
|
|
|
public void setYaw(float yaw) { this.yaw = yaw; }
|
|
|
|
public float getPitch() { return pitch; }
|
|
|
|
public void setPitch(float pitch) { this.pitch = pitch; }
|
|
|
|
public float getRoll() { return roll; }
|
|
|
|
public void setRoll(float roll) { this.roll = roll; }
|
2015-05-08 14:31:23 +00:00
|
|
|
}
|
2019-05-23 23:02:15 +00:00
|
|
|
|
2016-02-16 13:52:41 +00:00
|
|
|
/**
|
|
|
|
* Event that allows mods to alter the raw FOV itself.
|
|
|
|
* This directly affects to the FOV without being modified.
|
|
|
|
* */
|
|
|
|
public static class FOVModifier extends EntityViewRenderEvent
|
|
|
|
{
|
2018-12-21 22:45:35 +00:00
|
|
|
private double fov;
|
2019-05-23 23:02:15 +00:00
|
|
|
|
|
|
|
public FOVModifier(GameRenderer renderer, ActiveRenderInfo info, double renderPartialTicks, double fov) {
|
|
|
|
super(renderer, info, renderPartialTicks);
|
2016-02-16 13:52:41 +00:00
|
|
|
this.setFOV(fov);
|
|
|
|
}
|
|
|
|
|
2018-12-21 22:45:35 +00:00
|
|
|
public double getFOV() {
|
2016-02-16 13:52:41 +00:00
|
|
|
return fov;
|
|
|
|
}
|
|
|
|
|
2018-12-21 22:45:35 +00:00
|
|
|
public void setFOV(double fov) {
|
2016-02-16 13:52:41 +00:00
|
|
|
this.fov = fov;
|
|
|
|
}
|
|
|
|
}
|
2014-06-04 20:32:55 +00:00
|
|
|
}
|