|  |  | 
|  | //---------------------------------------------------------------------------- | 
|  | // Anti-Grain Geometry - Version 2.3 | 
|  | // Copyright (C) 2002-2005 Maxim Shemanarev (http://www.antigrain.com) | 
|  | // | 
|  | // Permission to copy, use, modify, sell and distribute this software | 
|  | // is granted provided this copyright notice appears in all copies. | 
|  | // This software is provided "as is" without express or implied | 
|  | // warranty, and with no claim as to its suitability for any purpose. | 
|  | // | 
|  | //---------------------------------------------------------------------------- | 
|  | // Contact: mcseem@antigrain.com | 
|  | //          mcseemagg@yahoo.com | 
|  | //          http://www.antigrain.com | 
|  | //---------------------------------------------------------------------------- | 
|  | // | 
|  | // class renderer_base | 
|  | // | 
|  | //---------------------------------------------------------------------------- | 
|  | #ifndef AGG_RENDERER_BASE_INCLUDED | 
|  | #define AGG_RENDERER_BASE_INCLUDED | 
|  | #include "agg_basics.h" | 
|  | #include "agg_rendering_buffer.h" | 
|  | namespace agg | 
|  | { | 
|  | template<class PixelFormat> class renderer_base | 
|  | { | 
|  | public: | 
|  | typedef PixelFormat pixfmt_type; | 
|  | typedef typename pixfmt_type::color_type color_type; | 
|  | typedef typename pixfmt_type::row_data row_data; | 
|  | typedef typename pixfmt_type::span_data span_data; | 
|  | renderer_base() : m_ren(0), m_clip_box(1, 1, 0, 0) {} | 
|  | renderer_base(pixfmt_type& ren) : | 
|  | m_ren(&ren), | 
|  | m_clip_box(0, 0, ren.width() - 1, ren.height() - 1) | 
|  | {} | 
|  | void attach(pixfmt_type& ren) | 
|  | { | 
|  | m_ren = &ren; | 
|  | m_clip_box = rect(0, 0, ren.width() - 1, ren.height() - 1); | 
|  | } | 
|  | const pixfmt_type& ren() const | 
|  | { | 
|  | return *m_ren; | 
|  | } | 
|  | pixfmt_type& ren() | 
|  | { | 
|  | return *m_ren; | 
|  | } | 
|  | unsigned width()  const | 
|  | { | 
|  | return m_ren->width(); | 
|  | } | 
|  | unsigned height() const | 
|  | { | 
|  | return m_ren->height(); | 
|  | } | 
|  | void first_clip_box() {} | 
|  | bool next_clip_box() | 
|  | { | 
|  | return false; | 
|  | } | 
|  | const rect& clip_box() const | 
|  | { | 
|  | return m_clip_box; | 
|  | } | 
|  | int         xmin()     const | 
|  | { | 
|  | return m_clip_box.x1; | 
|  | } | 
|  | int         ymin()     const | 
|  | { | 
|  | return m_clip_box.y1; | 
|  | } | 
|  | int         xmax()     const | 
|  | { | 
|  | return m_clip_box.x2; | 
|  | } | 
|  | int         ymax()     const | 
|  | { | 
|  | return m_clip_box.y2; | 
|  | } | 
|  | const rect& bounding_clip_box() const | 
|  | { | 
|  | return m_clip_box; | 
|  | } | 
|  | int         bounding_xmin()     const | 
|  | { | 
|  | return m_clip_box.x1; | 
|  | } | 
|  | int         bounding_ymin()     const | 
|  | { | 
|  | return m_clip_box.y1; | 
|  | } | 
|  | int         bounding_xmax()     const | 
|  | { | 
|  | return m_clip_box.x2; | 
|  | } | 
|  | int         bounding_ymax()     const | 
|  | { | 
|  | return m_clip_box.y2; | 
|  | } | 
|  | void blend_hline(int x1, int y, int x2, | 
|  | const color_type& c, cover_type cover) | 
|  | { | 
|  | if(x1 > x2) { | 
|  | int t = x2; | 
|  | x2 = x1; | 
|  | x1 = t; | 
|  | } | 
|  | if(y  > ymax()) { | 
|  | return; | 
|  | } | 
|  | if(y  < ymin()) { | 
|  | return; | 
|  | } | 
|  | if(x1 > xmax()) { | 
|  | return; | 
|  | } | 
|  | if(x2 < xmin()) { | 
|  | return; | 
|  | } | 
|  | if(x1 < xmin()) { | 
|  | x1 = xmin(); | 
|  | } | 
|  | if(x2 > xmax()) { | 
|  | x2 = xmax(); | 
|  | } | 
|  | m_ren->blend_hline(x1, y, x2 - x1 + 1, c, cover); | 
|  | } | 
|  | void blend_solid_hspan(int x, int y, int len, | 
|  | const color_type& c, | 
|  | const cover_type* covers) | 
|  | { | 
|  | if(y > ymax()) { | 
|  | return; | 
|  | } | 
|  | if(y < ymin()) { | 
|  | return; | 
|  | } | 
|  | if(x < xmin()) { | 
|  | len -= xmin() - x; | 
|  | if(len <= 0) { | 
|  | return; | 
|  | } | 
|  | covers += xmin() - x; | 
|  | x = xmin(); | 
|  | } | 
|  | if(x + len > xmax()) { | 
|  | len = xmax() - x + 1; | 
|  | if(len <= 0) { | 
|  | return; | 
|  | } | 
|  | } | 
|  | m_ren->blend_solid_hspan(x, y, len, c, covers); | 
|  | } | 
|  | private: | 
|  | pixfmt_type* m_ren; | 
|  | rect         m_clip_box; | 
|  | }; | 
|  | } | 
|  | #endif |