summaryrefslogtreecommitdiff
path: root/agg/inc/agg_span_gouraud_rgba.h
diff options
context:
space:
mode:
Diffstat (limited to 'agg/inc/agg_span_gouraud_rgba.h')
-rwxr-xr-xagg/inc/agg_span_gouraud_rgba.h206
1 files changed, 0 insertions, 206 deletions
diff --git a/agg/inc/agg_span_gouraud_rgba.h b/agg/inc/agg_span_gouraud_rgba.h
deleted file mode 100755
index 75679a9426c2..000000000000
--- a/agg/inc/agg_span_gouraud_rgba.h
+++ /dev/null
@@ -1,206 +0,0 @@
-//----------------------------------------------------------------------------
-// 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
-//----------------------------------------------------------------------------
-//
-// Adaptation for high precision colors has been sponsored by
-// Liberty Technology Systems, Inc., visit http://lib-sys.com
-//
-// Liberty Technology Systems, Inc. is the provider of
-// PostScript and PDF technology for software developers.
-//
-//----------------------------------------------------------------------------
-
-#ifndef AGG_SPAN_GOURAUD_RGBA_INCLUDED
-#define AGG_SPAN_GOURAUD_RGBA_INCLUDED
-
-#include "agg_basics.h"
-#include "agg_color_rgba.h"
-#include "agg_dda_line.h"
-#include "agg_span_gouraud.h"
-
-namespace agg
-{
-
- //=======================================================span_gouraud_rgba
- template<class ColorT, class Allocator = span_allocator<ColorT> >
- class span_gouraud_rgba : public span_gouraud<ColorT, Allocator>
- {
- public:
- typedef Allocator alloc_type;
- typedef ColorT color_type;
- typedef typename ColorT::value_type value_type;
- typedef span_gouraud<color_type, alloc_type> base_type;
- typedef typename base_type::coord_type coord_type;
-
- private:
- //--------------------------------------------------------------------
- struct rgba_calc
- {
- void init(const coord_type& c1, const coord_type& c2)
- {
- m_x1 = c1.x;
- m_y1 = c1.y;
- m_dx = c2.x - c1.x;
- m_dy = 1.0 / (c2.y - c1.y);
- m_r1 = c1.color.r;
- m_g1 = c1.color.g;
- m_b1 = c1.color.b;
- m_a1 = c1.color.a;
- m_dr = c2.color.r - m_r1;
- m_dg = c2.color.g - m_g1;
- m_db = c2.color.b - m_b1;
- m_da = c2.color.a - m_a1;
- }
-
- void calc(int y)
- {
- double k = 0.0;
- if(y > m_y1) k = (y - m_y1) * m_dy;
- color_type rgba;
- m_r = m_r1 + int(m_dr * k);
- m_g = m_g1 + int(m_dg * k);
- m_b = m_b1 + int(m_db * k);
- m_a = m_a1 + int(m_da * k);
- m_x = int(m_x1 + m_dx * k);
- }
-
- double m_x1;
- double m_y1;
- double m_dx;
- double m_dy;
- int m_r1;
- int m_g1;
- int m_b1;
- int m_a1;
- int m_dr;
- int m_dg;
- int m_db;
- int m_da;
- int m_r;
- int m_g;
- int m_b;
- int m_a;
- int m_x;
- };
-
- public:
-
- //--------------------------------------------------------------------
- span_gouraud_rgba(alloc_type& alloc) : base_type(alloc) {}
-
- //--------------------------------------------------------------------
- span_gouraud_rgba(alloc_type& alloc,
- const color_type& c1,
- const color_type& c2,
- const color_type& c3,
- double x1, double y1,
- double x2, double y2,
- double x3, double y3,
- double d = 0) :
- base_type(alloc, c1, c2, c3, x1, y1, x2, y2, x3, y3, d)
- {}
-
- //--------------------------------------------------------------------
- void prepare(unsigned max_span_len)
- {
- base_type::prepare(max_span_len);
-
- coord_type coord[3];
- arrange_vertices(coord);
-
- m_y2 = int(coord[1].y);
-
- m_swap = calc_point_location(coord[0].x, coord[0].y,
- coord[2].x, coord[2].y,
- coord[1].x, coord[1].y) < 0.0;
-
- m_rgba1.init(coord[0], coord[2]);
- m_rgba2.init(coord[0], coord[1]);
- m_rgba3.init(coord[1], coord[2]);
- }
-
- //--------------------------------------------------------------------
- color_type* generate(int x, int y, unsigned len)
- {
- m_rgba1.calc(y);
- const rgba_calc* pc1 = &m_rgba1;
- const rgba_calc* pc2 = &m_rgba2;
-
- if(y < m_y2)
- {
- m_rgba2.calc(y+1);
- }
- else
- {
- m_rgba3.calc(y);
- pc2 = &m_rgba3;
- }
-
- if(m_swap)
- {
- const rgba_calc* t = pc2;
- pc2 = pc1;
- pc1 = t;
- }
-
- int nx = pc1->m_x;
- unsigned nlen = pc2->m_x - pc1->m_x + 1;
-
- if(nlen < len) nlen = len;
-
- dda_line_interpolator<14> r(pc1->m_r, pc2->m_r, nlen);
- dda_line_interpolator<14> g(pc1->m_g, pc2->m_g, nlen);
- dda_line_interpolator<14> b(pc1->m_b, pc2->m_b, nlen);
- dda_line_interpolator<14> a(pc1->m_a, pc2->m_a, nlen);
-
- if(nx < x)
- {
- unsigned d = unsigned(x - nx);
- r += d;
- g += d;
- b += d;
- a += d;
- }
-
- color_type* span = base_type::allocator().span();
- do
- {
- span->r = (value_type)r.y();
- span->g = (value_type)g.y();
- span->b = (value_type)b.y();
- span->a = (value_type)a.y();
- ++r;
- ++g;
- ++b;
- ++a;
- ++span;
- }
- while(--len);
- return base_type::allocator().span();
- }
-
-
- private:
- bool m_swap;
- int m_y2;
- rgba_calc m_rgba1;
- rgba_calc m_rgba2;
- rgba_calc m_rgba3;
- };
-
-
-
-}
-
-#endif