mapnik/include/mapnik/image_view.hpp

115 lines
2.8 KiB
C++
Raw Normal View History

/*****************************************************************************
2012-02-02 01:53:35 +00:00
*
* This file is part of Mapnik (c++ mapping toolkit)
*
* Copyright (C) 2011 Artem Pavlenko
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
*****************************************************************************/
#ifndef MAPNIK_IMAGE_VIEW_HPP
#define MAPNIK_IMAGE_VIEW_HPP
namespace mapnik {
2012-02-02 01:53:35 +00:00
template <typename T>
class image_view
2010-06-02 11:03:30 +00:00
{
public:
using pixel_type = typename T::pixel_type;
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
image_view(unsigned x, unsigned y, unsigned width, unsigned height, T const& data)
: x_(x),
y_(y),
width_(width),
height_(height),
2012-02-02 01:53:35 +00:00
data_(data)
2010-06-02 11:03:30 +00:00
{
if (x_ >= data_.width()) x_=data_.width()-1;
if (y_ >= data_.height()) y_=data_.height()-1;
2010-06-02 11:03:30 +00:00
if (x_ + width_ > data_.width()) width_= data_.width() - x_;
if (y_ + height_ > data_.height()) height_= data_.height() - y_;
}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
~image_view() {}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
image_view(image_view<T> const& rhs)
: x_(rhs.x_),
y_(rhs.y_),
width_(rhs.width_),
height_(rhs.height_),
data_(rhs.data_) {}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
image_view<T> & operator=(image_view<T> const& rhs)
{
if (&rhs==this) return *this;
x_ = rhs.x_;
y_ = rhs.y_;
width_ = rhs.width_;
height_ = rhs.height_;
data_ = rhs.data_;
2012-07-12 19:00:02 +00:00
return *this;
2010-06-02 11:03:30 +00:00
}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
inline unsigned x() const
{
return x_;
}
2010-06-02 11:03:30 +00:00
inline unsigned y() const
{
return y_;
}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
inline unsigned width() const
{
return width_;
}
2012-07-12 19:00:02 +00:00
2010-06-02 11:03:30 +00:00
inline unsigned height() const
{
return height_;
}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
inline const pixel_type* getRow(unsigned row) const
{
return data_.getRow(row + y_) + x_;
}
2013-09-27 02:29:05 +00:00
inline const unsigned char* getBytes() const
{
2013-09-27 02:29:05 +00:00
return data_.getBytes();
}
2010-06-02 11:03:30 +00:00
inline T& data()
{
return data_;
}
inline T const& data() const
{
return data_;
}
2012-02-02 01:53:35 +00:00
2010-06-02 11:03:30 +00:00
private:
unsigned x_;
unsigned y_;
unsigned width_;
unsigned height_;
T const& data_;
};
}
#endif // MAPNIK_IMAGE_VIEW_HPP