Accueil > > > KB KLIK BALL
KB KLIK BALL
Information sur la source
Description
Un jeux d'arcade, avec un concept simple : Cliquer sur une balle la fait monter si elle descendait. Chaque balle qui touche le sol t'enlève une de tes 5 vies. Lorsqu'une balle touche le bord droit du jeu, tu gagne un point et elle s'immobilise. Il faut faire un max de points avec tes 5 vies.
Source
- Image 1 : Intro
- // on arrete la lecture
- stop();
- // on passe à l'image suivante après un clic du joueur
- onMouseUp = function () {
- play();
- };
-
-
-
- Image 2 : Le jeux
- // stop car il y a plusieurs image dans le scénario
- stop();
- //
- // dans l'image précédente du scénario, un clique
- //engendre la lecture du scenario, donc on annule l'effet de cet evenement
- onMouseUp = null;
- //
- // Initialisation des tableaux qui contiendrons les infos sur chaque balle
- // la position de la balle en x
- var px:Array = new Array();
- // la position de la balle en y
- var py:Array = new Array();
- // l'inertie, ou le vecteur vitesse de la balle en x
- var ix:Array = new Array();
- // l'inertie, ou le vecteur vitesse de la balle en y
- var iy:Array = new Array();
- // l'angle de rotation de la balle
- var pr:Array = new Array();
- // l'inertie en rotation de la balle
- var ir:Array = new Array();
- //
- // variable pour a création des balles
- // une variable incrémentée à chaque image de l'animation. Si elle
- // atteint delaymax, on l'initialise et on créé une balle
- delay = 0;
- // le nombre d'image entre la création des balles
- delaymax = 50;
- //
- // Le nombre de vies utilisée
- dies = 0;
- //
- // Le score du joueur
- score = 0;
- //
- // Ce qui suit est exécuté à chaque image de l'animation
- _root.onEnterFrame = function() {
- // Si on a plus de vies, aller à l'image suivante dans le scénario, c'est
- // à dire le GAME OVER
- if (dies>4) {
- _root.play();
- }
- // Incrémente le delai avant la prochaine creation d'une balle
- delay++;
- // création d'une balle
- if (delay>delaymax) {
- // La prochaine balle sera crée plus tôt
- delaymax--;
- // initialise le delai avant la prochaine création de balle
- delay = 0;
- //
- // initialise la position de la balle créé en fonction de la position
- //du movie clip b0.
- px[px.length] = b0._x;
- py[px.length-1] = b0._y;
- //
- // initialisation de l'inertie de la balle
- // elle part vers la droite
- ix[px.length-1] = Math.random()*3+3;
- // le plus souvent, elle monte,
- //mais il lui arrive de descendre
- iy[px.length-1] = Math.random()*5-1;
- //
- // initialisation de la rotation de la balle et de son inertie en rotation.
- pr[px.length-1] = Math.random()*360;
- ir[px.length-1] = 2;
- }
- //
- // gestion de chaque balle l'une aprés l'autre
- for (a=0; a<px.length; a++) {
- // si la balle ne touchait pas le sol ni n'était collée à droite à l'image précédente
- // de l'animation
- if (py[a]<250 && px[a]<600) {
- // apliquer le vecteur vitesse à la position et à la rotation de la balle
- px[a] += ix[a];
- py[a] += iy[a];
- pr[a] += ir[a];
- // modérer progressivement la rotation
- ir[a] *= 0.9;
- // gravité qui tend à faire tomber la balle
- iy[a] += 0.1;
- // afficher une balle à l'écran sous forme d'un movie clip
- //(attention à la profondeur qui sert après)
- ref = _root.attachMovie("ball", a.toString(), a);
- // positioner l'image de la balle
- ref._x = px[a];
- ref._y = py[a];
- // tourner l'image de la balle
- ref._rotation = pr[a];
- // apliquer un événement lorsqu'on clique sur la balle
- ref.onPress = function() {
- // inverser l'inertie verticalle de la balle
- // this.getDepth() nous donne le numéro de la balle
- //(voire la fonction créent le mc plus haut)
- iy[this.getDepth()] *= -1;
- // faire tourner un peu la balle
- ir[this.getDepth()] += 20;
- };
- // fin du onPress
- // si la balle touche le sol
- if (py[a]>250) {
- // enlever une vie
- dies++;
- // placer la balle sur l'image grisée en bas
- ref._x = dies*50;
- ref._y = 275;
- }
- // si la balle est à droite après les déplacements
- if (px[a]>=600) {
- score++;
- // fin de la condition "Si la balle, après déplacement, est à droite"
- }
- // fin de la condition "balle en position normale"
- }
- // fin de la gestion de chaque balle une par une
- }
- // fin du code éxécuté 30 fois par seconde
- };
-
-
- Image 3 : GAME OVER
- stop();
- _root.onEnterFrame = null;
- for (a=0; a<px.length; a++) {
- _root.createEmptyMovieClip(a.toString(), a);
- }
- _root.bts.onRelease = function() {
- _root.gotoAndStop(1);
- };
-
Image 1 : Intro
// on arrete la lecture
stop();
// on passe à l'image suivante après un clic du joueur
onMouseUp = function () {
play();
};
Image 2 : Le jeux
// stop car il y a plusieurs image dans le scénario
stop();
//
// dans l'image précédente du scénario, un clique
//engendre la lecture du scenario, donc on annule l'effet de cet evenement
onMouseUp = null;
//
// Initialisation des tableaux qui contiendrons les infos sur chaque balle
// la position de la balle en x
var px:Array = new Array();
// la position de la balle en y
var py:Array = new Array();
// l'inertie, ou le vecteur vitesse de la balle en x
var ix:Array = new Array();
// l'inertie, ou le vecteur vitesse de la balle en y
var iy:Array = new Array();
// l'angle de rotation de la balle
var pr:Array = new Array();
// l'inertie en rotation de la balle
var ir:Array = new Array();
//
// variable pour a création des balles
// une variable incrémentée à chaque image de l'animation. Si elle
// atteint delaymax, on l'initialise et on créé une balle
delay = 0;
// le nombre d'image entre la création des balles
delaymax = 50;
//
// Le nombre de vies utilisée
dies = 0;
//
// Le score du joueur
score = 0;
//
// Ce qui suit est exécuté à chaque image de l'animation
_root.onEnterFrame = function() {
// Si on a plus de vies, aller à l'image suivante dans le scénario, c'est
// à dire le GAME OVER
if (dies>4) {
_root.play();
}
// Incrémente le delai avant la prochaine creation d'une balle
delay++;
// création d'une balle
if (delay>delaymax) {
// La prochaine balle sera crée plus tôt
delaymax--;
// initialise le delai avant la prochaine création de balle
delay = 0;
//
// initialise la position de la balle créé en fonction de la position
//du movie clip b0.
px[px.length] = b0._x;
py[px.length-1] = b0._y;
//
// initialisation de l'inertie de la balle
// elle part vers la droite
ix[px.length-1] = Math.random()*3+3;
// le plus souvent, elle monte,
//mais il lui arrive de descendre
iy[px.length-1] = Math.random()*5-1;
//
// initialisation de la rotation de la balle et de son inertie en rotation.
pr[px.length-1] = Math.random()*360;
ir[px.length-1] = 2;
}
//
// gestion de chaque balle l'une aprés l'autre
for (a=0; a<px.length; a++) {
// si la balle ne touchait pas le sol ni n'était collée à droite à l'image précédente
// de l'animation
if (py[a]<250 && px[a]<600) {
// apliquer le vecteur vitesse à la position et à la rotation de la balle
px[a] += ix[a];
py[a] += iy[a];
pr[a] += ir[a];
// modérer progressivement la rotation
ir[a] *= 0.9;
// gravité qui tend à faire tomber la balle
iy[a] += 0.1;
// afficher une balle à l'écran sous forme d'un movie clip
//(attention à la profondeur qui sert après)
ref = _root.attachMovie("ball", a.toString(), a);
// positioner l'image de la balle
ref._x = px[a];
ref._y = py[a];
// tourner l'image de la balle
ref._rotation = pr[a];
// apliquer un événement lorsqu'on clique sur la balle
ref.onPress = function() {
// inverser l'inertie verticalle de la balle
// this.getDepth() nous donne le numéro de la balle
//(voire la fonction créent le mc plus haut)
iy[this.getDepth()] *= -1;
// faire tourner un peu la balle
ir[this.getDepth()] += 20;
};
// fin du onPress
// si la balle touche le sol
if (py[a]>250) {
// enlever une vie
dies++;
// placer la balle sur l'image grisée en bas
ref._x = dies*50;
ref._y = 275;
}
// si la balle est à droite après les déplacements
if (px[a]>=600) {
score++;
// fin de la condition "Si la balle, après déplacement, est à droite"
}
// fin de la condition "balle en position normale"
}
// fin de la gestion de chaque balle une par une
}
// fin du code éxécuté 30 fois par seconde
};
Image 3 : GAME OVER
stop();
_root.onEnterFrame = null;
for (a=0; a<px.length; a++) {
_root.createEmptyMovieClip(a.toString(), a);
}
_root.bts.onRelease = function() {
_root.gotoAndStop(1);
};
Conclusion
Personnellement ce jeux me plait, donc je vous conseille de l'essayer.
De plus, vous pouvez trouver d'autres jeux de moi à cette adresse : http://daddy11world.free.fr
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
jeu de dessin [ par patrickgilet ]
Dans un clip d'occurrence "zonedessin", j'ai limité "l'action de la souris".Normalement, on ne devrait pas pouvoir dessiner en dehors de ce cadre. Mai
Effet de fusion d'image au passage de la souris sur un bouton [ par galaxiae ]
Bonjour à tous!Actuellement je travaille sur le développement d'un site interactif et je me retrouve embêté car je n'arrive pas à réaliser un effet pa
bouton et clip (débutant) [ par phm666 ]
bonjour je cherche à faire jouer un clip d'animation par exemple lorsque je passe ma souris sur un bouton.J'insère donc un clip dans l'image "dessus",
apparition dun texte lors dun passage de la souris [ par eryk17 ]
comment faire pour que lorsque lon passe la souris sur un endroit d'une page il ya un texte qui s'affiche se serait dans une cellule d'un tableau.merc
Suivi de souris [ par vdiac ]
Bonjour @ Tous, j'ai une petite question, comment fait t on pour pouvoir faire une animation simple qui suit la souris ( J'ai trouvé qqc sur le site
clip qui suit la souris [ par celbob ]
Salut,j'essaie d'avoir un clip qui suit la position de la souris (en _x uniquement). Jusque là, j'y suis arrivée (avec startDrag), ms du coup, aucun b
Urgentissime validité d'1 mail [ par ihen ]
bonjour à toutes et à tous !!Voila g un prblm MEGA URGENT pour ce matin, qui concerne le controle de validité d'un mail.En effet, g un formulaire ave
faire pivoter un bras par clik de la souris [ par dri11 ]
Bonjour, je voudrais savoir s'il est possible par exemple de cliker sur une aiguille d'une horloge statique pour déplacer l'aiguille à l'heure que l o
truc qui suit la souris [ par Wally57 ]
je voudrais savoir quel actions il faut mettres pour qu un symbole suive la souris mais ne reste pas tout le temps dessus, il va tjs vers le curseur e
Verif LoadMovie [ par agau123 ]
Bonjour,comment vérifier que l'url du loadmovie est bonne.Explication :Mon swf principal appelle un fichier sur l'adresse http://monsite.fr/intro.swf.
|
Derniers Blogs
TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko [FRAMEWORK 4] LES TASKS ET LE THREAD UI[FRAMEWORK 4] LES TASKS ET LE THREAD UI par fathi
Je viens de passer quelques temps au TechDay's et j'ai pu voir pas mal de session intéressante. Par contre une chose m'a un peu étonné lors de certaines de ces sessions qui abordaient les améliorations du framework .NET (donc le 4.5) : en gros, bea...
Cliquez pour lire la suite de l'article par fathi WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui m'ont suivi. Je profite de ce poste, pour faire le re...
Cliquez pour lire la suite de l'article par JeremyJeanson TECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PCTECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PC par ROMELARD Fabrice
Speakers: Thierry Rapatout, Antoine Petit et Xavier Trebbia Cette session entre dans le cadre des RDV Décideurs des TechDays 2012, elle est liée à la consumérisation de l'IT et la mise en place du "DeskTop as a Service" dans de plus en ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|