-// $Id: drawing_request.hpp 4986 2007-04-16 17:48:28Z matzeb $
-//
// SuperTux
// Copyright (C) 2006 Matthias Braun <matze@braunis.de>
//
-// 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
// 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.
-#ifndef SUPERTUX_DRAWINGREQUEST_H
-#define SUPERTUX_DRAWINGREQUEST_H
-
-#include <vector>
-#include <string>
-#include <memory>
+// along with this program. If not, see <http://www.gnu.org/licenses/>.
-#include <assert.h>
+#ifndef HEADER_SUPERTUX_VIDEO_DRAWING_REQUEST_HPP
+#define HEADER_SUPERTUX_VIDEO_DRAWING_REQUEST_HPP
-//#include <stdint.h>
+#include <memory>
+#include <string>
+#include <vector>
-//#include <SDL_video.h>
+#include <stdint.h>
-#include "glutil.hpp"
-//#include "math/vector.hpp"
-//#include "color.hpp"
-//#include "font.hpp"
-#include <unison/video/RenderOptions.hpp>
+#include "math/rectf.hpp"
+#include "math/sizef.hpp"
+#include "math/vector.hpp"
+#include "video/color.hpp"
+#include "video/drawing_context.hpp"
+#include "video/font.hpp"
+#include "video/glutil.hpp"
class Surface;
-// some constants for predefined layer values
-enum {
- LAYER_BACKGROUND0 = -300,
- LAYER_BACKGROUND1 = -200,
- LAYER_BACKGROUNDTILES = -100,
- LAYER_TILES = 0,
- LAYER_OBJECTS = 50,
- LAYER_FLOATINGOBJECTS = 150,
- LAYER_FOREGROUNDTILES = 200,
- LAYER_FOREGROUND0 = 300,
- LAYER_FOREGROUND1 = 400,
- LAYER_HUD = 500,
- LAYER_GUI = 600
+enum RequestType
+{
+ SURFACE, SURFACE_PART, TEXT, GRADIENT, FILLRECT, INVERSEELLIPSE, DRAW_LIGHTMAP, GETLIGHT
};
-class Blend
+struct DrawingRequestData
{
-public:
- GLenum sfactor;
- GLenum dfactor;
-
- Blend()
- : sfactor(GL_SRC_ALPHA), dfactor(GL_ONE_MINUS_SRC_ALPHA)
+ virtual ~DrawingRequestData()
{}
+};
- Blend(GLenum s, GLenum d)
- : sfactor(s), dfactor(d)
+struct SurfaceRequest : public DrawingRequestData
+{
+ SurfaceRequest() :
+ surface()
{}
- Unison::Video::BlendMode to_unison_blend() const
- {
- if(sfactor == GL_ONE && dfactor == GL_ZERO)
- {
- return Unison::Video::BLEND_NONE;
- }
- else if(sfactor == GL_SRC_ALPHA && dfactor == GL_ONE_MINUS_SRC_ALPHA)
- {
- return Unison::Video::BLEND_ALPHA;
- }
- else if(sfactor == GL_SRC_ALPHA && dfactor == GL_ONE)
- {
- return Unison::Video::BLEND_ADD;
- }
- else if(sfactor == GL_ZERO && dfactor == GL_SRC_COLOR)
- {
- return Unison::Video::BLEND_MOD;
- }
- else
- {
- assert(0 && "Unsupported blend factors");
- }
- }
-};
+ const Surface* surface;
-enum Target {
- NORMAL, LIGHTMAP
+private:
+ SurfaceRequest(const SurfaceRequest&) = delete;
+ SurfaceRequest& operator=(const SurfaceRequest&) = delete;
};
-/*enum RequestType
+struct SurfacePartRequest : public DrawingRequestData
{
- SURFACE, SURFACE_PART, TEXT, GRADIENT, FILLRECT, GETLIGHT
-};
+ SurfacePartRequest() :
+ surface(),
+ srcrect(),
+ dstsize()
+ {}
-struct SurfacePartRequest
-{
const Surface* surface;
- Vector source, size;
+ Rectf srcrect;
+ Sizef dstsize;
+
+private:
+ SurfacePartRequest(const SurfacePartRequest&) = delete;
+ SurfacePartRequest& operator=(const SurfacePartRequest&) = delete;
};
-struct TextRequest
+struct TextRequest : public DrawingRequestData
{
+ TextRequest() :
+ font(),
+ text(),
+ alignment()
+ {}
+
const Font* font;
std::string text;
FontAlignment alignment;
+
+private:
+ TextRequest(const TextRequest&);
+ TextRequest& operator=(const TextRequest&);
};
-struct GradientRequest
+struct GradientRequest : public DrawingRequestData
{
- Color top, bottom;
+ GradientRequest() :
+ top(),
+ bottom(),
+ size()
+ {}
+
+ Color top;
+ Color bottom;
Vector size;
};
-struct FillRectRequest
+struct FillRectRequest : public DrawingRequestData
{
- Color color;
+ FillRectRequest() :
+ color(),
+ size(),
+ radius()
+ {}
+
+ Color color;
+ Vector size;
+ float radius;
+};
+
+struct InverseEllipseRequest : public DrawingRequestData
+{
+ InverseEllipseRequest() :
+ color(),
+ size()
+ {}
+
+ Color color;
Vector size;
};
float angle;
Color color;
- void* request_data;
-
- DrawingRequest()
- : angle(0.0f),
- color(1.0f, 1.0f, 1.0f, 1.0f)
+ DrawingRequestData* request_data;
+
+ DrawingRequest() :
+ target(),
+ type(),
+ pos(),
+ layer(),
+ drawing_effect(),
+ alpha(),
+ blend(),
+ angle(0.0f),
+ color(1.0f, 1.0f, 1.0f, 1.0f),
+ request_data()
{}
bool operator<(const DrawingRequest& other) const
}
};
-struct GetLightRequest
+struct GetLightRequest : public DrawingRequestData
{
+ GetLightRequest() : color_ptr() {}
+
Color* color_ptr;
-};*/
+
+private:
+ GetLightRequest(const GetLightRequest&) = delete;
+ GetLightRequest& operator=(const GetLightRequest&) = delete;
+};
#endif
+/* EOF */