VirtualBox

Changeset 63486 in vbox for trunk/src


Ignore:
Timestamp:
Aug 15, 2016 2:57:55 PM (8 years ago)
Author:
vboxsync
Message:

removed dead code

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Main/src-all/DisplayResampleImage.cpp

    r63459 r63486  
    1616 */
    1717
    18 /*
    19  * Based on gdImageCopyResampled from libgd.
    20  * Original copyright notice follows:
    21 
    22      Portions copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
    23      Pierre-Alain Joye ([email protected]).
    24 
    25      Permission has been granted to copy, distribute and modify gd in
    26      any context without fee, including a commercial application,
    27      provided that this notice is present in user-accessible supporting
    28      documentation.
    29 
    30      This does not affect your ownership of the derived work itself, and
    31      the intent is to assure proper credit for the authors of gd, not to
    32      interfere with your productive use of gd. If you have questions,
    33      ask. "Derived works" includes all programs that utilize the
    34      library. Credit must be given in user-accessible documentation.
    35 
    36      This software is provided "AS IS." The copyright holders disclaim
    37      all warranties, either express or implied, including but not
    38      limited to implied warranties of merchantability and fitness for a
    39      particular purpose, with respect to this code and accompanying
    40      documentation.
    41  */
    42 
    43 /*
    44  *
    45  * @todo Simplify: Offsets of images are 0,0 => no dstX, dstY, srcX, srcY;
    46  *             Screenshot has no alpha channel => no processing of alpha byte.
    47  */
    48 
    4918#include <iprt/types.h>
    5019
    51 /* 2.0.10: cast instead of floor() yields 35% performance improvement.
    52         Thanks to John Buckman. */
    53 
    54 #define floor2(exp) ((long) exp)
    55 /*#define floor2(exp) floor(exp)*/
    56 
    57 typedef uint8_t *gdImagePtr;
    58 
    59 DECLINLINE(int) gdImageGetTrueColorPixel (gdImagePtr im, int x, int y, int w)
    60 {
    61     return *(int32_t *)(im + y * w * 4 + x * 4);
    62 }
    63 
    64 DECLINLINE(void) gdImageSetPixel (gdImagePtr im, int x, int y, int color, int w)
     20DECLINLINE(void) imageSetPixel (uint8_t *im, int x, int y, int color, int w)
    6521{
    6622    *(int32_t *)(im + y * w * 4 + x * 4) = color;
    6723}
    6824
    69 #define gdAlphaMax 127
    70 #define gdAlphaOpaque 0
    71 #define gdAlphaTransparent 127
    72 #define gdRedMax 255
    73 #define gdGreenMax 255
    74 #define gdBlueMax 255
    75 #define gdTrueColorGetAlpha(c) (((c) & 0x7F000000) >> 24)
    76 #define gdTrueColorGetRed(c) (((c) & 0xFF0000) >> 16)
    77 #define gdTrueColorGetGreen(c) (((c) & 0x00FF00) >> 8)
    78 #define gdTrueColorGetBlue(c) ((c) & 0x0000FF)
    79 #define gdTrueColorAlpha(r, g, b, a) (((a) << 24) + \
    80         ((r) << 16) + \
    81         ((g) << 8) + \
    82         (b))
    83 
    84 #if 0 /* unused */
    85 void gdImageCopyResampled (uint8_t *dst,
    86                       uint8_t *src,
    87                       int dstX, int dstY,
    88                       int srcX, int srcY,
    89                       int dstW, int dstH, int srcW, int srcH)
    90 {
    91   int x, y;
    92   double sy1, sy2, sx1, sx2;
    93   for (y = dstY; (y < dstY + dstH); y++)
    94     {
    95       sy1 = ((double) y - (double) dstY) * (double) srcH / (double) dstH;
    96       sy2 = ((double) (y + 1) - (double) dstY) * (double) srcH /
    97         (double) dstH;
    98       for (x = dstX; (x < dstX + dstW); x++)
    99         {
    100           double sx, sy;
    101           double spixels = 0;
    102           double red = 0.0, green = 0.0, blue = 0.0, alpha = 0.0;
    103           sx1 = ((double) x - (double) dstX) * (double) srcW / dstW;
    104           sx2 = ((double) (x + 1) - (double) dstX) * (double) srcW / dstW;
    105           sy = sy1;
    106           do
    107             {
    108               double yportion;
    109               if (floor2 (sy) == floor2 (sy1))
    110                 {
    111                   yportion = 1.0 - (sy - (double)floor2 (sy));
    112                   if (yportion > sy2 - sy1)
    113                     {
    114                       yportion = sy2 - sy1;
    115                     }
    116                   sy = (double)floor2 (sy);
    117                 }
    118               else if (sy == floor2 (sy2))
    119                 {
    120                   yportion = sy2 - (double)floor2 (sy2);
    121                 }
    122               else
    123                 {
    124                   yportion = 1.0;
    125                 }
    126               sx = sx1;
    127               do
    128                 {
    129                   double xportion;
    130                   double pcontribution;
    131                   int p;
    132                   if (floor2 (sx) == floor2 (sx1))
    133                     {
    134                       xportion = 1.0 - (sx - (double)floor2 (sx));
    135                       if (xportion > sx2 - sx1)
    136                         {
    137                           xportion = sx2 - sx1;
    138                         }
    139                       sx = (double)floor2 (sx);
    140                     }
    141                   else if (sx == floor2 (sx2))
    142                     {
    143                       xportion = sx2 - (double)floor2 (sx2);
    144                     }
    145                   else
    146                     {
    147                       xportion = 1.0;
    148                     }
    149                   pcontribution = xportion * yportion;
    150                   /* 2.08: previously srcX and srcY were ignored.
    151                      Andrew Pattison */
    152                   p = gdImageGetTrueColorPixel (src,
    153                                                 (int) sx + srcX,
    154                                                 (int) sy + srcY, srcW);
    155                   red += gdTrueColorGetRed (p) * pcontribution;
    156                   green += gdTrueColorGetGreen (p) * pcontribution;
    157                   blue += gdTrueColorGetBlue (p) * pcontribution;
    158                   alpha += gdTrueColorGetAlpha (p) * pcontribution;
    159                   spixels += xportion * yportion;
    160                   sx += 1.0;
    161                 }
    162               while (sx < sx2);
    163               sy += 1.0;
    164             }
    165           while (sy < sy2);
    166           if (spixels != 0.0)
    167             {
    168               red /= spixels;
    169               green /= spixels;
    170               blue /= spixels;
    171               alpha /= spixels;
    172             }
    173           /* Clamping to allow for rounding errors above */
    174           if (red > 255.0)
    175             {
    176               red = 255.0;
    177             }
    178           if (green > 255.0)
    179             {
    180               green = 255.0;
    181             }
    182           if (blue > 255.0)
    183             {
    184               blue = 255.0;
    185             }
    186           if (alpha > gdAlphaMax)
    187             {
    188               alpha = gdAlphaMax;
    189             }
    190           gdImageSetPixel (dst,
    191                            x, y,
    192                            gdTrueColorAlpha ((int) red,
    193                                              (int) green,
    194                                              (int) blue, (int) alpha), dstW);
    195         }
    196     }
    197 }
    198 #endif
     25#define trueColorGetAlpha(c) (((c) & 0x7F000000) >> 24)
     26#define trueColorGetRed(c)   (((c) & 0xFF0000)   >> 16)
     27#define trueColorGetGreen(c) (((c) & 0x00FF00)   >> 8)
     28#define trueColorGetBlue(c)   ((c) & 0x0000FF)
    19929
    20030/* Fast integer implementation for 32 bpp bitmap scaling.
    201  * Use fixed point values * 16.
     31 * Using fixed point values * 16.
    20232 */
    20333typedef int32_t FIXEDPOINT;
     
    20939/* For 32 bit source only. */
    21040void BitmapScale32 (uint8_t *dst,
    211                         int dstW, int dstH,
    212                         const uint8_t *src,
    213                         int iDeltaLine,
    214                         int srcW, int srcH)
     41                    int dstW, int dstH,
     42                    const uint8_t *src,
     43                    int iDeltaLine,
     44                    int srcW, int srcH)
    21545{
    21646    int x, y;
     
    283113                    p = *(uint32_t *)(pu8SrcLine + FIXEDPOINT_TO_INT(sx) * 4);
    284114                    /* Color depth specific code end */
    285                     red += gdTrueColorGetRed (p) * pcontribution;
    286                     green += gdTrueColorGetGreen (p) * pcontribution;
    287                     blue += gdTrueColorGetBlue (p) * pcontribution;
     115                    red   += trueColorGetRed (p) * pcontribution;
     116                    green += trueColorGetGreen (p) * pcontribution;
     117                    blue  += trueColorGetBlue (p) * pcontribution;
    288118
    289119                    sx += INT_TO_FIXEDPOINT(1);
     
    312142                blue = 255;
    313143            }
    314             gdImageSetPixel (dst,
    315                              x, y,
    316                              ( ((int) red) << 16) + (((int) green) << 8) + ((int) blue),
    317                              dstW);
     144            imageSetPixel (dst,
     145                           x, y,
     146                           ( ((int) red) << 16) + (((int) green) << 8) + ((int) blue),
     147                           dstW);
    318148        }
    319149    }
    320150}
    321 
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette