exo birdie et titi de Greg
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

README.md 4.7 KiB

3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. # Partie 2
  2. Maintenant que nous avons un arrière-plan et un oiseau qui vole de haut en bas, ajoutons les tuyaux aux travers desquels l'oiseau va devoir passer.
  3. ## Ajouter les tuyaux
  4. Vous avez déjà vu que nous pouvons créer des objets `Actor` et comment les déplacer sur l'écran. Au besoin, retournez voir dans la section précédente comment vous avez procédé avec l'oiseau.
  5. Nous devons donc ajouter deux tuyaux, et si vous regardez dans le répertoire images, vous verrez que nous avons deux fichiers nommés `top.png` et `bottom.png`. Comment les ajouter au jeu ?
  6. > Créons deux nouveaux acteurs en ajoutant à la fin de votre code :
  7. ```python
  8. tube_superieur = Actor('top', (300,0))
  9. tube_inferieur = Actor('bottom', (300,500))
  10. ```
  11. Pour voir apparaître les tuyaux, il ne faut pas oublier de demander leur dessin. À vous de déterminer où placer ces deux lignes :
  12. ```python
  13. tube_superieur.draw()
  14. tube_inferieur.draw()
  15. ```
  16. > Testez le résultat
  17. Bien, nous avons des tuyaux ! Mais ils sont juste là, sur la page, et il n'y a pas d'espace entre eux.
  18. *Pouvez-vous deviner ce que les `(300, 0)` et `(300, 500)` signifient ? Modifiez-les pour vérifier.*
  19. ## Attention à l'écart
  20. Comment faire un trou pour que notre oiseau puisse voler ? Nous devons nous assurer que nous positionnons les tuyaux au bon endroit sur l'écran, et pour ce faire, nous devons connaître la taille de chaque image.
  21. > Voyons ce que nous pouvons découvrir d'un acteur, en ajoutant ce code à la fin de votre programme :
  22. ```python
  23. print(tube_superieur.width, tube_superieur.height)
  24. ```
  25. > Exécutez le programme et regardez quels nombres apparaissent dans la console.
  26. Vous devriez voir apparaître deux chiffres (normalement 100 500), c'est la largeur et la hauteur du tube supérieur en pixels.
  27. Grâce à ces informations, nous pouvons modifier la construction des tuyaux supérieurs et inférieurs en conséquence :
  28. ```python
  29. ecart = 140
  30. tube_superieur = Actor('top', (300, 0))
  31. tube_inferieur = Actor('bottom', (300, tube_superieur.height + ecart))
  32. ```
  33. Les deux valeurs séparées par une virgule à la fin de chaque ligne Actor contrôlent la position **x** (de gauche à droite), et **y** (de haut en bas) de l'Actor. Ainsi `(300,0)` place le tuyau à 300 pixels du bord gauche, et 0 pixel en bas du haut de la fenêtre.
  34. D'où viennent ces calculs ? Eh bien, l'écart est une nouvelle variable que nous créons, et nous disons que la hauteur du tuyau supérieur plus l'écart doit être la valeur **y** du tuyau inférieur. Essayez de changer la valeur de l'écart et voyez ce qui se passe.
  35. > Exécutez pour vérifier que nous avons créé un écart
  36. *Quel est le plus grand écart que vous pouvez faire tout en voyant le tuyau de fond ?*
  37. ## Allons de l'avant
  38. Pour donner l'impression que l'oiseau vole vers l'avant, et bien que cela paraissent paradoxal, il va falloir faire se déplacer les tubes. C'est une technique classique dans les jeux vidéos : le joueur reste immobile, c'est tout le reste qui se déplace.
  39. Faisons donc bouger ces tuyaux. Tout comme nous l'avons fait avec notre oiseau, nous pouvons créer une variable de vitesse pour les tuyaux et l'utiliser pour les faire bouger. Nous voulons que la ligne de code suivante s'exécute une fois lorsque nous lançons le programme, elle doit donc se trouver à la fin de votre code :
  40. ```python
  41. vitesse_defilement = 1
  42. ```
  43. Et ils doivent se déplacer continuellement, donc ce code va dans la fonction de mise à jour :
  44. ```python
  45. tube_superieur.x += vitesse_defilement
  46. tube_inferieur.x += vitesse_defilement
  47. ```
  48. Testez. Tout se passe-t-il comme prévu ? Si ce n'est pas le cas, relisez votre code et essayez de le corriger.
  49. ## Plus de tuyaux
  50. Nous avons besoin de plus de tuyaux, une seule paire ne suffit pas. En fait, nous en avons déjà assez, nous pouvons simplement les faire tourner en boucle lorsqu'ils sortent de l'écran.
  51. Pour ce faire, nous allons utiliser l'instruction `if` ainsi que les tests conditinnels `<` et `>`.
  52. Il y a trois choses délicates avec les énoncés `if` :
  53. - Que testez-vous exactement ? Que se passe-t-il après le "si" ?
  54. - Il ne faut pas oublier les deux points à la fin du test conditionnel.
  55. - Il faut que l'indentation soit correcte - combien d'espaces au début de la ligne ? - pour que le bon code soit exécuté.
  56. ## Boucles sur les tuyaux
  57. Mettons-nous au travail dans la fonction de mise à jour, car c'est là que nous déplaçons les tuyaux.
  58. > Ajoutez ce code à la fin de la fonction, et assurez-vous que vous l'indentez pour qu'il soit vraiment à l'intérieur de la fonction.
  59. > Efforcez-vous de *réellement* comprendre le sens des lignes de code.
  60. ```python
  61. if tube_superieur.x < 0 :
  62. tube_superieur.x = WIDTH
  63. ```
  64. Il devrait toutefois subsister certains soucis... À vous de les corriger 😁