private void soundBump() { // we check if the sound should be replayed if (bumpWallPlayed || bumpTopPlayed) { // if the x position has really changed (3 pixels) and the player is // no more facing to wall (useful to avoid problem with pushing // crates), the bump can again be played if (((Globals.player.getX() - bumpWallX) > 3 || (Globals.player.getX() - bumpWallX) < -3) && !Globals.player.isTotallyFacingToWall()) { bumpWallPlayed = false; } if (((Globals.player.getY() - bumpTopY) > 3 || (Globals.player.getY() - bumpTopY) < -3 || (Globals.player.getX() - bumpTopX) > 3 || (Globals.player.getX() - bumpTopX) < -3)) { bumpTopPlayed = false; } } // If the player is facing to a wall if (Globals.player.isFacingToWall()) { // to have the sound from the right or the left depending on the // position of the wall and the player int decal = 0; if (Globals.player.facingRight()) decal = 1; else decal = -1; // If the sound should be replayed, it will if (!bumpWallPlayed) { soundBump.playAt( 1.5f, 5f, Globals.player.getX() - Globals.player.getWidth() / 2 + decal, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); bumpWallPlayed = true; bumpWallX = Globals.player.getX(); } else { soundBump.setSourcePosition( Globals.player.getX() - Globals.player.getWidth() / 2 + decal, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); } } // If the player is knocking his head somewhere when jumping else if (Globals.player.isTopCollided() && Globals.player.jumping()) { // If the sound should be replayed, it will if (!bumpTopPlayed) { soundBump.playAt( 1.5f, 1f, Globals.player.getX() - Globals.player.getWidth() / 2, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); bumpTopPlayed = true; bumpTopX = Globals.player.getX(); bumpTopY = Globals.player.getY(); } } }
@Override public void render(GameContainer gc, StateBasedGame sbg, Graphics g) throws SlickException { if (map != null) super.render(gc, sbg, g); font.drawString(4 * gc.getWidth() / 5, 30, "" + Globals.score); Utils.drawCenteredString( g, "Cursors - Move Ctrl - Jump B - Show Bounds R - Restart", gc.getWidth(), gc.getHeight() - 20, Color.black); /*for (int i = 0; i < map.getWorld().getBodies().size(); i++) { if (map.getEntityByBody(map.getWorld().getBodies().get(i)) instanceof HomerIA) { sound.setSourcePosition((map.getEntityByBody( map.getWorld().getBodies().get(i)).getX() - map .getEntityByBody(map.getWorld().getBodies().get(i)) .getWidth() / 2), (map.getEntityByBody( map.getWorld().getBodies().get(i)).getY() - map .getEntityByBody(map.getWorld().getBodies().get(i)) .getHeight() / 2), 0f); } }*/ // We put the openAl listener's position and velocity AlUtils.setAlListenerPosition( Globals.player.getX() - Globals.player.getWidth() / 2, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); AlUtils.setAlListenerVelocity(Globals.player.getVelX() * 5, -Globals.player.getVelY(), 0.0f); // sound.setSourceVelocity(10f, 0f, 0f, soundIndex); // AlUtils.resetAlListener(); if (AL10.alGetError() != AL10.AL_NO_ERROR) System.out.println("Erreur d'OpenAL" + AL10.alGetError()); // Environment sounds if (soundWalk != null) soundWalk(); soundBump(); soundGround(); soundJump(); // we execute permanentSound method for all the enemy for (int i = 0; i < map.getWorld().getBodies().size(); i++) { if (map.getEntityByBody(map.getWorld().getBodies().get(i)) instanceof Enemy) { ((Enemy) map.getEntityByBody(map.getWorld().getBodies().get(i))).permanentSound(i); } } // the help sound if executed helpSound.setSourcePosition( Globals.player.getX() - Globals.player.getWidth() / 2, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); }
private void soundJump() { // if the player is jumping or falling we play the jump sound if (Globals.player.jumping() || Globals.player.falling()) { // if the sound is still playing we let it play if (!soundJump.playing()) { soundJump.loop( 1f, 0.5f, Globals.player.getX() - Globals.player.getWidth() / 2, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); soundJumpPlaying = true; } else { soundJump.setSourcePosition( Globals.player.getX() - Globals.player.getWidth() / 2, Globals.player.getY() - Globals.player.getHeight() / 2, 0.0f); } // We modulate the sound pitch depending on the y speed of movement // of the character float pitchVel = 0; pitchVel = 0.1f + Globals.player.getVelY() / 120f; // System.out.println(pitchVel+" lol"); // because the y velocity can be positive or negative depending on // falling or jumping if (pitchVel < 0) pitchVel = -pitchVel; // for security if (pitchVel > 10) pitchVel = 10; if (pitchVel < 0.0001) pitchVel = 0.0001f; soundJump.setPitch(pitchVel); } // we stop the sound because the character is no more jumping else { soundJump.stop(); } }
@Override public void render(GameContainer container, StateBasedGame game, Graphics g) throws SlickException { // TODO Graphics? g.drawString("Distance: " + distance, 10, 25); g.drawString("Speed: " + ((double) ((int) (speed * 10000.0))) / 10000.0, 10, 40); // all the graphics below will be affected by the translation g.translate(spX, 0); // The smoke ((ConfigurableEmitter) trail.getEmitter(0)) .setPosition(dudeWidth - dudeSize.width / 2 - spX, dudeHeight); trail.render(); // the death explosion ((ConfigurableEmitter) explosion.getEmitter(0)) .setPosition(dudeWidth - dudeSize.width / 2 - spX, dudeHeight); ((ConfigurableEmitter) explosion.getEmitter(1)) .setPosition(dudeWidth - dudeSize.width / 2 - spX, dudeHeight); explosion.render(); // the walls // upper wall for (int i = 0; i < upperWall.size() - 1; i++) { for (int j = 0; j < 5; j++) { g.drawLine( i * WALL_RES + wallOffset - spX, upperWall.get(i) - j, (i + 1) * WALL_RES + wallOffset - spX, upperWall.get(i + 1) - j); } } // lower wall for (int i = 0; i < lowerWall.size() - 1; i++) { for (int j = 0; j < 5; j++) { g.drawLine( i * WALL_RES + wallOffset - spX, lowerWall.get(i) + j, (i + 1) * WALL_RES + wallOffset - spX, lowerWall.get(i + 1) + j); } } // The object g.fillRect( dudeWidth - dudeSize.width / 2 - spX, (int) dudeHeight - dudeSize.height / 2, dudeSize.width, dudeSize.height); // if(dead) g.drawString("Le jeu est terminé, appuyez sur Entrée pour continuer", 250, 150); // Sounds AlUtils.setAlListenerPosition((float) (WALL_RES + dudeSize.width / 2), dudeHeight, 0f); if (movingUp) AlUtils.setAlListenerVelocity((float) (WALL_RES + dudeSize.width / 2), -20, 0f); else AlUtils.setAlListenerVelocity((float) (WALL_RES + dudeSize.width / 2), 20, 0f); enterSound.setSourcePosition((float) (WALL_RES + dudeSize.width / 2), dudeHeight, 0f, 0); sonG.setSourcePosition((float) (WALL_RES + dudeSize.width / 2), actualUpperWall, 0f, 0); sonD.setSourcePosition((float) (WALL_RES + dudeSize.width / 2), actualLowerWall, 0f, 1); sonG.setSourceVelocity( (float) (WALL_RES + dudeSize.width / 2), upperWall.get(currentWallNo - 1) - upperWall.get(currentWallNo), 0f, 0); sonD.setSourceVelocity( (float) (WALL_RES + dudeSize.width / 2), lowerWall.get(currentWallNo) - lowerWall.get(currentWallNo - 1), 0f, 1); distSonBas = (float) (1.0 / ((actualLowerWall - dudeHeight) / 50.0)); distSonHaut = (float) (1.0 / ((dudeHeight - actualUpperWall) / 50.0)); sonG.setPitch(distSonHaut); sonD.setPitch(distSonBas, 1); }