fix r,g,b ordering in 555 antigrain renderer

This commit is contained in:
zeromus 2009-07-12 04:13:22 +00:00
parent c87812a0db
commit 7365c9e6ea
1 changed files with 142 additions and 98 deletions

View File

@ -65,6 +65,8 @@
namespace agg namespace agg
{ {
//NOTE - these blenders are necessary to change the rgb order from the defaults, which are incorrect for us
//this custom blender does more correct blending math than the default //this custom blender does more correct blending math than the default
//which is necessary or else drawing transparent pixels on (31,31,31) will yield (30,30,30) //which is necessary or else drawing transparent pixels on (31,31,31) will yield (30,30,30)
struct my_blender_rgb555_pre struct my_blender_rgb555_pre
@ -82,35 +84,77 @@ namespace agg
//not sure whether this is right... //not sure whether this is right...
alpha = color_type::base_mask - alpha; alpha = color_type::base_mask - alpha;
pixel_type rgb = *p; pixel_type rgb = *p;
calc_type r = (rgb >> 10) & 31; calc_type b = (rgb >> 10) & 31;
calc_type g = (rgb >> 5) & 31; calc_type g = (rgb >> 5) & 31;
calc_type b = (rgb ) & 31; calc_type r = (rgb ) & 31;
r = ((r+1)*(alpha+1) + (cr)*(cover)-1)>>8; b = ((r+1)*(alpha+1) + (cb)*(cover)-1)>>8;
g = ((g+1)*(alpha+1) + (cg)*(cover)-1)>>8; g = ((g+1)*(alpha+1) + (cg)*(cover)-1)>>8;
b = ((b+1)*(alpha+1) + (cb)*(cover)-1)>>8; r = ((b+1)*(alpha+1) + (cr)*(cover)-1)>>8;
*p = (r<<10)|(g<<5)|b; *p = (b<<10)|(g<<5)|r;
} }
static AGG_INLINE pixel_type make_pix(unsigned r, unsigned g, unsigned b) static AGG_INLINE pixel_type make_pix(unsigned r, unsigned g, unsigned b)
{ {
return (pixel_type)(((r & 0xF8) << 7) | return (pixel_type)(((b & 0xF8) << 7) |
((g & 0xF8) << 2) | ((g & 0xF8) << 2) |
(b >> 3) | 0x8000); (r >> 3) | 0x8000);
} }
static AGG_INLINE color_type make_color(pixel_type p) static AGG_INLINE color_type make_color(pixel_type p)
{ {
return color_type((p >> 7) & 0xF8, return color_type((p << 3) & 0xF8,
(p >> 2) & 0xF8, (p >> 2) & 0xF8,
(p << 3) & 0xF8); (p >> 7) & 0xF8);
} }
}; };
struct my_blender_rgb555
{
typedef rgba8 color_type;
typedef color_type::value_type value_type;
typedef color_type::calc_type calc_type;
typedef int16u pixel_type;
static AGG_INLINE void blend_pix(pixel_type* p,
unsigned cr, unsigned cg, unsigned cb,
unsigned alpha,
unsigned)
{
pixel_type rgb = *p;
calc_type b = (rgb >> 7) & 0xF8;
calc_type g = (rgb >> 2) & 0xF8;
calc_type r = (rgb << 3) & 0xF8;
*p = (pixel_type)
(((((cb - b) * alpha + (b << 8)) >> 1) & 0x7C00) |
((((cg - g) * alpha + (g << 8)) >> 6) & 0x03E0) |
(((cr - r) * alpha + (r << 8)) >> 11) | 0x8000);
}
static AGG_INLINE pixel_type make_pix(unsigned r, unsigned g, unsigned b)
{
return (pixel_type)(((b & 0xF8) << 7) |
((g & 0xF8) << 2) |
(r >> 3) | 0x8000);
}
static AGG_INLINE color_type make_color(pixel_type p)
{
return color_type((p << 3) & 0xF8,
(p >> 2) & 0xF8,
(p >> 7) & 0xF8);
}
};
typedef pixfmt_alpha_blend_rgb_packed<my_blender_rgb555_pre, rendering_buffer> my_pixfmt_rgb555_pre; //----pixfmt_rgb555_pre typedef pixfmt_alpha_blend_rgb_packed<my_blender_rgb555_pre, rendering_buffer> my_pixfmt_rgb555_pre; //----pixfmt_rgb555_pre
typedef pixfmt_alpha_blend_rgb_packed<my_blender_rgb555, rendering_buffer> my_pixfmt_rgb555; //----pixfmt_rgb555_pre
} }
typedef std::map<std::string, const agg::int8u*> TAgg_Font_Table; typedef std::map<std::string, const agg::int8u*> TAgg_Font_Table;
static TAgg_Font_Table font_table; static TAgg_Font_Table font_table;
@ -173,7 +217,7 @@ static void Agg_init_fonts()
AggDraw_Desmume aggDraw; AggDraw_Desmume aggDraw;
typedef AggDrawTargetImplementation<PixFormatSetDeclaration<agg::pixfmt_rgb555,agg::my_pixfmt_rgb555_pre> > T_AGG_RGB555; typedef AggDrawTargetImplementation<PixFormatSetDeclaration<agg::my_pixfmt_rgb555,agg::my_pixfmt_rgb555_pre> > T_AGG_RGB555;
typedef AggDrawTargetImplementation<PixFormatSetDeclaration<agg::pixfmt_bgra32,agg::pixfmt_bgra32_pre> > T_AGG_RGBA; typedef AggDrawTargetImplementation<PixFormatSetDeclaration<agg::pixfmt_bgra32,agg::pixfmt_bgra32_pre> > T_AGG_RGBA;
T_AGG_RGB555 agg_targetScreen(GPU_screen, 256, 384, 512); T_AGG_RGB555 agg_targetScreen(GPU_screen, 256, 384, 512);
@ -230,99 +274,99 @@ void AggDraw_Desmume::setTarget(AggTarget newTarget)
// } // }
//} //}
//temporary, just for testing the lib ////temporary, just for testing the lib
//void AGGDraw() { //void AGGDraw() {
////
// aggDraw.setTarget(AggTarget_Screen);
// //
// aggDraw.setTarget(AggTarget_Lua); //// aggDraw.target->clear();
// ////
// aggDraw.target->clear(); //// aggDraw.target->clipBox(0,0,255,383);
// ////
// aggDraw.target->clipBox(0,0,255,383); // aggDraw.target->lineColor(0, 0, 255, 128);
// // aggDraw.target->fillColor(0, 0, 255, 128);
// aggDraw.target->lineColor(0, 255, 0, 128); //// //aggDraw.target->noFill();
// aggDraw.target->fillColor(0, 255, 0, 128);
// //aggDraw.target->noFill();
// aggDraw.target->lineWidth(1.0); // aggDraw.target->lineWidth(1.0);
// aggDraw.target->roundedRect(10,30,256-10,192-10,4); // aggDraw.target->roundedRect(10,30,256-10,192-10,4);
// ////
// aggDraw.target->setFont("verdana18_bold"); //// aggDraw.target->setFont("verdana18_bold");
// aggDraw.target->renderText(60,60, "testing testing testing"); //// aggDraw.target->renderText(60,60, "testing testing testing");
// ////
// // Gradients (Aqua Buttons) //// // Gradients (Aqua Buttons)
// //======================================= //// //=======================================
//// m_graphics.font("Verdana", 20.0, false, false, TAGG2D::VectorFontCache); ////// m_graphics.font("Verdana", 20.0, false, false, TAGG2D::VectorFontCache);
// double xb1 = 10; //// double xb1 = 10;
// double yb1 = 80; //// double yb1 = 80;
// double xb2 = xb1 + 150; //// double xb2 = xb1 + 150;
// double yb2 = yb1 + 36; //// double yb2 = yb1 + 36;
// ////
// aggDraw.target->fillColor(0,50,180,180); //// aggDraw.target->fillColor(0,50,180,180);
// aggDraw.target->lineColor(0,0,80, 255); //// aggDraw.target->lineColor(0,0,80, 255);
// aggDraw.target->lineWidth(1.0); //// aggDraw.target->lineWidth(1.0);
// aggDraw.target->roundedRect(xb1, yb1, xb2, yb2, 12, 18); //// aggDraw.target->roundedRect(xb1, yb1, xb2, yb2, 12, 18);
// ////
// aggDraw.target->lineColor(0,0,0,0); //// aggDraw.target->lineColor(0,0,0,0);
// aggDraw.target->fillLinearGradient(xb1, yb1, xb1, yb1+30, //// aggDraw.target->fillLinearGradient(xb1, yb1, xb1, yb1+30,
// agg::rgba8(100,200,255,255), //// agg::rgba8(100,200,255,255),
// agg::rgba8(255,255,255,0)); //// agg::rgba8(255,255,255,0));
// aggDraw.target->roundedRect(xb1+3, yb1+2.5, xb2-3, yb1+30, 9, 18, 1, 1); //// aggDraw.target->roundedRect(xb1+3, yb1+2.5, xb2-3, yb1+30, 9, 18, 1, 1);
// ////
// aggDraw.target->fillColor(0,0,50, 200); //// aggDraw.target->fillColor(0,0,50, 200);
// aggDraw.target->noLine(); //// aggDraw.target->noLine();
///* m_graphics.textAlignment(TAGG2D::AlignCenter, TAGG2D::AlignCenter); /////* m_graphics.textAlignment(TAGG2D::AlignCenter, TAGG2D::AlignCenter);
// m_graphics.text((xb1 + xb2) / 2.0, (yb1 + yb2) / 2.0, "Aqua Button", true, 0.0, 0.0); //// m_graphics.text((xb1 + xb2) / 2.0, (yb1 + yb2) / 2.0, "Aqua Button", true, 0.0, 0.0);
//*/ ////*/
// aggDraw.target->fillLinearGradient(xb1, yb2-20, xb1, yb2-3, //// aggDraw.target->fillLinearGradient(xb1, yb2-20, xb1, yb2-3,
// agg::rgba8(0, 0, 255,0), //// agg::rgba8(0, 0, 255,0),
// agg::rgba8(100,255,255,255)); //// agg::rgba8(100,255,255,255));
// aggDraw.target->roundedRect(xb1+3, yb2-20, xb2-3, yb2-2, 1, 1, 9, 18); //// aggDraw.target->roundedRect(xb1+3, yb2-20, xb2-3, yb2-2, 1, 1, 9, 18);
// ////
// // Basic Shapes -- Ellipse //// // Basic Shapes -- Ellipse
// //=========================================== //// //===========================================
// aggDraw.target->lineWidth(3.5); //// aggDraw.target->lineWidth(3.5);
// aggDraw.target->lineColor(20, 80, 80); //// aggDraw.target->lineColor(20, 80, 80);
// aggDraw.target->fillColor(200, 255, 80, 200); //// aggDraw.target->fillColor(200, 255, 80, 200);
// aggDraw.target->ellipse(150, 200, 50, 90); //// aggDraw.target->ellipse(150, 200, 50, 90);
// ////
// // Paths //// // Paths
// //=========================================== //// //===========================================
// aggDraw.target->resetPath(); //// aggDraw.target->resetPath();
// aggDraw.target->fillColor(255, 0, 0, 100); //// aggDraw.target->fillColor(255, 0, 0, 100);
// aggDraw.target->lineColor(0, 0, 255, 100); //// aggDraw.target->lineColor(0, 0, 255, 100);
// aggDraw.target->lineWidth(2); //// aggDraw.target->lineWidth(2);
// aggDraw.target->moveTo(300/2, 200/2); //// aggDraw.target->moveTo(300/2, 200/2);
// aggDraw.target->horLineRel(-150/2); //// aggDraw.target->horLineRel(-150/2);
// aggDraw.target->arcRel(150/2, 150/2, 0, 1, 0, 150/2, -150/2); //// aggDraw.target->arcRel(150/2, 150/2, 0, 1, 0, 150/2, -150/2);
// aggDraw.target->closePolygon(); //// aggDraw.target->closePolygon();
// aggDraw.target->drawPath(); //// aggDraw.target->drawPath();
// ////
// aggDraw.target->resetPath(); //// aggDraw.target->resetPath();
// aggDraw.target->fillColor(255, 255, 0, 100); //// aggDraw.target->fillColor(255, 255, 0, 100);
// aggDraw.target->lineColor(0, 0, 255, 100); //// aggDraw.target->lineColor(0, 0, 255, 100);
// aggDraw.target->lineWidth(2); //// aggDraw.target->lineWidth(2);
// aggDraw.target->moveTo(275/2, 175/2); //// aggDraw.target->moveTo(275/2, 175/2);
// aggDraw.target->verLineRel(-150/2); //// aggDraw.target->verLineRel(-150/2);
// aggDraw.target->arcRel(150/2, 150/2, 0, 0, 0, -150/2, 150/2); //// aggDraw.target->arcRel(150/2, 150/2, 0, 0, 0, -150/2, 150/2);
// aggDraw.target->closePolygon(); //// aggDraw.target->closePolygon();
// aggDraw.target->drawPath(); //// aggDraw.target->drawPath();
// ////
// aggDraw.target->resetPath(); //// aggDraw.target->resetPath();
// aggDraw.target->noFill(); //// aggDraw.target->noFill();
// aggDraw.target->lineColor(127, 0, 0); //// aggDraw.target->lineColor(127, 0, 0);
// aggDraw.target->lineWidth(5); //// aggDraw.target->lineWidth(5);
// aggDraw.target->moveTo(600/2, 350/2); //// aggDraw.target->moveTo(600/2, 350/2);
// aggDraw.target->lineRel(50/2, -25/2); //// aggDraw.target->lineRel(50/2, -25/2);
// aggDraw.target->arcRel(25/2, 25/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2); //// aggDraw.target->arcRel(25/2, 25/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2);
// aggDraw.target->lineRel(50/2, -25/2); //// aggDraw.target->lineRel(50/2, -25/2);
// aggDraw.target->arcRel(25/2, 50/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2); //// aggDraw.target->arcRel(25/2, 50/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2);
// aggDraw.target->lineRel(50/2, -25/2); //// aggDraw.target->lineRel(50/2, -25/2);
// aggDraw.target->arcRel(25/2, 75/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2); //// aggDraw.target->arcRel(25/2, 75/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2);
// aggDraw.target->lineRel(50, -25); //// aggDraw.target->lineRel(50, -25);
// aggDraw.target->arcRel(25/2, 100/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2); //// aggDraw.target->arcRel(25/2, 100/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2);
// aggDraw.target->lineRel(50/2, -25/2); //// aggDraw.target->lineRel(50/2, -25/2);
// aggDraw.target->drawPath(); //// aggDraw.target->drawPath();
//} //}
// ////
// //