update_states.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. #include "update_states.h"
  2. void update_title(Game_Data *data)
  3. {
  4. //TODO
  5. }
  6. void update_game(Game_Data *data)
  7. {
  8. data->last_time = data->current_time;
  9. data->current_time = RTC_GetTicks();
  10. if(data->list != NULL){ //if the linked list is not empty
  11. updateWalls(data->list, data->current_time - data->last_time); //update the linked list
  12. if(isColliding(data->list, data->player_angle, data->nb_lines) == true){ //if the player and a wall collide
  13. PrintMini(50, 0, "TOUCHE", MINI_OVER); //death handling
  14. }
  15. data->list = removeWall(data->list, 0); //remove every wall whose distance to the center equals zero
  16. }
  17. //level generation
  18. //TODO: something else than pure randomness
  19. if(rand() % 40 == 1){
  20. data->list = addWall(data->list, 128, 8, 1, rand()%6);
  21. }else if(rand() % 70 == 1){
  22. int emptyRow = rand()%6;
  23. int i = 0;
  24. for(i = 0; i < 6; i++)
  25. if(i != emptyRow)
  26. data->list = addWall(data->list, 128, 15, 1, i);
  27. }
  28. if(KeyDown(K_LEFT)){
  29. data->player_angle-=15;
  30. }
  31. if(KeyDown(K_RIGHT)){
  32. data->player_angle+=15;
  33. }
  34. if(KeyDown(K_PLUS) && data->line_transition.counter == 0)
  35. {
  36. data->line_transition.counter = 10;
  37. data->line_transition.counter_start = 10;
  38. data->line_transition.delta_nb_lines = 1;
  39. }else if(KeyDown(K_MINUS) && data->line_transition.counter == 0){
  40. data->line_transition.counter = 10;
  41. data->line_transition.counter_start = 10;
  42. data->line_transition.delta_nb_lines = -1;
  43. }
  44. if(data->line_transition.counter != 0){
  45. data->line_transition.counter --;
  46. if(data->line_transition.counter <= 0){
  47. data->nb_lines += data->line_transition.delta_nb_lines;
  48. data->line_transition.counter_start = 0;
  49. data->line_transition.delta_nb_lines = 0;
  50. }
  51. }
  52. if(data->player_angle < 0)
  53. data->player_angle = 360 + data->player_angle;
  54. data->player_angle = data->player_angle % 360;
  55. updateCamera(&(data->cam), data->current_time - data->last_time);
  56. }
  57. void update_menu(Game_Data *data)
  58. {
  59. //TODO
  60. }
  61. void update_game_over(Game_Data *data)
  62. {
  63. //TODO
  64. }
  65. void updateCamera(Camera *cam, unsigned int delta_time){
  66. cam->speed = 1; //to change
  67. cam->angle += cam->speed * delta_time / 2.;
  68. if(cam->angle >= 360)
  69. cam->angle = cam->angle % 360;
  70. }