Vector3 function additions
This commit is contained in:
parent
7016ee0b76
commit
bcfcfdfb03
2 changed files with 101 additions and 2 deletions
|
@ -127,4 +127,72 @@ public class Vector3
|
||||||
{
|
{
|
||||||
return new Vector3(this.x + offset.x, this.y + offset.y, this.z + offset.z);
|
return new Vector3(this.x + offset.x, this.y + offset.y, this.z + offset.z);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public Vector3 normalize()
|
||||||
|
{
|
||||||
|
double d = getMagnitude();
|
||||||
|
|
||||||
|
if (d != 0)
|
||||||
|
{
|
||||||
|
scale(1 / d);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Rotate by a this vector around an axis.
|
||||||
|
*
|
||||||
|
* @return The new Vector3 rotation.
|
||||||
|
*/
|
||||||
|
public Vector3 rotate(float angle, Vector3 axis)
|
||||||
|
{
|
||||||
|
return translateMatrix(getRotationMatrix(angle, axis), this.clone());
|
||||||
|
}
|
||||||
|
|
||||||
|
public double[] getRotationMatrix(float angle)
|
||||||
|
{
|
||||||
|
double[] matrix = new double[16];
|
||||||
|
Vector3 axis = this.clone().normalize();
|
||||||
|
double x = axis.x;
|
||||||
|
double y = axis.y;
|
||||||
|
double z = axis.z;
|
||||||
|
angle *= 0.0174532925D;
|
||||||
|
float cos = (float) Math.cos(angle);
|
||||||
|
float ocos = 1.0F - cos;
|
||||||
|
float sin = (float) Math.sin(angle);
|
||||||
|
matrix[0] = (x * x * ocos + cos);
|
||||||
|
matrix[1] = (y * x * ocos + z * sin);
|
||||||
|
matrix[2] = (x * z * ocos - y * sin);
|
||||||
|
matrix[4] = (x * y * ocos - z * sin);
|
||||||
|
matrix[5] = (y * y * ocos + cos);
|
||||||
|
matrix[6] = (y * z * ocos + x * sin);
|
||||||
|
matrix[8] = (x * z * ocos + y * sin);
|
||||||
|
matrix[9] = (y * z * ocos - x * sin);
|
||||||
|
matrix[10] = (z * z * ocos + cos);
|
||||||
|
matrix[15] = 1.0F;
|
||||||
|
return matrix;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Vector3 translateMatrix(double[] matrix, Vector3 translation)
|
||||||
|
{
|
||||||
|
double x = translation.x * matrix[0] + translation.y * matrix[1] + translation.z * matrix[2] + matrix[3];
|
||||||
|
double y = translation.x * matrix[4] + translation.y * matrix[5] + translation.z * matrix[6] + matrix[7];
|
||||||
|
double z = translation.x * matrix[8] + translation.y * matrix[9] + translation.z * matrix[10] + matrix[11];
|
||||||
|
translation.x = x;
|
||||||
|
translation.y = y;
|
||||||
|
translation.z = z;
|
||||||
|
return translation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static double[] getRotationMatrix(float angle, Vector3 axis)
|
||||||
|
{
|
||||||
|
return axis.getRotationMatrix(angle);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Vector3 clone()
|
||||||
|
{
|
||||||
|
return new Vector3(this.x, this.y, this.z);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,7 @@ public class FXElectricBolt extends EntityFX
|
||||||
public static final ResourceLocation PARTICLE_RESOURCE = new ResourceLocation("textures/particle/particles.png");
|
public static final ResourceLocation PARTICLE_RESOURCE = new ResourceLocation("textures/particle/particles.png");
|
||||||
|
|
||||||
private final float boltWidth = 0.05f;
|
private final float boltWidth = 0.05f;
|
||||||
|
private final float complexity = 2;
|
||||||
private BoltPoint start;
|
private BoltPoint start;
|
||||||
private BoltPoint target;
|
private BoltPoint target;
|
||||||
private double boltLength;
|
private double boltLength;
|
||||||
|
@ -48,7 +49,8 @@ public class FXElectricBolt extends EntityFX
|
||||||
this.target = new BoltPoint(target);
|
this.target = new BoltPoint(target);
|
||||||
|
|
||||||
this.boltLength = start.distance(target);
|
this.boltLength = start.distance(target);
|
||||||
this.segments.add(new BoltSegment(this.start, this.target));
|
|
||||||
|
this.setUp();
|
||||||
}
|
}
|
||||||
|
|
||||||
public FXElectricBolt setColor(float r, float g, float b)
|
public FXElectricBolt setColor(float r, float g, float b)
|
||||||
|
@ -59,11 +61,35 @@ public class FXElectricBolt extends EntityFX
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void calculate()
|
public void setUp()
|
||||||
{
|
{
|
||||||
|
this.segments.add(new BoltSegment(this.start, this.target));
|
||||||
|
double offsetRatio = this.boltLength * this.complexity;
|
||||||
|
this.split(offsetRatio / 8, 0.1f, 45);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void split(double offset, float length, float angle)
|
||||||
|
{
|
||||||
|
int splitAmount = 2;
|
||||||
|
Set<BoltSegment> oldSegments = this.segments;
|
||||||
|
this.segments.clear();
|
||||||
|
|
||||||
|
for (BoltSegment segment : oldSegments)
|
||||||
|
{
|
||||||
|
Vector3 subSegment = segment.getDifference().scale(1 / splitAmount);
|
||||||
|
|
||||||
|
BoltPoint[] newPoints = new BoltPoint[splitAmount + 1];
|
||||||
|
newPoints[0] = segment.start;
|
||||||
|
newPoints[splitAmount + 1] = segment.end;
|
||||||
|
|
||||||
|
for (int i = 1; i < splitAmount; i++)
|
||||||
|
{
|
||||||
|
Vector3 newOffset = segment.getDifference().getPerpendicular();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onUpdate()
|
public void onUpdate()
|
||||||
{
|
{
|
||||||
|
@ -165,5 +191,10 @@ public class FXElectricBolt extends EntityFX
|
||||||
this.start = start;
|
this.start = start;
|
||||||
this.end = end;
|
this.end = end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Vector3 getDifference()
|
||||||
|
{
|
||||||
|
return this.end.difference(this.start);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue