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,6 +211,8 @@ public class Spinner implements HitObject {
if (isSpinning && !(keyPressed || GameMod.RELAX.isActive())) if (isSpinning && !(keyPressed || GameMod.RELAX.isActive()))
isSpinning = false; isSpinning = false;
deltaOverflow += delta;
while (deltaOverflow >= DELTA_UPDATE_TIME) {
// spin automatically // spin automatically
// http://osu.ppy.sh/wiki/FAQ#Spinners // http://osu.ppy.sh/wiki/FAQ#Spinners
float angle; float angle;
@ -241,25 +243,25 @@ public class Spinner implements HitObject {
else if (angleDiff > Math.PI) else if (angleDiff > Math.PI)
angleDiff -= TWO_PI; angleDiff -= TWO_PI;
System.out.println("AngleDiff "+angleDiff);
// spin caused by the cursor // spin caused by the cursor
float cursorVelocity = 0; float cursorVelocity = 0;
if (isSpinning) if (isSpinning)
cursorVelocity = Utils.clamp(angleDiff / TWO_PI / delta * 1000, -8f, 8f); cursorVelocity = Utils.clamp(angleDiff / TWO_PI / delta * 1000, -8f, 8f);
deltaOverflow += delta;
while (deltaOverflow >= DELTA_UPDATE_TIME) {
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) {