Fixed alpha composition when destination alpha is transparent.
Jianyu Guan I found I make a big mistake that when dstA==0, I just simply let *dstp=*srcp and forgot to make dstRGB = srcRGB*srcA. The if consition "(*dstp & amask) == 0" in BlitRGBtoRGBPixelAlphaMMX and BlitRGBtoRGBPixelAlphaMMX3dNow should be removed.
parent
89bc80f1ae
commit
76b7b1e96c
|
@ -352,7 +352,7 @@ BlitRGBtoRGBPixelAlphaMMX(SDL_BlitInfo * info)
|
||||||
Uint32 alpha = *srcp & amask;
|
Uint32 alpha = *srcp & amask;
|
||||||
if (alpha == 0) {
|
if (alpha == 0) {
|
||||||
/* do nothing */
|
/* do nothing */
|
||||||
} else if (alpha == amask || (*dstp & amask) == 0) {
|
} else if (alpha == amask) {
|
||||||
*dstp = *srcp;
|
*dstp = *srcp;
|
||||||
} else {
|
} else {
|
||||||
src1 = _mm_cvtsi32_si64(*srcp); /* src(ARGB) -> src1 (0000ARGB)*/
|
src1 = _mm_cvtsi32_si64(*srcp); /* src(ARGB) -> src1 (0000ARGB)*/
|
||||||
|
@ -545,7 +545,7 @@ BlitRGBtoRGBPixelAlphaMMX3DNOW(SDL_BlitInfo * info)
|
||||||
alpha = *srcp & amask;
|
alpha = *srcp & amask;
|
||||||
if (alpha == 0) {
|
if (alpha == 0) {
|
||||||
/* do nothing */
|
/* do nothing */
|
||||||
} else if (alpha == amask || (*dstp & amask) == 0) {
|
} else if (alpha == amask) {
|
||||||
*dstp = *srcp;
|
*dstp = *srcp;
|
||||||
} else {
|
} else {
|
||||||
src1 = _mm_cvtsi32_si64(*srcp); /* src(ARGB) -> src1 (0000ARGB)*/
|
src1 = _mm_cvtsi32_si64(*srcp); /* src(ARGB) -> src1 (0000ARGB)*/
|
||||||
|
|
Loading…
Reference in New Issue