This commit is contained in:
fd 2015-04-03 14:00:59 -04:00
parent a49b5bc945
commit fa9accfc88
3 changed files with 48 additions and 42 deletions

View File

@ -147,6 +147,9 @@ public class OsuHitObject {
sheight = swidth * 3 / 4; sheight = swidth * 3 / 4;
xMultiplier = swidth / 640f; xMultiplier = swidth / 640f;
yMultiplier = sheight / 480f; yMultiplier = sheight / 480f;
//xMultiplier = swidth / MAX_X;
//yMultiplier = sheight / MAX_Y;
xOffset = (int) (width - MAX_X * xMultiplier) / 2; xOffset = (int) (width - MAX_X * xMultiplier) / 2;
yOffset = (int) (height - MAX_Y * yMultiplier) / 2; yOffset = (int) (height - MAX_Y * yMultiplier) / 2;
} }

View File

@ -44,7 +44,7 @@ public class Spinner implements HitObject {
private static final int MAX_ROTATION_VELOCITIES = 50; private static final int MAX_ROTATION_VELOCITIES = 50;
/** The amount of time, in milliseconds, before another velocity is stored. */ /** The amount of time, in milliseconds, before another velocity is stored. */
private static final int DELTA_UPDATE_TIME = 4; private static final int DELTA_UPDATE_TIME = 16;
/** The amount of time, in milliseconds, to fade in the spinner. */ /** The amount of time, in milliseconds, to fade in the spinner. */
private static final int FADE_IN_TIME = 500; private static final int FADE_IN_TIME = 500;
@ -211,55 +211,57 @@ public class Spinner implements HitObject {
if (isSpinning && !(keyPressed || GameMod.RELAX.isActive())) if (isSpinning && !(keyPressed || GameMod.RELAX.isActive()))
isSpinning = false; isSpinning = false;
// spin automatically
// http://osu.ppy.sh/wiki/FAQ#Spinners
float angle;
if (GameMod.AUTO.isActive()) {
lastAngle = 0;
angle = delta * AUTO_MULTIPLIER;
isSpinning = true;
} else if (GameMod.SPUN_OUT.isActive() || GameMod.AUTOPILOT.isActive()) {
lastAngle = 0;
angle = delta * SPUN_OUT_MULTIPLIER;
isSpinning = true;
} else {
angle = (float) Math.atan2(mouseY - (height / 2), mouseX - (width / 2));
// set initial angle to current mouse position to skip first click
if (!isSpinning && (keyPressed || GameMod.RELAX.isActive())) {
lastAngle = angle;
isSpinning = true;
return false;
}
}
// make angleDiff the smallest angle change possible
// (i.e. 1/4 rotation instead of 3/4 rotation)
float angleDiff = angle - lastAngle;
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 = Utils.clamp(angleDiff / TWO_PI / delta * 1000, -8f, 8f);
deltaOverflow += delta; deltaOverflow += delta;
while (deltaOverflow >= DELTA_UPDATE_TIME) { while (deltaOverflow >= DELTA_UPDATE_TIME) {
// spin automatically
// http://osu.ppy.sh/wiki/FAQ#Spinners
float angle;
if (GameMod.AUTO.isActive()) {
lastAngle = 0;
angle = delta * AUTO_MULTIPLIER;
isSpinning = true;
} else if (GameMod.SPUN_OUT.isActive() || GameMod.AUTOPILOT.isActive()) {
lastAngle = 0;
angle = delta * SPUN_OUT_MULTIPLIER;
isSpinning = true;
} else {
angle = (float) Math.atan2(mouseY - (height / 2), mouseX - (width / 2));
// set initial angle to current mouse position to skip first click
if (!isSpinning && (keyPressed || GameMod.RELAX.isActive())) {
lastAngle = angle;
isSpinning = true;
return false;
}
}
// make angleDiff the smallest angle change possible
// (i.e. 1/4 rotation instead of 3/4 rotation)
float angleDiff = angle - lastAngle;
if (angleDiff < -Math.PI)
angleDiff += TWO_PI;
else if (angleDiff > Math.PI)
angleDiff -= TWO_PI;
System.out.println("AngleDiff "+angleDiff);
// spin caused by the cursor
float cursorVelocity = 0;
if (isSpinning)
cursorVelocity = Utils.clamp(angleDiff / TWO_PI / delta * 1000, -8f, 8f);
sumVelocity -= storedVelocities[velocityIndex]; sumVelocity -= storedVelocities[velocityIndex];
sumVelocity += cursorVelocity; sumVelocity += cursorVelocity;
storedVelocities[velocityIndex++] = cursorVelocity; storedVelocities[velocityIndex++] = cursorVelocity;
velocityIndex %= storedVelocities.length; velocityIndex %= storedVelocities.length;
deltaOverflow -= DELTA_UPDATE_TIME; deltaOverflow -= DELTA_UPDATE_TIME;
}
float rotationAngle = sumVelocity / storedVelocities.length * TWO_PI * delta / 1000; float rotationAngle = sumVelocity / storedVelocities.length * TWO_PI * delta / 1000;
rotate(rotationAngle); rotate(rotationAngle);
if (Math.abs(rotationAngle) > 0.00001f) if (Math.abs(rotationAngle) > 0.00001f)
data.changeHealth(delta * GameData.HP_DRAIN_MULTIPLIER); data.changeHealth(delta * GameData.HP_DRAIN_MULTIPLIER);
lastAngle = angle; lastAngle = angle;
}
return false; return false;
} }

View File

@ -31,6 +31,7 @@ public class ReplayImporter {
data.replayString = replayToImport.getName().substring(0, replayToImport.getName().length()-4); data.replayString = replayToImport.getName().substring(0, replayToImport.getName().length()-4);
ScoreDB.addScore(data);; ScoreDB.addScore(data);;
} else { } else {
System.out.println("Could not find beatmap for replay "+replayToImport);
//ErrorHandler.error("Could not find beatmap for replay "+replayToImport, null, false); //ErrorHandler.error("Could not find beatmap for replay "+replayToImport, null, false);
} }
} catch (IOException e) { } catch (IOException e) {