agg_renderer_base.h

来自「这是VCF框架的代码」· C头文件 代码 · 共 551 行 · 第 1/2 页

H
551
字号
//----------------------------------------------------------------------------// Anti-Grain Geometry - Version 2.4// 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{    //-----------------------------------------------------------renderer_base    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;        //--------------------------------------------------------------------        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_i(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(); }        //--------------------------------------------------------------------        bool clip_box(int x1, int y1, int x2, int y2)        {            rect_i cb(x1, y1, x2, y2);            cb.normalize();            if(cb.clip(rect_i(0, 0, width() - 1, height() - 1)))            {                m_clip_box = cb;                return true;            }            m_clip_box.x1 = 1;            m_clip_box.y1 = 1;            m_clip_box.x2 = 0;            m_clip_box.y2 = 0;            return false;        }        //--------------------------------------------------------------------        void reset_clipping(bool visibility)        {            if(visibility)            {                m_clip_box.x1 = 0;                m_clip_box.y1 = 0;                m_clip_box.x2 = width() - 1;                m_clip_box.y2 = height() - 1;            }            else            {                m_clip_box.x1 = 1;                m_clip_box.y1 = 1;                m_clip_box.x2 = 0;                m_clip_box.y2 = 0;            }        }        //--------------------------------------------------------------------        void clip_box_naked(int x1, int y1, int x2, int y2)        {            m_clip_box.x1 = x1;            m_clip_box.y1 = y1;            m_clip_box.x2 = x2;            m_clip_box.y2 = y2;        }        //--------------------------------------------------------------------        bool inbox(int x, int y) const        {            return x >= m_clip_box.x1 && y >= m_clip_box.y1 &&                   x <= m_clip_box.x2 && y <= m_clip_box.y2;        }        //--------------------------------------------------------------------        const rect_i& 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_i& 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 clear(const color_type& c)        {            unsigned y;            if(width())            {                for(y = 0; y < height(); y++)                {                    m_ren->copy_hline(0, y, width(), c);                }            }        }                  //--------------------------------------------------------------------        void copy_pixel(int x, int y, const color_type& c)        {            if(inbox(x, y))            {                m_ren->copy_pixel(x, y, c);            }        }        //--------------------------------------------------------------------        void blend_pixel(int x, int y, const color_type& c, cover_type cover)        {            if(inbox(x, y))            {                m_ren->blend_pixel(x, y, c, cover);            }        }        //--------------------------------------------------------------------        color_type pixel(int x, int y) const        {            return inbox(x, y) ?                    m_ren->pixel(x, y) :                   color_type::no_color();        }        //--------------------------------------------------------------------        void copy_hline(int x1, int y, int x2, const color_type& c)        {            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->copy_hline(x1, y, x2 - x1 + 1, c);        }        //--------------------------------------------------------------------        void copy_vline(int x, int y1, int y2, const color_type& c)        {            if(y1 > y2) { int t = y2; y2 = y1; y1 = t; }            if(x  > xmax()) return;            if(x  < xmin()) return;            if(y1 > ymax()) return;            if(y2 < ymin()) return;            if(y1 < ymin()) y1 = ymin();            if(y2 > ymax()) y2 = ymax();            m_ren->copy_vline(x, y1, y2 - y1 + 1, c);        }        //--------------------------------------------------------------------        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_vline(int x, int y1, int y2,                          const color_type& c, cover_type cover)        {            if(y1 > y2) { int t = y2; y2 = y1; y1 = t; }            if(x  > xmax()) return;            if(x  < xmin()) return;            if(y1 > ymax()) return;            if(y2 < ymin()) return;            if(y1 < ymin()) y1 = ymin();            if(y2 > ymax()) y2 = ymax();            m_ren->blend_vline(x, y1, y2 - y1 + 1, c, cover);        }        //--------------------------------------------------------------------        void copy_bar(int x1, int y1, int x2, int y2, const color_type& c)        {            rect_i rc(x1, y1, x2, y2);            rc.normalize();            if(rc.clip(clip_box()))            {                int y;                for(y = rc.y1; y <= rc.y2; y++)                {                    m_ren->copy_hline(rc.x1, y, unsigned(rc.x2 - rc.x1 + 1), c);                }            }        }        //--------------------------------------------------------------------        void blend_bar(int x1, int y1, int x2, int y2,                        const color_type& c, cover_type cover)        {            rect_i rc(x1, y1, x2, y2);            rc.normalize();            if(rc.clip(clip_box()))            {                int y;                for(y = rc.y1; y <= rc.y2; y++)                {                    m_ren->blend_hline(rc.x1,                                       y,                                       unsigned(rc.x2 - rc.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())

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?