Yang Zhenye 201199680
Dependencies: mbed
Ball/Ball.cpp
- Committer:
- yangzhenye
- Date:
- 2020-05-15
- Revision:
- 9:a5a82b3d1102
- Parent:
- 5:fcad75e9b9e1
File content as of revision 9:a5a82b3d1102:
/* ELEC2645 Embedded Systems Project School of Electronic & Electrical Engineering University of Leeds 2019/20 Name:Yang Zhenye Username:el17zy Student ID Number:201199680 Date:2020/5/12 */ #include "Ball.h" Ball::Ball() { } Ball::~Ball() { } void Ball::init(int size,int speed) { _size = size; _x = WIDTH/2 - _size/2; _y = HEIGHT/2 - _size/2; srand(time(NULL)); int direction = rand() % 4; // randomise initial direction. // 4 possibilities. Get random modulo and set velocities accordingly if (direction == 0) { _velocity.x = speed; _velocity.y = speed; } else if (direction == 1) { _velocity.x = speed; _velocity.y = -speed; } else if (direction == 2) { _velocity.x = speed; _velocity.y = speed; } else { _velocity.x = -speed; _velocity.y = -speed; } } void Ball::draw(N5110 &lcd) { lcd.drawRect(_x,_y,_size,_size,FILL_BLACK); } void Ball::update() { _x += _velocity.x; _y += _velocity.y; } void Ball::set_velocity(Vector2D v) { _velocity.x = v.x; _velocity.y = v.y; } Vector2D Ball::get_velocity() { Vector2D v = {_velocity.x,_velocity.y}; return v; } Vector2D Ball::get_pos() { Vector2D p = {_x,_y}; return p; } void Ball::set_pos(Vector2D p) { _x = p.x; _y = p.y; }