summaryrefslogtreecommitdiffstats
path: root/base/gfx
diff options
context:
space:
mode:
authorglen@chromium.org <glen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-24 19:29:05 +0000
committerglen@chromium.org <glen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-24 19:29:05 +0000
commit7aa4286f9a94b542e602ae08188c5dd4feb16880 (patch)
tree5f1f789dff9304403ded5ac4f07449a75295c4cd /base/gfx
parentac97c48bbe9ab3f77efcd4ec0fa51fc1628842f2 (diff)
downloadchromium_src-7aa4286f9a94b542e602ae08188c5dd4feb16880.zip
chromium_src-7aa4286f9a94b542e602ae08188c5dd4feb16880.tar.gz
chromium_src-7aa4286f9a94b542e602ae08188c5dd4feb16880.tar.bz2
Reverting 19131.
Review URL: http://codereview.chromium.org/147095 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@19154 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/gfx')
-rw-r--r--base/gfx/png_codec_unittest.cc47
-rw-r--r--base/gfx/png_decoder.cc24
2 files changed, 3 insertions, 68 deletions
diff --git a/base/gfx/png_codec_unittest.cc b/base/gfx/png_codec_unittest.cc
index c9734a7..9184abe 100644
--- a/base/gfx/png_codec_unittest.cc
+++ b/base/gfx/png_codec_unittest.cc
@@ -7,7 +7,6 @@
#include "base/gfx/png_encoder.h"
#include "base/gfx/png_decoder.h"
#include "testing/gtest/include/gtest/gtest.h"
-#include "third_party/skia/include/core/SkBitmap.h"
static void MakeRGBImage(int w, int h, std::vector<unsigned char>* dat) {
dat->resize(w * h * 3);
@@ -42,25 +41,6 @@ static void MakeRGBAImage(int w, int h, bool use_transparency,
}
}
-// Returns true if each channel of the given two colors are "close." This is
-// used for comparing colors where rounding errors may cause off-by-one.
-bool ColorsClose(uint32_t a, uint32_t b) {
- return abs(static_cast<int>(SkColorGetB(a) - SkColorGetB(b))) < 2 &&
- abs(static_cast<int>(SkColorGetG(a) - SkColorGetG(b))) < 2 &&
- abs(static_cast<int>(SkColorGetR(a) - SkColorGetR(b))) < 2 &&
- abs(static_cast<int>(SkColorGetA(a) - SkColorGetA(b))) < 2;
-}
-
-void MakeTestSkBitmap(int w, int h, SkBitmap* bmp) {
- bmp->setConfig(SkBitmap::kARGB_8888_Config, w, h);
- bmp->allocPixels();
-
- uint32_t* src_data = bmp->getAddr32(0, 0);
- for (int i = 0; i < w * h; i++) {
- src_data[i] = SkPreMultiplyARGB(i % 255, i % 250, i % 245, i % 240);
- }
-}
-
TEST(PNGCodec, EncodeDecodeRGB) {
const int w = 20, h = 20;
@@ -220,30 +200,3 @@ TEST(PNGCodec, StripAddAlpha) {
ASSERT_EQ(original_rgb.size(), decoded.size());
ASSERT_TRUE(original_rgb == decoded);
}
-
-TEST(PNGCodec, EncodeBGRASkBitmap) {
- const int w = 20, h = 20;
-
- SkBitmap original_bitmap;
- MakeTestSkBitmap(w, h, &original_bitmap);
-
- // Encode the bitmap.
- std::vector<unsigned char> encoded;
- PNGEncoder::EncodeBGRASkBitmap(original_bitmap, false, &encoded);
-
- // Decode the encoded string.
- SkBitmap decoded_bitmap;
- EXPECT_TRUE(PNGDecoder::Decode(&encoded, &decoded_bitmap));
-
- // Compare the original bitmap and the output bitmap. We use ColorsClose
- // as SkBitmaps are considered to be pre-multiplied, the unpremultiplication
- // (in Encode) and repremultiplication (in Decode) can be lossy.
- for (int x = 0; x < w; x++) {
- for (int y = 0; y < h; y++) {
- uint32_t original_pixel = original_bitmap.getAddr32(0, y)[x];
- uint32_t decoded_pixel = decoded_bitmap.getAddr32(0, y)[x];
- EXPECT_TRUE(ColorsClose(original_pixel, decoded_pixel));
- }
- }
-}
-
diff --git a/base/gfx/png_decoder.cc b/base/gfx/png_decoder.cc
index bd36c57..e493464 100644
--- a/base/gfx/png_decoder.cc
+++ b/base/gfx/png_decoder.cc
@@ -261,8 +261,8 @@ class PngReadStructDestroyer {
// static
bool PNGDecoder::Decode(const unsigned char* input, size_t input_size,
- ColorFormat format, std::vector<unsigned char>* output,
- int* w, int* h) {
+ ColorFormat format, std::vector<unsigned char>* output,
+ int* w, int* h) {
if (input_size < 8)
return false; // Input data too small to be a png
@@ -324,25 +324,7 @@ bool PNGDecoder::Decode(const std::vector<unsigned char>* data,
&decoded_data, &width, &height)) {
bitmap->setConfig(SkBitmap::kARGB_8888_Config, width, height);
bitmap->allocPixels();
- for (int y = 0; y < height; y++) {
- for (int x = 0; x < width; x++) {
- int pix = (y * height + x) * 4;
- unsigned char alpha = decoded_data[pix + 3];
- if (alpha != 0 && alpha != 255) {
- bitmap->getAddr32(0, y)[x] = SkColorSetARGB(
- alpha,
- (decoded_data[pix + 2] * alpha) >> 8,
- (decoded_data[pix + 1] * alpha) >> 8,
- (decoded_data[pix] * alpha) >> 8);
- } else {
- bitmap->getAddr32(0, y)[x] = SkColorSetARGB(
- alpha,
- decoded_data[pix + 2],
- decoded_data[pix + 1],
- decoded_data[pix]);
- }
- }
- }
+ memcpy(bitmap->getPixels(), &decoded_data.front(), width * height * 4);
return true;
}
return false;