* on R5, the meaning of B_CONSTANT_ALPHA is a bit different

with regards to drawing bitmaps with alpha channel, instead
  of ignoring the bitmap alpha channel, it is further multiplied
  with the high color alpha channel, so basically, you can
  use the high color alpha as a "global" alpha value to
  draw the bitmap with
* removed some duplicate code


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@18843 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Stephan Aßmus 2006-09-14 18:07:02 +00:00
parent 846cc588f2
commit d39634ce4d
4 changed files with 6 additions and 62 deletions

View File

@ -148,10 +148,8 @@ blend_color_hspan_alpha_cc(int x, int y, unsigned len,
if (covers) { if (covers) {
// non-solid opacity // non-solid opacity
do { do {
uint16 alpha = hAlpha * *covers; uint16 alpha = hAlpha * colors->a * *covers / 255;
// if (alpha) { if (alpha) {
if (alpha && (colors->a & 0xff)) {
// support for transparent magic
if (alpha == 255 * 255) { if (alpha == 255 * 255) {
ASSIGN_ALPHA_CC(p, colors->r, colors->g, colors->b); ASSIGN_ALPHA_CC(p, colors->r, colors->g, colors->b);
} else { } else {
@ -164,23 +162,17 @@ if (alpha && (colors->a & 0xff)) {
} while(--len); } while(--len);
} else { } else {
// solid full opcacity // solid full opcacity
uint16 alpha = hAlpha * cover; uint16 alpha = hAlpha * colors->a * cover / 255;
if (alpha == 255 * 255) { if (alpha == 255 * 255) {
do { do {
if (colors->a & 0xff) {
// support for transparent magic
ASSIGN_ALPHA_CC(p, colors->r, colors->g, colors->b); ASSIGN_ALPHA_CC(p, colors->r, colors->g, colors->b);
}
p += 4; p += 4;
++colors; ++colors;
} while(--len); } while(--len);
// solid partial opacity // solid partial opacity
} else if (alpha) { } else if (alpha) {
do { do {
if (colors->a & 0xff) {
// support for transparent magic
BLEND_ALPHA_CC(p, colors->r, colors->g, colors->b, alpha); BLEND_ALPHA_CC(p, colors->r, colors->g, colors->b, alpha);
}
p += 4; p += 4;
++colors; ++colors;
} while(--len); } while(--len);

View File

@ -150,7 +150,7 @@ blend_color_hspan_alpha_co(int x, int y, unsigned len,
if (covers) { if (covers) {
// non-solid opacity // non-solid opacity
do { do {
uint16 alpha = hAlpha * *covers; uint16 alpha = hAlpha * colors->a * *covers / 255;
if (alpha) { if (alpha) {
if (alpha == 255*255) { if (alpha == 255*255) {
ASSIGN_ALPHA_CO(p, colors->r, colors->g, colors->b); ASSIGN_ALPHA_CO(p, colors->r, colors->g, colors->b);
@ -164,7 +164,7 @@ blend_color_hspan_alpha_co(int x, int y, unsigned len,
} while(--len); } while(--len);
} else { } else {
// solid full opcacity // solid full opcacity
uint16 alpha = hAlpha * cover; uint16 alpha = hAlpha * colors->a * cover / 255;
if (alpha == 255 * 255) { if (alpha == 255 * 255) {
do { do {
ASSIGN_ALPHA_CO(p, colors->r, colors->g, colors->b); ASSIGN_ALPHA_CO(p, colors->r, colors->g, colors->b);

View File

@ -83,8 +83,6 @@ blend_solid_hspan_over_solid(int x, int y, unsigned len,
} while(--len); } while(--len);
} }
// blend_solid_vspan_over_solid // blend_solid_vspan_over_solid
void void
blend_solid_vspan_over_solid(int x, int y, unsigned len, blend_solid_vspan_over_solid(int x, int y, unsigned len,
@ -109,50 +107,5 @@ blend_solid_vspan_over_solid(int x, int y, unsigned len,
} while(--len); } while(--len);
} }
// blend_color_hspan_over_solid
void
blend_color_hspan_over_solid(int x, int y, unsigned len,
const color_type* colors,
const uint8* covers, uint8 cover,
agg_buffer* buffer, const PatternHandler* pattern)
{
uint8* p = buffer->row_ptr(y) + (x << 2);
if (covers) {
// non-solid opacity
do {
// if (*covers) {
if (*covers && (colors->a & 0xff)) {
if (*covers == 255) {
ASSIGN_OVER(p, colors->r, colors->g, colors->b);
} else {
BLEND_OVER(p, colors->r, colors->g, colors->b, *covers);
}
}
covers++;
p += 4;
++colors;
} while(--len);
} else {
// solid full opcacity
if (cover == 255) {
do {
if (colors->a & 0xff) {
ASSIGN_OVER(p, colors->r, colors->g, colors->b);
}
p += 4;
++colors;
} while(--len);
// solid partial opacity
} else if (cover) {
do {
BLEND_OVER(p, colors->r, colors->g, colors->b, cover);
p += 4;
++colors;
} while(--len);
}
}
}
#endif // DRAWING_MODE_OVER_H #endif // DRAWING_MODE_OVER_H

View File

@ -140,14 +140,13 @@ PixelFormat::SetDrawingMode(drawing_mode mode, source_alpha alphaSrcMode,
fBlendHLine = blend_hline_over; fBlendHLine = blend_hline_over;
fBlendSolidHSpan = blend_solid_hspan_over; fBlendSolidHSpan = blend_solid_hspan_over;
fBlendSolidVSpan = blend_solid_vspan_over; fBlendSolidVSpan = blend_solid_vspan_over;
fBlendColorHSpan = blend_color_hspan_over;
} else { } else {
fBlendPixel = blend_pixel_over_solid; fBlendPixel = blend_pixel_over_solid;
fBlendHLine = blend_hline_over_solid; fBlendHLine = blend_hline_over_solid;
fBlendSolidHSpan = blend_solid_hspan_over_solid; fBlendSolidHSpan = blend_solid_hspan_over_solid;
fBlendSolidVSpan = blend_solid_vspan_over_solid; fBlendSolidVSpan = blend_solid_vspan_over_solid;
fBlendColorHSpan = blend_color_hspan_over_solid;
} }
fBlendColorHSpan = blend_color_hspan_over;
break; break;
case B_OP_ERASE: case B_OP_ERASE:
fBlendPixel = blend_pixel_erase; fBlendPixel = blend_pixel_erase;