From 7872dfb95de823b40233ab6364e10507263f973d Mon Sep 17 00:00:00 2001 From: Alexander Sulfrian Date: Sun, 25 Apr 2010 18:13:16 +0200 Subject: added main application added makefile added main function (src/main.cpp) added Application-class with sdl initialisation and main loop added log4cxx.xml configuration for main application adjusted .gitignore --- .gitignore | 4 +- Makefile | 42 ++++++++++++++ log4cxx.xml | 42 ++++++++++++++ src/main.cpp | 36 ++++++++++++ src/menu/application.cpp | 139 +++++++++++++++++++++++++++++++++++++++++++++++ src/menu/application.hpp | 79 +++++++++++++++++++++++++++ 6 files changed, 341 insertions(+), 1 deletion(-) create mode 100644 Makefile create mode 100644 log4cxx.xml create mode 100644 src/main.cpp create mode 100644 src/menu/application.cpp create mode 100644 src/menu/application.hpp diff --git a/.gitignore b/.gitignore index daa63a09..e38a2894 100644 --- a/.gitignore +++ b/.gitignore @@ -15,10 +15,12 @@ Thumbs.db *.bdsproj.local *.bak *~ -Makefile config.log config.status __history aclocal.m4 autom4te.cache/ coverage/ +usdx +test/ +debug.log diff --git a/Makefile b/Makefile new file mode 100644 index 00000000..9d5c27a7 --- /dev/null +++ b/Makefile @@ -0,0 +1,42 @@ +PROJECT:=usdx +TOP:=. + +headers:=$(wildcard $(TOP)/src/*/*/*.hpp) $(wildcard $(TOP)/src/*/*.hpp) $(wildcard $(TOP)/src/*.hpp) + +sources:=$(wildcard $(TOP)/src/*/*/*.cpp) $(wildcard $(TOP)/src/*/*.cpp) $(wildcard $(TOP)/src/*.cpp) + +deps:=$(sources:.cpp=.d) + +CXXFLAGS:=-Wall -Werror -I$(TOP)/src -I$(TOP)/src/base -I$(TOP)/src/menu -I$(TOP)/src/media -I$(TOP)/src/screens -g +LDFLAGS:=-lsqlite3 -lSDL -llog4cxx -lboost_program_options-mt -lboost_filesystem-mt -lSDL_image -lSDL_gfx -lcppunit -lGL +TARGET:=$(PROJECT) + +objects:=$(sources:.cpp=.o) + +############################################################################## + +.PHONY: all clean run + +all: $(TARGET) + +clean: + -$(RM) -r $(TARGET) $(TARGET-COVERAGE) $(objects) $(deps) $(coverage) + +run: $(TARGET) + ./$(TARGET) + +ifneq ($(MAKECMDGOALS),clean) +-include $(deps) +endif + +############################################################################## +# normal build + +$(TARGET): $(objects) $(deps) + $(CXX) $(LDFLAGS) -o $(TARGET) $(objects) + +%.o: %.cpp + $(CXX) $(CXXFLAGS) -MMD -c $< -o $@ + +%.d: %.cpp + $(CXX) $(CXXFLAGS) -MM -c $< -MF $@ diff --git a/log4cxx.xml b/log4cxx.xml new file mode 100644 index 00000000..75daba46 --- /dev/null +++ b/log4cxx.xml @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main.cpp b/src/main.cpp new file mode 100644 index 00000000..83fa8298 --- /dev/null +++ b/src/main.cpp @@ -0,0 +1,36 @@ +/* + * UltraStar Deluxe - Karaoke Game + * + * UltraStar Deluxe is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + * + * $URL$ + * $Id$ + */ + +#include "application.hpp" +#include + +int main (int argc, char** argv) +{ + usdx::Application::get_instance()->run(); + delete usdx::Application::get_instance(); + + return EXIT_SUCCESS; +} diff --git a/src/menu/application.cpp b/src/menu/application.cpp new file mode 100644 index 00000000..d36e10b3 --- /dev/null +++ b/src/menu/application.cpp @@ -0,0 +1,139 @@ +/* + * UltraStar Deluxe - Karaoke Game + * + * UltraStar Deluxe is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + * + * $URL$ + * $Id$ + */ + +#include "application.hpp" +#include + +namespace usdx +{ + log4cxx::LoggerPtr Application::log = + log4cxx::Logger::getLogger("usdx.menu.application"); + + Application* Application::instance = NULL; + + Application::Application(Control* parent) + : DrawableControl(parent), display(NULL), frame(NULL), + running(false), display_width(800), display_height(600) + { + SDL_Init(SDL_INIT_VIDEO | SDL_INIT_AUDIO); + + fps_manager = new FPSmanager(); + } + + Application::~Application() + { + if (fps_manager) { + delete fps_manager; + fps_manager = NULL; + } + + SDL_Quit(); + } + + Application* Application::get_instance(void) + { + if (! instance) { + instance = new Application(NULL); + } + + return instance; + } + + void Application::draw(SDL_Surface* screen) const + { + if (frame) { + frame->repaint(screen); + } + } + + const Frame *Application::get_current_frame(void) const + { + return frame; + } + + void Application::set_current_frame(Frame* new_frame) + { + frame = new_frame; + repaint(display); + } + + void Application::main_loop(SDL_Surface* display) + { + SDL_Event event; + + running = true; + while (running) { + // repaint everything + repaint(display); + SDL_Flip(display); + + LOG4CXX_ERROR(log, L"repaint"); + + // poll current events + while (SDL_PollEvent(&event)) { + switch (event.type) { + case SDL_QUIT: + running = false; + return; + } + } + + // limit frames + SDL_framerateDelay(fps_manager); + } + } + + void Application::run(void) + { + if (! display) { + display = SDL_SetVideoMode(display_width, + display_height, + 24, + SDL_SWSURFACE | + SDL_DOUBLEBUF); + } + + if (! display) { + LOG4CXX_ERROR(log, L"SDL_SetVideoMode failed."); + throw new std::exception(); + } + + SDL_initFramerate(fps_manager); + SDL_setFramerate(fps_manager, 50); + + main_loop(display); + } + + const int Application::get_display_width(void) const + { + return display_width; + } + + const int Application::get_display_height(void) const + { + return display_height; + } +}; diff --git a/src/menu/application.hpp b/src/menu/application.hpp new file mode 100644 index 00000000..b750241a --- /dev/null +++ b/src/menu/application.hpp @@ -0,0 +1,79 @@ +/* + * UltraStar Deluxe - Karaoke Game + * + * UltraStar Deluxe is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + * + * $URL$ + * $Id$ + */ + +#ifndef APPLICATION_HPP +#define APPLICATION_HPP + +#include +#include +#include + +#include "drawable_control.hpp" +#include "frame.hpp" + +namespace usdx +{ + class Application : public DrawableControl + { + private: + static log4cxx::LoggerPtr log; + static Application* instance; + + SDL_Surface* display; + Frame* frame; + FPSmanager* fps_manager; + + bool running; + + int display_width; + int display_height; + + /** + * This is the main loop. + */ + void main_loop(SDL_Surface* display); + + protected: + Application(Control* parent); + + void draw(SDL_Surface* screen) const; + + public: + virtual ~Application(); + + static Application* get_instance(void); + + void run(void); + + const Frame* get_current_frame(void) const; + void set_current_frame(Frame* new_frame); + + const int get_display_width(void) const; + const int get_display_height(void) const; + }; +}; + +#endif -- cgit v1.2.3