aboutsummaryrefslogtreecommitdiff
path: root/src/levels/level1.c
blob: 06bd5181e551add77b4c129d731bff0523c61c9c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include "level1.h"
#include "game.h"
#include "world.h"
#include "entity.h"
#include "entitiesInclude.h"

void initLevel1(Game * game, Levels * levels) {
    int i;

	levels->data = KF_MALLOC(sizeof(Level1));

	if (levels->data == NULL) {
		ALLOCATION_ERROR;
		return;
	}

	Level1 * data = (Level1*)levels->data;
	data->stage = 0;

	WorldEntry entries[] = {
		(WorldEntry){ENTITY_ANTIFA, (Vector3){0.0, 0.0, 0.0}, QuaternionIdentity()},
		(WorldEntry){ENTITY_SOLDATO, (Vector3){0.0, 10.0, 800.0}, QuaternionIdentity()}
	};

    addEntriesToWorld(
		&game->world,
		game,
		entries,
		sizeof(entries) / sizeof(WorldEntry)
	);
}

void closelevel1(Levels * levels) {
	if (levels->data != NULL)
		KF_FREE(levels->data);
}

bool updateLevel1(Game * game, Levels * levels) {
	int i;
	Level1 * data = (Level1*)levels->data;
	Entity * player = getEntityFromWorld(game->world, 0);
	bool levelDone = false;

	switch (data->stage) {
		case 0:
			// Next stage
			if (game->world.entitiesCount == 1) {
				Vector3 position = Vector3Add(player->position, (Vector3){0.0, 0.0, 1000.0});
				Vector3 spacing = (Vector3){0.0, 10.0, 10.0};
				addSoldatoGroupToWorld(game, 10, position, spacing);

				data->stage = 1;
			}

			break;
		case 1:
			if (game->world.entitiesCount == 1)
				levelDone = true;

			break;
		default:
			levelDone = true;
			break;
	}

    return levelDone;
}