1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
{
double aCos = cos(theRot);
double aSin = sin(theRot);
int aCosLong = (int) (aCos * 0x10000);
int aSinLong = (int) (aSin * 0x10000);
#ifdef OPTIMIZE_SOFTWARE_DRAWING
int aRotCenterXLong = (int)(theRotCenterX * 0x10000);
int aRotCenterYLong = (int)(theRotCenterY * 0x10000);
#endif
uint32_t* aDestPixelsRow = GetBits() + ((int)aDestRect.mY * mWidth) + (int)aDestRect.mX;
int aDestPixelsPitch = mWidth;
if (theColor == Color::White)
{
#define DEST_PIXEL_TYPE uint32_t
#define WRITE_PIXEL\
{\
uint32_t dest = *aDestPixels;\
int a = a1+a2+a3+a4; \
if(a==0) /* transparent */ \
aDestPixels++;\
else \
{ \
uint32_t r = aMaxTable[((((src1&0xFF0000)*a1) + ((src2&0xFF0000)*a2) + ((src3&0xFF0000)*a3) + ((src4&0xFF0000)*a4))>>24) + ((dest&0xFF0000)>>16)]; \
uint32_t g = aMaxTable[((((src1&0x00FF00)*a1) + ((src2&0x00FF00)*a2) + ((src3&0x00FF00)*a3) + ((src4&0x00FF00)*a4))>>16) + ((dest&0x00FF00)>>8)]; \
uint32_t b = aMaxTable[((((src1&0x0000FF)*a1) + ((src2&0x0000FF)*a2) + ((src3&0x0000FF)*a3) + ((src4&0x0000FF)*a4))>>8) + (dest&0x0000FF)]; \
\
*aDestPixels++ = (dest & 0xFF000000) | (r<<16) | (g<<8) | b; \
} \
}
#include "BltRotatedHelper.inc"
#undef WRITE_PIXEL
#undef DEST_PIXEL_TYPE
}
else
{
int ca = theColor.mAlpha;
int cr = (theColor.mRed * ca) / 255;
int cg = (theColor.mGreen * ca) / 255;
int cb = (theColor.mBlue * ca) / 255;
#define DEST_PIXEL_TYPE uint32_t
#define WRITE_PIXEL\
{\
uint32_t dest = *aDestPixels;\
int a = a1+a2+a3+a4; \
if(a==0) /* transparent */ \
aDestPixels++; \
else \
{ \
uint32_t destPixel = *aDestPixels; \
\
uint32_t r = aMaxTable[((((((src1&0xFF0000)*a1) + ((src2&0xFF0000)*a2) + ((src3&0xFF0000)*a3) + ((src4&0xFF0000)*a4))>>24)*cr)>>8) + ((dest&0xFF0000)>>16)]; \
uint32_t g = aMaxTable[(((((src1&0x00FF00)*a1) + ((src2&0x00FF00)*a2) + ((src3&0x00FF00)*a3) + ((src4&0x00FF00)*a4))*cg)>>24) + ((dest&0x00FF00)>>8)]; \
uint32_t b = aMaxTable[(((((src1&0x0000FF)*a1) + ((src2&0x0000FF)*a2) + ((src3&0x0000FF)*a3) + ((src4&0x0000FF)*a4))*cb)>>16) + (dest&0x0000FF)]; \
\
*aDestPixels++ = (dest & 0xFF000000) | (r<<16) | (g<<8) | b; \
}\
}
#include "BltRotatedHelper.inc"
#undef WRITE_PIXEL
#undef DEST_PIXEL_TYPE
}
}
|