2 // Copyright (C) 2006 Matthias Braun <matze@braunis.de>
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
17 #ifndef HEADER_SUPERTUX_VIDEO_SURFACE_HPP
18 #define HEADER_SUPERTUX_VIDEO_SURFACE_HPP
23 #include "math/vector.hpp"
24 #include "math/rect.hpp"
25 #include "video/surface_ptr.hpp"
26 #include "video/texture_ptr.hpp"
30 /** A rectangular image. The class basically holds a reference to a
31 texture with additional UV coordinates that specify a rectangular
32 area on this texture */
36 static SurfacePtr create(const std::string& file);
37 static SurfacePtr create(const std::string& file, const Rect& rect);
41 SurfaceData* surface_data;
46 Surface(const std::string& file);
47 Surface(const std::string& file, const Rect& rect);
48 Surface(const Surface&);
53 SurfacePtr clone() const;
55 /** flip the surface horizontally */
57 bool get_flipx() const;
59 TexturePtr get_texture() const;
60 SurfaceData* get_surface_data() const;
63 int get_width() const;
64 int get_height() const;
65 Vector get_position() const;
67 /** returns a vector containing width and height */
68 Vector get_size() const;
71 Surface& operator=(const Surface&);