Fixed not losing any health at near-zero rotation angles. Signed-off-by: Jeffrey Han <itdelatrisu@gmail.com>
This commit is contained in:
parent
2c59b345b5
commit
54806303f4
|
@ -177,7 +177,6 @@ public class OsuGroupList {
|
|||
if (audioFile != null && audioFile.equals(osu.audioFilename)) {
|
||||
MusicController.reset();
|
||||
System.gc(); // TODO: why can't files be deleted without calling this?
|
||||
// TODO 2: this is broken as of 800014e
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -37,10 +37,15 @@ import org.newdawn.slick.Image;
|
|||
* Data type representing a spinner object.
|
||||
*/
|
||||
public class Spinner implements HitObject {
|
||||
|
||||
/** Container dimensions. */
|
||||
private static int width, height;
|
||||
|
||||
/** The number of rotation velocities to store. */
|
||||
private static final int MAX_ROTATION_VELOCITIES = 50;
|
||||
|
||||
/** PI constants. */
|
||||
private static final float TWO_PI = (float) (Math.PI * 2);
|
||||
|
||||
/** The associated OsuHitObject. */
|
||||
private OsuHitObject hitObject;
|
||||
|
||||
|
@ -56,17 +61,17 @@ public class Spinner implements HitObject {
|
|||
/** The total number of rotations needed to clear the spinner. */
|
||||
private float rotationsNeeded;
|
||||
|
||||
/** The sum of all the velocities in storedVelocities. */
|
||||
private float sumVelocity = 0f;
|
||||
/** The sum of all the velocities in storedVelocities. */
|
||||
private float sumVelocity = 0f;
|
||||
|
||||
/** Array of the last 50 rotation velocities. */
|
||||
private float[] storedVelocities = new float[50];
|
||||
/** Array holding the most recent rotation velocities. */
|
||||
private float[] storedVelocities = new float[MAX_ROTATION_VELOCITIES];
|
||||
|
||||
/** True if the mouse cursor is pressed. */
|
||||
private boolean isSpinning;
|
||||
|
||||
/** Current index of the stored velocities in rotations/second. */
|
||||
private int velocityIndex = 0;
|
||||
/** Current index of the stored velocities in rotations/second. */
|
||||
private int velocityIndex = 0;
|
||||
|
||||
/**
|
||||
* Initializes the Spinner data type with images and dimensions.
|
||||
|
@ -134,8 +139,9 @@ public class Spinner implements HitObject {
|
|||
data.drawSymbolNumber(extraRotations * 1000, width / 2, height * 2 / 3, 1.0f);
|
||||
}
|
||||
|
||||
int rpm = Math.abs(Math.round(sumVelocity/storedVelocities.length*60));
|
||||
//TODO: add rpm meter at bottom of spinner
|
||||
// TODO: add rpm meter at bottom of spinner
|
||||
// TODO 2: make this work for Auto/Spun-Out mods
|
||||
// int rpm = Math.abs(Math.round(sumVelocity / storedVelocities.length * 60));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -190,9 +196,8 @@ public class Spinner implements HitObject {
|
|||
}
|
||||
|
||||
// game button is released
|
||||
if (isSpinning && !Utils.isGameKeyPressed()) {
|
||||
if (isSpinning && !Utils.isGameKeyPressed())
|
||||
isSpinning = false;
|
||||
}
|
||||
|
||||
float angle = (float) Math.atan2(mouseY - (height / 2), mouseX - (width / 2));
|
||||
|
||||
|
@ -207,36 +212,37 @@ public class Spinner implements HitObject {
|
|||
|
||||
// make angleDiff the smallest angle change possible
|
||||
// (i.e. 1/4 rotation instead of 3/4 rotation)
|
||||
if (angleDiff < -Math.PI) {
|
||||
angleDiff = (float) (angleDiff + Math.PI*2);
|
||||
} else if (angleDiff > Math.PI) {
|
||||
angleDiff = (float) (angleDiff - Math.PI*2);
|
||||
}
|
||||
if (angleDiff < -Math.PI)
|
||||
angleDiff += TWO_PI;
|
||||
else if (angleDiff > Math.PI)
|
||||
angleDiff -= TWO_PI;
|
||||
|
||||
// spin caused by the cursor
|
||||
float cursorVelocity = 0;
|
||||
if (isSpinning)
|
||||
cursorVelocity = Math.min((float)(angleDiff / (Math.PI*2) / delta * 1000), 8f);
|
||||
cursorVelocity = Math.min(angleDiff / TWO_PI / delta * 1000, 8f);
|
||||
|
||||
sumVelocity -= storedVelocities[velocityIndex];
|
||||
sumVelocity += cursorVelocity;
|
||||
storedVelocities[velocityIndex++] = cursorVelocity;
|
||||
velocityIndex %= storedVelocities.length;
|
||||
sumVelocity -= storedVelocities[velocityIndex];
|
||||
sumVelocity += cursorVelocity;
|
||||
storedVelocities[velocityIndex++] = cursorVelocity;
|
||||
velocityIndex %= storedVelocities.length;
|
||||
|
||||
data.changeHealth(delta * GameData.HP_DRAIN_MULTIPLIER);
|
||||
rotate(sumVelocity / storedVelocities.length * (float)Math.PI*2 * delta / 1000);
|
||||
float rotationAngle = sumVelocity / storedVelocities.length * TWO_PI * delta / 1000;
|
||||
rotate(rotationAngle);
|
||||
if (rotationAngle > 0.00001f)
|
||||
data.changeHealth(delta * GameData.HP_DRAIN_MULTIPLIER);
|
||||
|
||||
lastAngle = angle;
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Rotates the spinner by a number of radians.
|
||||
* Rotates the spinner by an angle.
|
||||
* @param angle the angle to rotate (in radians)
|
||||
*/
|
||||
private void rotate(float angle) {
|
||||
angle = Math.abs(angle);
|
||||
float newRotations = rotations + (angle / (float) (2 * Math.PI));
|
||||
float newRotations = rotations + (angle / TWO_PI);
|
||||
|
||||
// added one whole rotation...
|
||||
if (Math.floor(newRotations) > rotations) {
|
||||
|
|
|
@ -393,15 +393,17 @@ public class OpenALStreamPlayer {
|
|||
lastUpdateTime = System.currentTimeMillis() - offsetTime;
|
||||
}
|
||||
|
||||
/**
|
||||
* Closes the stream.
|
||||
*/
|
||||
public void close() {
|
||||
if(audio != null){
|
||||
if (audio != null) {
|
||||
try {
|
||||
audio.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -916,7 +916,7 @@ public class SoundStore {
|
|||
return;
|
||||
}
|
||||
|
||||
if(this.stream != null){
|
||||
if (this.stream != null) {
|
||||
this.stream.close();
|
||||
}
|
||||
currentMusic = sources.get(0);
|
||||
|
|
Loading…
Reference in New Issue
Block a user