lesson#28 finalized
This commit is contained in:
parent
516fbaba58
commit
dcf19b890e
|
@ -2,8 +2,8 @@ module app;
|
||||||
|
|
||||||
import game.data;
|
import game.data;
|
||||||
import game.gstatemanager;
|
import game.gstatemanager;
|
||||||
import game.menu;
|
import game.state.menu;
|
||||||
import game.play;
|
import game.state.play;
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
validateRaylibBinding();
|
validateRaylibBinding();
|
||||||
|
|
|
@ -0,0 +1,62 @@
|
||||||
|
module game.animation.animation;
|
||||||
|
|
||||||
|
import raylib;
|
||||||
|
|
||||||
|
struct Animation {
|
||||||
|
private {
|
||||||
|
Texture2D texture;
|
||||||
|
Rectangle[] rectFrames;
|
||||||
|
int numFrames;
|
||||||
|
int currentFrame;
|
||||||
|
float frameTimeSecs;
|
||||||
|
float frameTimeSecsLeft;
|
||||||
|
bool isActive;
|
||||||
|
}
|
||||||
|
|
||||||
|
this(in Texture2D texture, in int numFrames, in float frameTimeSecs) {
|
||||||
|
this.texture = texture;
|
||||||
|
this.numFrames = numFrames;
|
||||||
|
this.frameTimeSecs = frameTimeSecs;
|
||||||
|
this.frameTimeSecsLeft = frameTimeSecs;
|
||||||
|
this.currentFrame = 0;
|
||||||
|
this.isActive = true;
|
||||||
|
|
||||||
|
// create rectangle frames
|
||||||
|
immutable frameWidth = texture.width / numFrames;
|
||||||
|
immutable frameHeight = texture.height;
|
||||||
|
foreach(i; 0 .. numFrames) {
|
||||||
|
this.rectFrames ~= Rectangle(i * frameWidth, frameHeight, frameWidth, frameHeight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void start() {
|
||||||
|
isActive = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void stop() {
|
||||||
|
isActive = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void reset() {
|
||||||
|
currentFrame = 0;
|
||||||
|
frameTimeSecsLeft = frameTimeSecs;
|
||||||
|
}
|
||||||
|
|
||||||
|
void update() {
|
||||||
|
if(!isActive) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
frameTimeSecsLeft -= GetFrameTime();
|
||||||
|
if(frameTimeSecsLeft <= 0) {
|
||||||
|
frameTimeSecsLeft += frameTimeSecs;
|
||||||
|
currentFrame = (currentFrame + 1) % numFrames;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void draw(in Vector2 position) {
|
||||||
|
DrawTextureRec(texture, rectFrames[currentFrame], position, Colors.WHITE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ class Entity {
|
||||||
Rectangle frame;
|
Rectangle frame;
|
||||||
Vector2 position;
|
Vector2 position;
|
||||||
|
|
||||||
this(in Texture2D texture, in Rectangle frame, in Vector2 Position) {
|
this(in Texture2D texture, in Rectangle frame, in Vector2 position) {
|
||||||
this.texture = texture;
|
this.texture = texture;
|
||||||
this.frame = frame;
|
this.frame = frame;
|
||||||
this.position = position;
|
this.position = position;
|
||||||
|
|
|
@ -0,0 +1,27 @@
|
||||||
|
module game.entity.coin;
|
||||||
|
|
||||||
|
import game.data;
|
||||||
|
import game.animation.animation;
|
||||||
|
|
||||||
|
class Coin: Entity {
|
||||||
|
private {
|
||||||
|
Animation animation;
|
||||||
|
}
|
||||||
|
|
||||||
|
this(in Texture2D texture, in Rectangle frame, in Vector2 position) {
|
||||||
|
super(texture, frame, position);
|
||||||
|
|
||||||
|
animation = Animation(texture, 5, 0.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
override void update() {
|
||||||
|
animation.update();
|
||||||
|
}
|
||||||
|
|
||||||
|
override void processEvents() {}
|
||||||
|
|
||||||
|
override void draw() {
|
||||||
|
animation.draw(position);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
module game.player;
|
module game.entity.player;
|
||||||
|
|
||||||
import game.data;
|
import game.data;
|
||||||
|
|
||||||
class Player: Entity {
|
class Player: Entity {
|
||||||
this(const ref Texture2D texture, const Rectangle frame, const Vector2 position) {
|
this(in Texture2D texture, in Rectangle frame, in Vector2 position) {
|
||||||
super(texture, frame, position);
|
super(texture, frame, position);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
module game.menu;
|
module game.state.menu;
|
||||||
|
|
||||||
import game.data;
|
import game.data;
|
||||||
import game.gstatemanager;
|
import game.gstatemanager;
|
|
@ -1,8 +1,9 @@
|
||||||
module game.play;
|
module game.state.play;
|
||||||
|
|
||||||
import game.data;
|
import game.data;
|
||||||
import game.gstatemanager;
|
import game.gstatemanager;
|
||||||
import game.player;
|
import game.entity.player;
|
||||||
|
import game.entity.coin;
|
||||||
|
|
||||||
import std.file: getcwd;
|
import std.file: getcwd;
|
||||||
import std.path: buildPath;
|
import std.path: buildPath;
|
||||||
|
@ -11,19 +12,24 @@ import std.string: toStringz;
|
||||||
class Play: IState {
|
class Play: IState {
|
||||||
// variables
|
// variables
|
||||||
private {
|
private {
|
||||||
Texture2D texPlayer;
|
Texture2D texPlayer, texCoin;
|
||||||
Player player;
|
Player player;
|
||||||
|
Coin coin;
|
||||||
}
|
}
|
||||||
|
|
||||||
this() {
|
this() {
|
||||||
texPlayer = LoadTexture(getcwd.buildPath("../../assets/Evil Wizard/Evil Wizard.png").toStringz);
|
// player
|
||||||
player = new Player(texPlayer, Rectangle(75, 75, 125, 125), Vector2(0, 0));
|
texPlayer = LoadTexture(getcwd.buildPath("../../assets/spritesheets/player/woodcutter/Woodcutter.png").toStringz);
|
||||||
// texPlayer = LoadTexture(getcwd.buildPath("../../assets/fire/png/blue/loops/burning_loop_1_144x192.png").toStringz);
|
player = new Player(texPlayer, Rectangle(0, 0, 48, 48), Vector2(0, 0));
|
||||||
// player = new Player(texPlayer, Rectangle(0, 0, 144, 192), Vector2(0, 0));
|
|
||||||
|
// coin
|
||||||
|
texCoin = LoadTexture(getcwd.buildPath("../../assets/spritesheets/coins/MonedaD.png").toStringz);
|
||||||
|
coin = new Coin(texCoin, Rectangle(0, 0, 16, 16), Vector2(0, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
~this() {
|
~this() {
|
||||||
UnloadTexture(texPlayer);
|
UnloadTexture(texPlayer);
|
||||||
|
UnloadTexture(texCoin);
|
||||||
}
|
}
|
||||||
|
|
||||||
// inherited from IState interface
|
// inherited from IState interface
|
||||||
|
@ -35,6 +41,7 @@ class Play: IState {
|
||||||
|
|
||||||
void update() {
|
void update() {
|
||||||
player.update();
|
player.update();
|
||||||
|
coin.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
void processEvents() {
|
void processEvents() {
|
||||||
|
@ -50,9 +57,10 @@ class Play: IState {
|
||||||
BeginDrawing(); scope(exit) { EndDrawing(); }
|
BeginDrawing(); scope(exit) { EndDrawing(); }
|
||||||
|
|
||||||
// clear background
|
// clear background
|
||||||
ClearBackground(Colors.YELLOW);
|
ClearBackground(Colors.GRAY);
|
||||||
|
|
||||||
// draw
|
// draw
|
||||||
player.draw();
|
player.draw();
|
||||||
|
coin.draw();
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue