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 #include "video/surface.hpp"
23 #include "video/texture.hpp"
24 #include "video/video_systems.hpp"
27 Surface::create(const std::string& file)
29 return SurfacePtr(new Surface(file));
33 Surface::create(const std::string& file, const Rect& rect)
35 return SurfacePtr(new Surface(file, rect));
38 Surface::Surface(const std::string& file) :
39 texture(texture_manager->get(file)),
42 Size(texture->get_image_width(),
43 texture->get_image_height())),
46 surface_data = VideoSystem::new_surface_data(*this);
49 Surface::Surface(const std::string& file, const Rect& rect_) :
50 texture(texture_manager->get(file, rect_)),
52 rect(0, 0, Size(rect_.get_width(), rect_.get_height())),
55 surface_data = VideoSystem::new_surface_data(*this);
58 Surface::Surface(const Surface& rhs) :
64 surface_data = VideoSystem::new_surface_data(*this);
69 VideoSystem::free_surface_data(surface_data);
73 Surface::clone() const
75 SurfacePtr surface(new Surface(*this));
79 /** flip the surface horizontally */
85 bool Surface::get_flipx() const
91 Surface::get_texture() const
97 Surface::get_surface_data() const
103 Surface::get_x() const
109 Surface::get_y() const
115 Surface::get_width() const
117 return rect.get_width();
121 Surface::get_height() const
123 return rect.get_height();
127 Surface::get_position() const
129 return Vector(get_x(), get_y());
133 Surface::get_size() const
135 return Vector(get_width(), get_height());