From c01f67b284db9c987680d121c11df2d9da56e2d0 Mon Sep 17 00:00:00 2001 From: aleksav013 Date: Mon, 7 Jun 2021 16:51:43 +0200 Subject: Smart pointers --- src/Game.cpp | 18 +++++++++--------- src/State.cpp | 32 ++++++++++---------------------- src/includes/Game.hpp | 9 +++++---- src/includes/State.hpp | 8 ++++---- 4 files changed, 28 insertions(+), 39 deletions(-) diff --git a/src/Game.cpp b/src/Game.cpp index c0bad0e..359be55 100644 --- a/src/Game.cpp +++ b/src/Game.cpp @@ -53,13 +53,13 @@ void Game::pwptex() for(size_t i=0;i mainfont,std::map maintex) +Game::Game(std::shared_ptr mainprozor,std::map> mainfont,std::map> maintex) { - prozor=glprozor; + prozor=mainprozor; font=mainfont; tex=maintex; @@ -111,7 +111,7 @@ bool Game::gameover() void Game::updatedt() { dt=sat.restart().asMicroseconds()/1000000.0; - if(dt>1) dt=0; + if(dt>0.5) dt=0; } void Game::updateui() { diff --git a/src/State.cpp b/src/State.cpp index 9e63762..9e20035 100644 --- a/src/State.cpp +++ b/src/State.cpp @@ -11,19 +11,19 @@ State::State() } void State::initwin() { - prozor=new sf::RenderWindow(sf::VideoMode::getFullscreenModes()[0],"RPG igra"); - prozor->setFramerateLimit(60); + prozor=std::make_shared(sf::VideoMode::getFullscreenModes()[0],"RPG igra",sf::Style::Fullscreen); + prozor->setVerticalSyncEnabled(true); visina=prozor->getSize().y; sirina=prozor->getSize().x; } void State::initassets() { - font["default"] = new sf::Font; - tex["neprijatelj"] = new sf::Texture; - tex["health"] = new sf::Texture; - tex["clear"] = new sf::Texture; - tex["vampiric"] = new sf::Texture; - //tex["djule"] = new sf::Texture; + font["default"]=std::make_shared(); + tex["neprijatelj"]=std::make_shared(); + tex["health"]=std::make_shared(); + tex["clear"]=std::make_shared(); + tex["vampiric"]=std::make_shared(); + //tex["djule"]=std::make_shared(); font["default"]->loadFromFile("assets/fonts/LiberationMono-Regular.ttf"); tex["health"]->loadFromFile("assets/images/healing.png"); tex["neprijatelj"]->loadFromFile("assets/images/nep.png"); @@ -108,7 +108,7 @@ void State::updateui() } void State::loop() { - Game *igra=new Game(prozor,font,tex); + std::unique_ptr igra=std::make_unique(prozor,font,tex); while(prozor->isOpen()) { events(); @@ -123,8 +123,7 @@ void State::loop() prozor->draw(krajtext); if(newgame) { - delete igra; - igra=new Game(prozor,font,tex); + igra=std::make_unique(prozor,font,tex); } } if(pause) @@ -138,15 +137,4 @@ void State::loop() ischanged=0; newgame=0; } - delete igra; -} -State::~State() -{ - delete prozor; - delete font["default"]; - delete tex["neprijatelj"]; - delete tex["health"]; - delete tex["clear"]; - delete tex["vampiric"]; - //delete tex["djule"]; } diff --git a/src/includes/Game.hpp b/src/includes/Game.hpp index d893fd8..529b13a 100644 --- a/src/includes/Game.hpp +++ b/src/includes/Game.hpp @@ -7,11 +7,12 @@ #include"Enemy3.hpp" #include"Powerup.hpp" +#include class Game { private: - std::map font; - std::map tex; + std::map> font; + std::map> tex; float dt; sf::Clock sat,time; @@ -22,7 +23,7 @@ class Game std::vector pow; int visina,sirina; - sf::RenderWindow *prozor; + std::shared_ptr prozor; sf::RectangleShape health,healthblank,stomp,stompblank,vampiric,vampiricblank; sf::Text healthtext,stomptext,fps,score,vampirictext; @@ -44,7 +45,7 @@ class Game void initent(); void updatewin(); public: - Game(sf::RenderWindow *glprozor,std::map mainfont,std::map maintex); + Game(std::shared_ptr mainprozor,std::map> mainfont,std::map> maintex); void loop(bool ischanged,bool pause); void draw(); bool gameover(); diff --git a/src/includes/State.hpp b/src/includes/State.hpp index c9dffb9..5623bbf 100644 --- a/src/includes/State.hpp +++ b/src/includes/State.hpp @@ -2,15 +2,16 @@ #define STATE_H #include +#include class State { private: - sf::RenderWindow *prozor; + std::shared_ptr prozor; int visina,sirina; bool ischanged=0,newgame=0,pause=0,kraj=0; - std::map font; - std::map tex; + std::map> font; + std::map> tex; sf::RectangleShape podloga; sf::Text pausetext,krajtext; @@ -23,7 +24,6 @@ class State void keyboard(); public: State(); - ~State(); void loop(); }; -- cgit v1.2.3