X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fobject%2Ffireworks.cpp;h=c5ec447af8a71513263575227609d7c9e1cb2083;hb=f2ffe3ee4a4955232ac311c661f98e11d2daa155;hp=62904c5b4c6e23816d99d4dfb6a5fc8cffe2eba2;hpb=5b7f9214cb929399f1a855ef5807018a9447d510;p=supertux.git diff --git a/src/object/fireworks.cpp b/src/object/fireworks.cpp index 62904c5b4..c5ec447af 100644 --- a/src/object/fireworks.cpp +++ b/src/object/fireworks.cpp @@ -1,36 +1,33 @@ -// $Id$ -// // SuperTux -// Copyright (C) 2005 Matthias Braun +// Copyright (C) 2006 Matthias Braun // -// 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 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 3 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; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA -// 02111-1307, USA. -#include +// along with this program. If not, see . -#include "fireworks.hpp" -#include "resources.hpp" -#include "sector.hpp" -#include "camera.hpp" -#include "gameobjs.hpp" -#include "main.hpp" -#include "video/drawing_context.hpp" #include "audio/sound_manager.hpp" +#include "math/random_generator.hpp" +#include "object/camera.hpp" +#include "object/fireworks.hpp" +#include "object/particles.hpp" +#include "supertux/globals.hpp" +#include "supertux/sector.hpp" +#include "video/drawing_context.hpp" -Fireworks::Fireworks() +Fireworks::Fireworks() : + timer() { - timer.start(.2); + timer.start(.2f); + sound_manager->preload("sounds/fireworks.wav"); } Fireworks::~Fireworks() @@ -40,23 +37,29 @@ Fireworks::~Fireworks() void Fireworks::update(float ) { - if(timer.check()) { - Sector* sector = Sector::current(); - Vector pos = sector->camera->get_translation(); - pos += Vector(SCREEN_WIDTH * ((float) rand() / RAND_MAX), - SCREEN_HEIGHT/2 * ((float) rand() / RAND_MAX)); + if(timer.check()) { + Sector* sector = Sector::current(); + Vector pos = sector->camera->get_translation(); + pos += Vector(graphicsRandom.randf(SCREEN_WIDTH), + graphicsRandom.randf(SCREEN_HEIGHT/2)); - int red = rand() % 255; - int green = rand() % red; - sector->add_object(new Particles(pos, 0, 360, Vector(140, 140), - Vector(0, 0), 45, Color(red, green, 0), 3, 1.3, - LAYER_FOREGROUND1+1)); - sound_manager->play("sounds/fireworks.wav"); - timer.start(((float) rand() / RAND_MAX) + .5); - } + float red = graphicsRandom.randf(1.0); + float green = graphicsRandom.randf(1.0); + //float red = 0.7; + //float green = 0.9; + (void) red; + (void) green; + sector->add_object(new Particles(pos, 0, 360, Vector(140, 140), + Vector(0, 0), 45, Color(red, green, 0), 3, 1.3f, + LAYER_FOREGROUND1+1)); + sound_manager->play("sounds/fireworks.wav"); + timer.start(graphicsRandom.randf(1.0, 1.5)); + } } void Fireworks::draw(DrawingContext& ) { } + +/* EOF */