explorer game

Dependencies:   mbed

explorer/explorer.cpp

Committer:
el17my
Date:
2020-04-21
Revision:
3:672d4bd8225d
Parent:
2:89f04cd3bf45
Child:
7:88c4ba6bb37b

File content as of revision 3:672d4bd8225d:

#include "explorer.h"
//the explorer.cpp need to defined the module and movement of the explorer including the restarted point 
int move_right_sprite[10][10] =   { 
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,0,0,1,0,1,0,0,0 },
  { 0,0,1,1,1,1,1,0,0,0 },
  { 0,0,1,0,1,0,0,0,0,0 },
  { 0,0,0,0,1,0,0,0,0,0 },
  { 0,0,0,0,1,1,1,0,0,0 },
  { 0,0,0,1,0,0,0,1,0,0 },
  { 1,0,1,0,0,0,0,0,1,0 },
};

int move_left_sprite[10][10] =   { 
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,1,0,1,0,0,0,0,0 },
  { 0,0,1,1,1,1,1,0,0,0 },
  { 0,0,0,0,1,0,1,0,0,0 },
  { 0,0,0,0,1,0,0,0,0,0 },
  { 0,0,0,1,1,0,0,0,0,0 },
  { 0,0,1,0,0,1,0,0,0,0 },
  { 0,1,0,0,0,0,1,0,0,0 },
};

int stand_right_sprite[10][10] =   { 
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,0,0,1,0,1,0,0,0 },
  { 0,0,1,1,1,1,1,0,0,0 },
  { 0,0,1,0,1,0,0,0,0,0 },
  { 0,0,0,0,1,0,0,0,0,0 },
  { 0,0,0,0,1,0,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
};

int stand_left_sprite[10][10] =   { 
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
  { 0,0,0,1,1,1,0,0,0,0 },
  { 0,0,1,0,1,0,0,0,0,0 },
  { 0,0,1,1,1,1,1,0,0,0 },
  { 0,0,0,0,1,0,1,0,0,0 },
  { 0,0,0,0,1,0,0,0,0,0 },
  { 0,0,0,0,1,0,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
  { 0,0,0,1,0,1,0,0,0,0 },
};

Explorer::Explorer() {} 

Explorer::~Explorer() {}

void Explorer::set_x_coordinate(float joy_x, int speed, Player_direction direction)
{
  //this process is to set x and make sure the player can move          
  _player_direction = direction;
  _speed = speed;
  if (joystick_x < float(-0.5)) {
    _speed = _speed--;//
    _player_direction = left;
    _sprite = Move_left;//makesure the value is the Move_left value in the enum 
  //now x is moving to the right than add to the X position
  } else if (joystick_x > float(0.5)) {
    _speed = _speed++;
    _player_direction = right; 
    _sprite = Move_right;//makesure the value is the Move_right value in the enum  
  } else if (_player_direction == right) {  
    _sprite = Stand_right;// not moving so equals to enum Stand_right.
  } else { 
    _sprite = Stand_left;//the least situation is equals to enum Stand_right.
  }      
  _x = 0.5*_speed + 30;//this equation decides how fast the player move later I will update differnet modes to choose different speed
}
//this function is easy to understand because this is just choosing different sprite according to the direction
int * Explorer::get_form(explorer_sprite sprite){
  if (sprite == Move_right) {
    return *move_right_sprite;
  } else if (sprite == Move_left) {
    return *move_left_sprite;
  } else if (sprite == Stand_left) {
    return *stand_right_sprite;
  } else {
    return *stand_left_sprite;
  }
}

Player_direction Explorer::get_direction() {
  return _player_direction;
}    

explorer_sprite get_explorer_sprite(); {
  return _sprite;
}
    
void Explorer::set_y_coordinate(bool ifjump, int jump_height, int level) {
  _level = level; 
  _jump_height = jump_height;
  // jump need to have this function
  // when you jump makesure the module will not be offscreen also if you fall from the surface you can not jump back again
  if (ifjump == 1) {  
    _jump_height = 30;  //the player can jump up to 30 height and then fall down 
  else if (_jumpheight !=0) { 
  _jumpheight-- }
  };
  //not offscreen and back to the surface        
  if (_level == 1 && ifjump){
    _level = ;
  } else if (_level == 0) {
    _level = ;
  }
  _y = _level - 0.5*_jumpheight;
}  
int Explorer::get_y() {
  return _y;
}

int Explorer::get_x() {
  return _x;
}
  
int Explorer::get_speed() {
  return _speed;
}
  
int Explorer::get_jumptime() {
  return _jumptime;
}

void Explorer::reset_flag(bool flag) {
  _r_flag = flag
  if (flag) {
    _r_flag = true;
  } else {
    _r_flag = false;
  }
}
 
void Explorer::fall(bool f_flag, Gamepad &gamepad) { 
  _f_flag = f_flag;
  if (f_flag == true) {
    gamepad.tone(int(1500-0.5*_y), 0.05);  // decending equation 
    _y--;
  else if(_y == -80) {  // Stop falling function 
    _f_flag = false;
    _r_flag = true;
    game.tone(1000, 0.05);
    wait(0.01);
    }
  }
}

bool Explorer::get_fall_flag() {
  return _f_flag;
}

bool Explorer::get_reset_flag() {
  return _r_flag;
}