fixed timing can someone test this?

can someone help me test this?
pull/1/head
BuildTools 2019-05-28 17:02:25 +10:00
parent 395144e6ee
commit 63033b5504
94 changed files with 67 additions and 26 deletions

View File

@ -56,7 +56,7 @@ public class Example {
TexturedModel tModel = ModelLoader.loadModel("stall.obj", "stallTexture.png"); TexturedModel tModel = ModelLoader.loadModel("stall.obj", "stallTexture.png");
tModel.getTexture().setReflectivity(1f); tModel.getTexture().setReflectivity(1f);
tModel.getTexture().setShineDamper(7f); tModel.getTexture().setShineDamper(7f);
Player entity = new Player(tModel, new Vector3f(0,0,-3),0,180f,0, new Vector3f(0.2f, 0.2f, 0.2f)); Player entity = new Player(tModel, new Vector3f(0,0,-3),0,180f,0, new Vector3f(0.2f, 0.2f, 0.2f), 5000);
ThirdPersonCamera camera = new ThirdPersonCamera(new Vector3f(0,0.1f,0), entity); ThirdPersonCamera camera = new ThirdPersonCamera(new Vector3f(0,0.1f,0), entity);
masterRenderer = new MasterRenderer(camera); masterRenderer = new MasterRenderer(camera);

View File

@ -16,6 +16,7 @@ public class Player extends Entity{
private static float terrainHeight = 0; private static float terrainHeight = 0;
private double timeModifier = 1;
private float currentSpeed = 0; private float currentSpeed = 0;
private float currentTurn = 0; private float currentTurn = 0;
@ -23,21 +24,21 @@ public class Player extends Entity{
private boolean isInAir = false; private boolean isInAir = false;
public Player(TexturedModel model, Vector3f position, float rotX, float rotY, float rotZ, Vector3f scale) { public Player(TexturedModel model, Vector3f position, float rotX, float rotY, float rotZ, Vector3f scale, double timeScale) {
super(model, position, rotX, rotY, rotZ, scale); super(model, position, rotX, rotY, rotZ, scale);
this.timeModifier = timeScale;
} }
public void move(Terrain t) { public void move(Terrain t) {
checkInputs(); checkInputs();
super.increaseRotation(0, (float) ((currentTurn / 1000000) * Window.getTime()), 0); super.increaseRotation(0, (float) ((currentTurn) * Window.getTime() / timeModifier), 0);
float distance = (currentSpeed / 1000000) * Window.getFloatTime(); float distance = (float) ((currentSpeed) * (Window.getTime() / (timeModifier * 2.5)));
float dx = (float) (distance * Math.sin(Math.toRadians(super.getRotY()))); float dx = (float) (distance * Math.sin(Math.toRadians(super.getRotY())));
float dz = (float) (distance * Math.cos(Math.toRadians(super.getRotY()))); float dz = (float) (distance * Math.cos(Math.toRadians(super.getRotY())));
super.increasePosition(dx, 0, dz); super.increasePosition(dx, 0, dz);
super.increasePosition(0, (float) (upwardsSpeed * (Window.getTime() / 1000000)), 0); super.increasePosition(0, (float) (upwardsSpeed * (Window.getTime() / (timeModifier * 2))), 0);
terrainHeight = t.getHeightOfTerrain(super.getPosition().x, super.getPosition().z); terrainHeight = t.getHeightOfTerrain(super.getPosition().x, super.getPosition().z);
upwardsSpeed += GRAVITY * Window.getTime() / 1000000; upwardsSpeed += GRAVITY * Window.getTime() / (timeModifier * 2);
if(super.getPosition().y < terrainHeight) { if(super.getPosition().y < terrainHeight) {
isInAir = false; isInAir = false;
upwardsSpeed = 0; upwardsSpeed = 0;

View File

@ -4,6 +4,7 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import org.lwjgl.opengl.GL11; import org.lwjgl.opengl.GL11;
import org.lwjgl.opengl.GL13;
import org.lwjgl.opengl.GL20; import org.lwjgl.opengl.GL20;
import org.lwjgl.opengl.GL30; import org.lwjgl.opengl.GL30;
@ -42,6 +43,8 @@ public class ShadowMapEntityRenderer {
for (TexturedModel model : entities.keySet()) { for (TexturedModel model : entities.keySet()) {
RawModel rawModel = model.getRawModel(); RawModel rawModel = model.getRawModel();
bindModel(rawModel); bindModel(rawModel);
GL13.glActiveTexture(GL13.GL_TEXTURE0);
GL11.glBindTexture(GL11.GL_TEXTURE_2D, model.getTexture().getTextureID());
for (Entity entity : entities.get(model)) { for (Entity entity : entities.get(model)) {
prepareInstance(entity); prepareInstance(entity);
GL11.glDrawElements(GL11.GL_TRIANGLES, rawModel.getVertexCount(), GL11.glDrawElements(GL11.GL_TRIANGLES, rawModel.getVertexCount(),
@ -49,6 +52,7 @@ public class ShadowMapEntityRenderer {
} }
} }
GL20.glDisableVertexAttribArray(0); GL20.glDisableVertexAttribArray(0);
GL20.glDisableVertexAttribArray(1);
GL30.glBindVertexArray(0); GL30.glBindVertexArray(0);
} }
@ -63,6 +67,7 @@ public class ShadowMapEntityRenderer {
private void bindModel(RawModel rawModel) { private void bindModel(RawModel rawModel) {
GL30.glBindVertexArray(rawModel.getVaoID()); GL30.glBindVertexArray(rawModel.getVaoID());
GL20.glEnableVertexAttribArray(0); GL20.glEnableVertexAttribArray(0);
GL20.glEnableVertexAttribArray(1);
} }
/** /**

View File

@ -27,6 +27,7 @@ public class ShadowShader extends ShaderProgram {
@Override @Override
protected void bindAttributes() { protected void bindAttributes() {
super.bindAttribute(0, "in_position"); super.bindAttribute(0, "in_position");
super.bindAttribute(1, "in_textureCoords");
} }
} }

View File

@ -1,11 +1,16 @@
#version 330 #version 400
out vec4 out_colour; in vec2 textureCoords;
uniform sampler2D modelTexture;//will use this next week out vec4 out_Colour;
uniform sampler2D modelTexture;
void main(void){ void main(void){
float alpha = texture(modelTexture, textureCoords).a;
if(alpha < 0.5){
discard;
}
out_colour = vec4(1.0); out_Colour = vec4(1.0);
}
}

View File

@ -1,11 +1,16 @@
#version 150 #version 150
in vec3 in_position; in vec3 in_position;
in vec2 in_textureCoords;
out vec2 textureCoords;
uniform mat4 mvpMatrix; uniform mat4 mvpMatrix;
void main(void){ void main(void){
textureCoords = in_textureCoords;
gl_Position = mvpMatrix * vec4(in_position, 1.0); gl_Position = mvpMatrix * vec4(in_position, 1.0);
} }

View File

@ -27,7 +27,7 @@ void main(void){
float objectNearestLight = texture(shadowMap, shadowCoords.xy).r; float objectNearestLight = texture(shadowMap, shadowCoords.xy).r;
float lightFactor = 1.0; float lightFactor = 1.0;
if(shadowCoords.z > objectNearestLight){ if(shadowCoords.z > objectNearestLight){
lightFactor = 1.0 - 0.4; lightFactor = 1.0 - (shadowCoords.w * 0.4);
} }
vec4 blendMapColour = texture(blendMap, pass_textureCoords); vec4 blendMapColour = texture(blendMap, pass_textureCoords);

View File

@ -18,7 +18,9 @@ uniform vec3 lightPosition[5];
uniform mat4 toShadowMapSpace; uniform mat4 toShadowMapSpace;
const float density = 0.01; const float density = 0.01;
const float gradient = 1; const float gradient = 5;
const float shadowDistance = 150.0;
const float transitionDistance = 10.0;
void main(void){ void main(void){
@ -39,4 +41,9 @@ void main(void){
float distance = length(positionRelativeToCam.xyz); float distance = length(positionRelativeToCam.xyz);
visibility = exp(-pow((distance * density), gradient)); visibility = exp(-pow((distance * density), gradient));
visibility = clamp(visibility, 0.0, 1.0); visibility = clamp(visibility, 0.0, 1.0);
distance = distance - (shadowDistance - transitionDistance);
distance = distance / transitionDistance;
shadowCoords.w = clamp(1.0-distance, 0.0, 1.0);
} }

View File

@ -1,11 +1,16 @@
#version 330 #version 400
out vec4 out_colour; in vec2 textureCoords;
uniform sampler2D modelTexture;//will use this next week out vec4 out_Colour;
uniform sampler2D modelTexture;
void main(void){ void main(void){
float alpha = texture(modelTexture, textureCoords).a;
if(alpha < 0.5){
discard;
}
out_colour = vec4(1.0); out_Colour = vec4(1.0);
}
}

View File

@ -1,11 +1,16 @@
#version 150 #version 150
in vec3 in_position; in vec3 in_position;
in vec2 in_textureCoords;
out vec2 textureCoords;
uniform mat4 mvpMatrix; uniform mat4 mvpMatrix;
void main(void){ void main(void){
textureCoords = in_textureCoords;
gl_Position = mvpMatrix * vec4(in_position, 1.0); gl_Position = mvpMatrix * vec4(in_position, 1.0);
} }

View File

@ -27,7 +27,7 @@ void main(void){
float objectNearestLight = texture(shadowMap, shadowCoords.xy).r; float objectNearestLight = texture(shadowMap, shadowCoords.xy).r;
float lightFactor = 1.0; float lightFactor = 1.0;
if(shadowCoords.z > objectNearestLight){ if(shadowCoords.z > objectNearestLight){
lightFactor = 1.0 - 0.4; lightFactor = 1.0 - (shadowCoords.w * 0.4);
} }
vec4 blendMapColour = texture(blendMap, pass_textureCoords); vec4 blendMapColour = texture(blendMap, pass_textureCoords);

View File

@ -18,7 +18,9 @@ uniform vec3 lightPosition[5];
uniform mat4 toShadowMapSpace; uniform mat4 toShadowMapSpace;
const float density = 0.01; const float density = 0.01;
const float gradient = 1; const float gradient = 5;
const float shadowDistance = 150.0;
const float transitionDistance = 10.0;
void main(void){ void main(void){
@ -39,4 +41,9 @@ void main(void){
float distance = length(positionRelativeToCam.xyz); float distance = length(positionRelativeToCam.xyz);
visibility = exp(-pow((distance * density), gradient)); visibility = exp(-pow((distance * density), gradient));
visibility = clamp(visibility, 0.0, 1.0); visibility = clamp(visibility, 0.0, 1.0);
distance = distance - (shadowDistance - transitionDistance);
distance = distance / transitionDistance;
shadowCoords.w = clamp(1.0-distance, 0.0, 1.0);
} }

Binary file not shown.

View File

@ -1,5 +1,5 @@
#Generated by Maven #Generated by Maven
#Tue May 28 12:07:06 AEST 2019 #Tue May 28 17:00:00 AEST 2019
version=NIGHTLY version=NIGHTLY
groupId=me.hydos groupId=me.hydos
artifactId=ginger artifactId=ginger

Binary file not shown.