Skip to content
Snippets Groups Projects
Commit 6aa942db authored by Taha Belkhiri's avatar Taha Belkhiri
Browse files

Merge branch 'render' of github.com:maberet/ProjetZZ1 into render

parents 42b48d50 8fb2d162
No related branches found
No related tags found
No related merge requests found
...@@ -6,7 +6,7 @@ int trajectoireAntoine[NUMBERPOINT_TRAJEC][2]; ...@@ -6,7 +6,7 @@ int trajectoireAntoine[NUMBERPOINT_TRAJEC][2];
void initBall() void initBall()
{ {
ball.x = 5 * BLOCK_SIZE; ball.x = 5 * BLOCK_SIZE;
ball.y = 5 * BLOCK_SIZE; ball.y = 2 * BLOCK_SIZE;
ball.z = player.h/BLOCK_SIZE; ball.z = player.h/BLOCK_SIZE;
ball.h = 0.5 * BLOCK_SIZE; ball.h = 0.5 * BLOCK_SIZE;
ball.w = 0.5 * BLOCK_SIZE; ball.w = 0.5 * BLOCK_SIZE;
......
...@@ -3,11 +3,10 @@ ...@@ -3,11 +3,10 @@
int running; int running;
int game_state; int game_state;
int main(){ int main(){
float ***** Q = allocateAndInitiateQ(); //float ***** Q = allocateAndInitiateQ();
writeQ(Q); //writeQ(Q);
running = 1; running = 1;
game_state = GAME; game_state = GAME;
readMapFromFile("map.txt"); readMapFromFile("map.txt");
......
...@@ -5,6 +5,7 @@ player_t ennemy; ...@@ -5,6 +5,7 @@ player_t ennemy;
int *landingPoint; int *landingPoint;
int *lastHitPoint; int *lastHitPoint;
int landingPointIsFind = 0;
void initPlayer() void initPlayer()
{ {
...@@ -29,15 +30,22 @@ void initPlayer() ...@@ -29,15 +30,22 @@ void initPlayer()
player.viewAngle = 0; player.viewAngle = 0;
} }
int *generateLandingPoint() int *generateLandingPoint(int rxWall)
{ {
int *landingPoint = malloc(sizeof(int) * 2); int *landingPoint = malloc(sizeof(int) * 2);
int randomLength = rand() % (int)((MAP_WIDTH / 2) * BLOCK_SIZE) + (MAP_WIDTH / 2) * BLOCK_SIZE; srand(time(NULL));
int randomPointX = randomLength * cos(player.angle) + player.x; //printf("wall x :%d=>%d\n", rxWall, rxWall/BLOCK_SIZE);
int randomPointY = randomLength * sin(player.angle) + player.y;
landingPoint[0] = randomPointX / BLOCK_SIZE; int randomPointX = MAP_WIDTH/2 + 1 + rand()%(rxWall/BLOCK_SIZE - (MAP_WIDTH/2));
int randomPointY = -1;
//printf("entre %d et %d\n", MAP_WIDTH/2, MAP_WIDTH/2+rxWall/BLOCK_SIZE - (MAP_WIDTH/2));
//printf("randomPointX: %d => %d\n", randomPointX, randomPointX*BLOCK_SIZE);
landingPoint[0] = randomPointX ;
landingPoint[1] = randomPointY / BLOCK_SIZE; landingPoint[1] = randomPointY / BLOCK_SIZE;
// printf("landing point: %d %d\n", landingPoint[0], landingPoint[1]); landingPointIsFind = 1;
return landingPoint; return landingPoint;
} }
...@@ -59,6 +67,8 @@ void freeIntList(int *list) ...@@ -59,6 +67,8 @@ void freeIntList(int *list)
void hitBall() void hitBall()
{ {
<<<<<<< HEAD
=======
// printf("map edges: %d %d\n", BLOCK_SIZE * MAP_WIDTH/2, BLOCK_SIZE *MAP_HEIGHT/2); // printf("map edges: %d %d\n", BLOCK_SIZE * MAP_WIDTH/2, BLOCK_SIZE *MAP_HEIGHT/2);
// printf("ray1: %d %d\n", ray1[0], ray1[1]); // printf("ray1: %d %d\n", ray1[0], ray1[1]);
int fermetureAngle = 2; int fermetureAngle = 2;
...@@ -72,6 +82,7 @@ void hitBall() ...@@ -72,6 +82,7 @@ void hitBall()
//printf("angle min: %d\n", angleMin); //printf("angle min: %d\n", angleMin);
//printf("angle max: %d\n", angleMax); //printf("angle max: %d\n", angleMax);
//printf("distance to ball: %f\n", sqrt(pow(ball.x - player.x, 2) + pow(ball.y - player.y, 2))/BLOCK_SIZE); //printf("distance to ball: %f\n", sqrt(pow(ball.x - player.x, 2) + pow(ball.y - player.y, 2))/BLOCK_SIZE);
>>>>>>> 0383eb7e8ec1fcd92d8fd2c6846d5e9ab2d08f17
if (sqrt(pow(player.x - ball.x, 2) + pow(player.y - ball.y, 2)) / BLOCK_SIZE < HIT_RANGE) if (sqrt(pow(player.x - ball.x, 2) + pow(player.y - ball.y, 2)) / BLOCK_SIZE < HIT_RANGE)
{ {
int rxWall, ryWall; int rxWall, ryWall;
...@@ -82,39 +93,47 @@ void hitBall() ...@@ -82,39 +93,47 @@ void hitBall()
if (player.isHitting) if (player.isHitting)
{ {
castSingleRay(player.angle, &distanceWall, &distanceNet, &rxWall, &ryWall, &rxNet, &ryNet); castSingleRay(player.angle, &distanceWall, &distanceNet, &rxWall, &ryWall, &rxNet, &ryNet);
printf("rayWall: %d %d\n", rxWall/BLOCK_SIZE, ryWall/BLOCK_SIZE); //printf("rayWall: %d %d\n", rxWall/BLOCK_SIZE, ryWall/BLOCK_SIZE);
printf("distanceWall: %f\n", distanceWall); //printf("distanceWall: %f\n", distanceWall);
<<<<<<< HEAD
//printf("rayNet: %d %d\n", rxNet/BLOCK_SIZE, ryNet/BLOCK_SIZE);
//printf("distanceNet: %f\n", distanceNet);
if (rxWall > MAP_WIDTH/2)
{
if (player.isHitting)
=======
printf("rayNet: %d %d\n", rxNet/BLOCK_SIZE, ryNet/BLOCK_SIZE); printf("rayNet: %d %d\n", rxNet/BLOCK_SIZE, ryNet/BLOCK_SIZE);
printf("distanceNet: %f\n", distanceNet); printf("distanceNet: %f\n", distanceNet);
// printf("hit\n"); // printf("hit\n");
if (rxWall > MAP_WIDTH/2) if (rxWall > MAP_WIDTH/2)
>>>>>>> 0383eb7e8ec1fcd92d8fd2c6846d5e9ab2d08f17
{ {
freeIntList(landingPoint);
freeIntList(lastHitPoint);
freeIntList(lastHitPoint);
lastHitPoint = allocLastHitPoint(); lastHitPoint = allocLastHitPoint();
landingPoint = generateLandingPoint();
//cherche et trouve point de chute, UNE SEULE FOIS!
if(landingPointIsFind == 0){
freeIntList(landingPoint);
landingPoint = generateLandingPoint(rxWall);
printf("landing point: x=%d; y=%d\n", landingPoint[0], landingPoint[1]);
}
lastHitPoint[0] = ball.x; lastHitPoint[0] = ball.x;
lastHitPoint[1] = player.h; lastHitPoint[1] = player.h;
/*ball.x = player.x;
ball.y = player.y;
ball.z = player.h;*/
ball.angle = player.angle; ball.angle = player.angle;
ball.speed = 2 * HIT_FORCE; ball.speed = 2 * HIT_FORCE;
ball.z = player.h; ball.z = player.h;
ball.isHit = 1; ball.isHit = 1;
} }
// printf("valid hit\n");
} }
else else
{ {
// printf("unvalid hit\n"); // printf("unvalid hit\n");
} }
} }
//}
} }
void updateBall() void updateBall()
...@@ -123,6 +142,7 @@ void updateBall() ...@@ -123,6 +142,7 @@ void updateBall()
ball.y = ball.y + ball.speed * sin(ball.angle); ball.y = ball.y + ball.speed * sin(ball.angle);
if (ball.isHit) if (ball.isHit)
{ {
// landingPoint est déjà / BLOCK_SIZE de base // landingPoint est déjà / BLOCK_SIZE de base
ball.z = lagrangeInterpolation(ball.x / BLOCK_SIZE, lastHitPoint[0] / BLOCK_SIZE, lastHitPoint[1] / BLOCK_SIZE, 15, 2 * player.h / BLOCK_SIZE, landingPoint[0], 0); ball.z = lagrangeInterpolation(ball.x / BLOCK_SIZE, lastHitPoint[0] / BLOCK_SIZE, lastHitPoint[1] / BLOCK_SIZE, 15, 2 * player.h / BLOCK_SIZE, landingPoint[0], 0);
if (ball.z > 0) if (ball.z > 0)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment