From 7365c9e6ea8481820a7ba01f60e8f72712d023e0 Mon Sep 17 00:00:00 2001 From: zeromus Date: Sun, 12 Jul 2009 04:13:22 +0000 Subject: [PATCH] fix r,g,b ordering in 555 antigrain renderer --- desmume/src/aggdraw.cpp | 240 ++++++++++++++++++++++++---------------- 1 file changed, 142 insertions(+), 98 deletions(-) diff --git a/desmume/src/aggdraw.cpp b/desmume/src/aggdraw.cpp index 41efd71c9..e45850b97 100644 --- a/desmume/src/aggdraw.cpp +++ b/desmume/src/aggdraw.cpp @@ -65,6 +65,8 @@ 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 //which is necessary or else drawing transparent pixels on (31,31,31) will yield (30,30,30) struct my_blender_rgb555_pre @@ -82,35 +84,77 @@ namespace agg //not sure whether this is right... alpha = color_type::base_mask - alpha; pixel_type rgb = *p; - calc_type r = (rgb >> 10) & 31; + calc_type b = (rgb >> 10) & 31; calc_type g = (rgb >> 5) & 31; - calc_type b = (rgb ) & 31; - r = ((r+1)*(alpha+1) + (cr)*(cover)-1)>>8; + calc_type r = (rgb ) & 31; + b = ((r+1)*(alpha+1) + (cb)*(cover)-1)>>8; g = ((g+1)*(alpha+1) + (cg)*(cover)-1)>>8; - b = ((b+1)*(alpha+1) + (cb)*(cover)-1)>>8; - *p = (r<<10)|(g<<5)|b; + r = ((b+1)*(alpha+1) + (cr)*(cover)-1)>>8; + *p = (b<<10)|(g<<5)|r; } 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) | - (b >> 3) | 0x8000); + (r >> 3) | 0x8000); } 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 << 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_pixfmt_rgb555_pre; //----pixfmt_rgb555_pre + + typedef pixfmt_alpha_blend_rgb_packed my_pixfmt_rgb555; //----pixfmt_rgb555_pre } + typedef std::map TAgg_Font_Table; static TAgg_Font_Table font_table; @@ -173,7 +217,7 @@ static void Agg_init_fonts() AggDraw_Desmume aggDraw; -typedef AggDrawTargetImplementation > T_AGG_RGB555; +typedef AggDrawTargetImplementation > T_AGG_RGB555; typedef AggDrawTargetImplementation > T_AGG_RGBA; 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() { +//// +// aggDraw.setTarget(AggTarget_Screen); // -// aggDraw.setTarget(AggTarget_Lua); -// -// aggDraw.target->clear(); -// -// aggDraw.target->clipBox(0,0,255,383); -// -// aggDraw.target->lineColor(0, 255, 0, 128); -// aggDraw.target->fillColor(0, 255, 0, 128); -// //aggDraw.target->noFill(); +//// aggDraw.target->clear(); +//// +//// aggDraw.target->clipBox(0,0,255,383); +//// +// aggDraw.target->lineColor(0, 0, 255, 128); +// aggDraw.target->fillColor(0, 0, 255, 128); +//// //aggDraw.target->noFill(); // aggDraw.target->lineWidth(1.0); // aggDraw.target->roundedRect(10,30,256-10,192-10,4); -// -// aggDraw.target->setFont("verdana18_bold"); -// aggDraw.target->renderText(60,60, "testing testing testing"); -// -// // Gradients (Aqua Buttons) -// //======================================= -//// m_graphics.font("Verdana", 20.0, false, false, TAGG2D::VectorFontCache); -// double xb1 = 10; -// double yb1 = 80; -// double xb2 = xb1 + 150; -// double yb2 = yb1 + 36; -// -// aggDraw.target->fillColor(0,50,180,180); -// aggDraw.target->lineColor(0,0,80, 255); -// aggDraw.target->lineWidth(1.0); -// aggDraw.target->roundedRect(xb1, yb1, xb2, yb2, 12, 18); -// -// aggDraw.target->lineColor(0,0,0,0); -// aggDraw.target->fillLinearGradient(xb1, yb1, xb1, yb1+30, -// agg::rgba8(100,200,255,255), -// agg::rgba8(255,255,255,0)); -// 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->noLine(); -///* 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); -//*/ -// aggDraw.target->fillLinearGradient(xb1, yb2-20, xb1, yb2-3, -// agg::rgba8(0, 0, 255,0), -// agg::rgba8(100,255,255,255)); -// aggDraw.target->roundedRect(xb1+3, yb2-20, xb2-3, yb2-2, 1, 1, 9, 18); -// -// // Basic Shapes -- Ellipse -// //=========================================== -// aggDraw.target->lineWidth(3.5); -// aggDraw.target->lineColor(20, 80, 80); -// aggDraw.target->fillColor(200, 255, 80, 200); -// aggDraw.target->ellipse(150, 200, 50, 90); -// -// // Paths -// //=========================================== -// aggDraw.target->resetPath(); -// aggDraw.target->fillColor(255, 0, 0, 100); -// aggDraw.target->lineColor(0, 0, 255, 100); -// aggDraw.target->lineWidth(2); -// aggDraw.target->moveTo(300/2, 200/2); -// aggDraw.target->horLineRel(-150/2); -// aggDraw.target->arcRel(150/2, 150/2, 0, 1, 0, 150/2, -150/2); -// aggDraw.target->closePolygon(); -// aggDraw.target->drawPath(); -// -// aggDraw.target->resetPath(); -// aggDraw.target->fillColor(255, 255, 0, 100); -// aggDraw.target->lineColor(0, 0, 255, 100); -// aggDraw.target->lineWidth(2); -// aggDraw.target->moveTo(275/2, 175/2); -// aggDraw.target->verLineRel(-150/2); -// aggDraw.target->arcRel(150/2, 150/2, 0, 0, 0, -150/2, 150/2); -// aggDraw.target->closePolygon(); -// aggDraw.target->drawPath(); -// -// aggDraw.target->resetPath(); -// aggDraw.target->noFill(); -// aggDraw.target->lineColor(127, 0, 0); -// aggDraw.target->lineWidth(5); -// aggDraw.target->moveTo(600/2, 350/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->lineRel(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->arcRel(25/2, 75/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2); -// aggDraw.target->lineRel(50, -25); -// 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->drawPath(); +//// +//// aggDraw.target->setFont("verdana18_bold"); +//// aggDraw.target->renderText(60,60, "testing testing testing"); +//// +//// // Gradients (Aqua Buttons) +//// //======================================= +////// m_graphics.font("Verdana", 20.0, false, false, TAGG2D::VectorFontCache); +//// double xb1 = 10; +//// double yb1 = 80; +//// double xb2 = xb1 + 150; +//// double yb2 = yb1 + 36; +//// +//// aggDraw.target->fillColor(0,50,180,180); +//// aggDraw.target->lineColor(0,0,80, 255); +//// aggDraw.target->lineWidth(1.0); +//// aggDraw.target->roundedRect(xb1, yb1, xb2, yb2, 12, 18); +//// +//// aggDraw.target->lineColor(0,0,0,0); +//// aggDraw.target->fillLinearGradient(xb1, yb1, xb1, yb1+30, +//// agg::rgba8(100,200,255,255), +//// agg::rgba8(255,255,255,0)); +//// 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->noLine(); +/////* 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); +////*/ +//// aggDraw.target->fillLinearGradient(xb1, yb2-20, xb1, yb2-3, +//// agg::rgba8(0, 0, 255,0), +//// agg::rgba8(100,255,255,255)); +//// aggDraw.target->roundedRect(xb1+3, yb2-20, xb2-3, yb2-2, 1, 1, 9, 18); +//// +//// // Basic Shapes -- Ellipse +//// //=========================================== +//// aggDraw.target->lineWidth(3.5); +//// aggDraw.target->lineColor(20, 80, 80); +//// aggDraw.target->fillColor(200, 255, 80, 200); +//// aggDraw.target->ellipse(150, 200, 50, 90); +//// +//// // Paths +//// //=========================================== +//// aggDraw.target->resetPath(); +//// aggDraw.target->fillColor(255, 0, 0, 100); +//// aggDraw.target->lineColor(0, 0, 255, 100); +//// aggDraw.target->lineWidth(2); +//// aggDraw.target->moveTo(300/2, 200/2); +//// aggDraw.target->horLineRel(-150/2); +//// aggDraw.target->arcRel(150/2, 150/2, 0, 1, 0, 150/2, -150/2); +//// aggDraw.target->closePolygon(); +//// aggDraw.target->drawPath(); +//// +//// aggDraw.target->resetPath(); +//// aggDraw.target->fillColor(255, 255, 0, 100); +//// aggDraw.target->lineColor(0, 0, 255, 100); +//// aggDraw.target->lineWidth(2); +//// aggDraw.target->moveTo(275/2, 175/2); +//// aggDraw.target->verLineRel(-150/2); +//// aggDraw.target->arcRel(150/2, 150/2, 0, 0, 0, -150/2, 150/2); +//// aggDraw.target->closePolygon(); +//// aggDraw.target->drawPath(); +//// +//// aggDraw.target->resetPath(); +//// aggDraw.target->noFill(); +//// aggDraw.target->lineColor(127, 0, 0); +//// aggDraw.target->lineWidth(5); +//// aggDraw.target->moveTo(600/2, 350/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->lineRel(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->arcRel(25/2, 75/2, aggDraw.target->deg2Rad(-30), 0, 1, 50/2, -25/2); +//// aggDraw.target->lineRel(50, -25); +//// 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->drawPath(); //} -// +//// //