mirror of
https://grond.iut-fbleau.fr/stiti/SAE_2.02
synced 2024-11-12 22:01:41 +01:00
Ajout de Onzeur Bird
This commit is contained in:
parent
2ab9a2a56b
commit
5d806c1fea
@ -50,7 +50,7 @@ defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
| my-controller/my-method -> my_controller/my_method
|
||||
*/
|
||||
$route['default_controller'] = 'home/index';
|
||||
$route['404_override'] = '';
|
||||
$route['404_override'] = 'errors/error_404';
|
||||
$route['translate_uri_dashes'] = FALSE;
|
||||
$route['albums'] = 'albums/index';
|
||||
$route['musiques'] = 'Musiques/index';
|
||||
|
16
CodeIgniter-3.1.13/application/controllers/Errors.php
Normal file
16
CodeIgniter-3.1.13/application/controllers/Errors.php
Normal file
@ -0,0 +1,16 @@
|
||||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
class Errors extends CI_Controller {
|
||||
|
||||
public function __construct() {
|
||||
parent::__construct();
|
||||
}
|
||||
|
||||
public function error_404() {
|
||||
$this->output->set_status_header('404');
|
||||
$this->load->view('layout/header_dark');
|
||||
$this->load->view('error_404');
|
||||
$this->load->view('layout/footer_dark');
|
||||
}
|
||||
}
|
159
CodeIgniter-3.1.13/application/views/error_404.php
Normal file
159
CodeIgniter-3.1.13/application/views/error_404.php
Normal file
@ -0,0 +1,159 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>404 - Page non trouvée</title>
|
||||
<link rel="stylesheet" href="<?php echo base_url('assets/css/error_404'); ?>">
|
||||
</head>
|
||||
<body>
|
||||
<h1>Erreur 404 🤖 - Cette page n'existe pas<h1>
|
||||
<p>Ne partez pas si vite, pourquoi ne pas rester pour jouer à Flappy Onzeur ?</p>
|
||||
<canvas id="flappyBirdCanvas" width="400" height="600"></canvas>
|
||||
<div class="overlay" id="overlay">
|
||||
<div class="countdown" id="countdown">3</div>
|
||||
</div>
|
||||
<script>
|
||||
const canvas = document.getElementById('flappyBirdCanvas');
|
||||
const ctx = canvas.getContext('2d');
|
||||
const GRAVITY = 0.25;
|
||||
const FLAP = -4.5;
|
||||
const PIPE_WIDTH = 50;
|
||||
const PIPE_SPEED = 2;
|
||||
const PIPE_SPACING = 150;
|
||||
let pipes = [];
|
||||
let isGameOver = false;
|
||||
|
||||
// Chargement des ressources
|
||||
const birdSprite = new Image();
|
||||
birdSprite.src = 'https://dwarves.iut-fbleau.fr/~stiti/SAE_2.02/CodeIgniter-3.1.13/assets/img/Logo_ONZEUR.png';
|
||||
|
||||
const backgroundImage = new Image();
|
||||
backgroundImage.src = 'https://images-wixmp-ed30a86b8c4ca887773594c2.wixmp.com/f/089918d8-99ff-45de-a084-3fe85d0e3fcc/dg34rsu-29a3d144-dc3f-473e-a949-f73a4ba1ef7c.png/v1/fill/w_608,h_457,q_80,strp/flappy_bird_backdrop_by_lenaxux_dg34rsu-fullview.jpg?token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ1cm46YXBwOjdlMGQxODg5ODIyNjQzNzNhNWYwZDQxNWVhMGQyNmUwIiwiaXNzIjoidXJuOmFwcDo3ZTBkMTg4OTgyMjY0MzczYTVmMGQ0MTVlYTBkMjZlMCIsIm9iaiI6W1t7ImhlaWdodCI6Ijw9NDU3IiwicGF0aCI6IlwvZlwvMDg5OTE4ZDgtOTlmZi00NWRlLWEwODQtM2ZlODVkMGUzZmNjXC9kZzM0cnN1LTI5YTNkMTQ0LWRjM2YtNDczZS1hOTQ5LWY3M2E0YmExZWY3Yy5wbmciLCJ3aWR0aCI6Ijw9NjA4In1dXSwiYXVkIjpbInVybjpzZXJ2aWNlOmltYWdlLm9wZXJhdGlvbnMiXX0._FI7nnUO3ZCIz23z4_juaIbbiEa_LQd1lX6MK-0iUEE'; // Remplacez 'background.jpg' par le chemin de votre image de fond
|
||||
|
||||
// Définir la classe Bird
|
||||
class Bird {
|
||||
constructor() {
|
||||
this.x = 150;
|
||||
this.y = 200;
|
||||
this.vy = 0;
|
||||
this.width = 34;
|
||||
this.height = 24;
|
||||
this.weight = 1;
|
||||
}
|
||||
|
||||
update() {
|
||||
this.vy += GRAVITY;
|
||||
this.y += this.vy;
|
||||
|
||||
if (this.y > canvas.height - this.height) {
|
||||
this.y = canvas.height - this.height;
|
||||
this.vy = 0;
|
||||
}
|
||||
|
||||
if (this.y < 0) {
|
||||
this.y = 0;
|
||||
this.vy = 0;
|
||||
}
|
||||
}
|
||||
|
||||
draw() {
|
||||
ctx.drawImage(birdSprite, this.x, this.y, this.width, this.height);
|
||||
}
|
||||
|
||||
flap() {
|
||||
this.vy += FLAP;
|
||||
}
|
||||
}
|
||||
|
||||
const bird = new Bird();
|
||||
|
||||
// Contrôles
|
||||
document.addEventListener('keydown', function (e) {
|
||||
if (e.code === 'Space') bird.flap();
|
||||
});
|
||||
|
||||
// Fonction principale pour démarrer le jeu après un compte à rebours de 3 secondes
|
||||
function startGame() {
|
||||
// Afficher le compte à rebours
|
||||
let countdown = 3;
|
||||
const countdownInterval = setInterval(function() {
|
||||
// Mettre à jour le compte à rebours dans l'overlay
|
||||
document.getElementById('countdown').textContent = countdown;
|
||||
countdown--;
|
||||
|
||||
if (countdown < 0) {
|
||||
clearInterval(countdownInterval); // Arrêter le compte à rebours
|
||||
document.getElementById('overlay').style.display = 'none'; // Masquer l'overlay
|
||||
animate(); // Démarrer le jeu
|
||||
}
|
||||
}, 1000);
|
||||
}
|
||||
|
||||
// Fonction principale d'animation
|
||||
function animate() {
|
||||
if (isGameOver) {
|
||||
alert('Game Over ! Visiblement les jeux-vidéos ne sont pas fait pour vous... Cliquez sur le bouton \'OK\' pour retourner à la page d\'accueil.');
|
||||
window.location.href = '<?php echo base_url(); ?>'; // Rediriger vers la page d'accueil
|
||||
return;
|
||||
}
|
||||
|
||||
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
||||
|
||||
// Dessiner le fond
|
||||
ctx.drawImage(backgroundImage, 0, 0, canvas.width, canvas.height);
|
||||
|
||||
// Gérer les obstacles (pipes)
|
||||
pipes.forEach(pipe => {
|
||||
pipe.x -= PIPE_SPEED;
|
||||
|
||||
// Dessiner les tuyaux
|
||||
ctx.fillStyle = 'purple';
|
||||
ctx.fillRect(pipe.x, 0, PIPE_WIDTH, pipe.top);
|
||||
ctx.fillRect(pipe.x, pipe.bottom, PIPE_WIDTH, canvas.height - pipe.bottom);
|
||||
|
||||
// Vérifier la collision avec les tuyaux
|
||||
if (bird.x + bird.width > pipe.x && bird.x < pipe.x + PIPE_WIDTH) {
|
||||
if (bird.y < pipe.top || bird.y + bird.height > pipe.bottom) {
|
||||
// Collision détectée, fin de jeu
|
||||
isGameOver = true;
|
||||
}
|
||||
}
|
||||
|
||||
// Supprimer les tuyaux sortis de l'écran
|
||||
if (pipe.x + PIPE_WIDTH < 0) {
|
||||
pipes.shift();
|
||||
}
|
||||
});
|
||||
|
||||
// Vérifier la collision avec le sol
|
||||
if (bird.y + bird.height >= canvas.height) {
|
||||
// Collision avec le sol, fin de jeu
|
||||
isGameOver = true;
|
||||
}
|
||||
|
||||
// Gérer l'oiseau
|
||||
bird.update();
|
||||
bird.draw();
|
||||
|
||||
// Générer de nouveaux tuyaux
|
||||
if (frames % 100 === 0) {
|
||||
const topHeight = Math.random() * (canvas.height / 2);
|
||||
const bottomHeight = Math.random() * (canvas.height / 2);
|
||||
pipes.push({ x: canvas.width, top: topHeight, bottom: canvas.height - bottomHeight });
|
||||
}
|
||||
|
||||
frames++;
|
||||
|
||||
requestAnimationFrame(animate);
|
||||
}
|
||||
|
||||
|
||||
let frames = 0;
|
||||
|
||||
// Lancer le jeu lorsque la page est chargée
|
||||
window.onload = function() {
|
||||
startGame(); // Commencer le compte à rebours et le jeu après 3 secondes
|
||||
};
|
||||
</script>
|
||||
</body>
|
||||
|
24
CodeIgniter-3.1.13/assets/css/error_404.css
Normal file
24
CodeIgniter-3.1.13/assets/css/error_404.css
Normal file
@ -0,0 +1,24 @@
|
||||
canvas {
|
||||
border: 1px solid black;
|
||||
display: block;
|
||||
margin: 0 auto;
|
||||
z-index: 1;
|
||||
}
|
||||
|
||||
.overlay {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
background-color: rgba(0, 0, 0, 0.5);
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
z-index: 2;
|
||||
}
|
||||
|
||||
.countdown {
|
||||
font-size: 36px;
|
||||
color: white;
|
||||
}
|
Loading…
Reference in New Issue
Block a user