 Chromium Code Reviews
 Chromium Code Reviews Issue 6849030:
  Add support for multi resolution icons   (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 6849030:
  Add support for multi resolution icons   (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| Index: skia/ext/skia_utils_mac_unittest.mm | 
| diff --git a/skia/ext/skia_utils_mac_unittest.mm b/skia/ext/skia_utils_mac_unittest.mm | 
| index 1726c4a1bdc5717847032af64de2e1d85ded66f5..b9ab54c1ba6d9bf80951bc467ab0204d288834a8 100644 | 
| --- a/skia/ext/skia_utils_mac_unittest.mm | 
| +++ b/skia/ext/skia_utils_mac_unittest.mm | 
| @@ -9,39 +9,60 @@ namespace { | 
| class SkiaUtilsMacTest : public testing::Test { | 
| public: | 
| + // Creates a red or blue bitmap. | 
| + SkBitmap CreateSkBitmap(int width, int height, bool isred, bool tfbit); | 
| + | 
| + // Creates a red or blue image. | 
| + NSImage* CreateNSImage(int width, int height, bool isred); | 
| + | 
| + // Checks that the given bitmap rep is actually red or blue. | 
| + void TestImageRep(NSBitmapImageRep* imageRep, bool isred); | 
| + | 
| + // Checks that the given bitmap is actually red or blue. | 
| + void TestSkBitmap(const SkBitmap& bitmap, bool isred); | 
| + | 
| // If not red, is blue. | 
| // If not tfbit (twenty-four-bit), is 444. | 
| void ShapeHelper(int width, int height, bool isred, bool tfbit); | 
| }; | 
| -void SkiaUtilsMacTest::ShapeHelper(int width, int height, | 
| - bool isred, bool tfbit) { | 
| - SkBitmap thing; | 
| +SkBitmap SkiaUtilsMacTest::CreateSkBitmap(int width, int height, | 
| + bool isred, bool tfbit) { | 
| + SkBitmap bitmap; | 
| if (tfbit) | 
| - thing.setConfig(SkBitmap::kARGB_8888_Config, width, height); | 
| + bitmap.setConfig(SkBitmap::kARGB_8888_Config, width, height); | 
| else | 
| - thing.setConfig(SkBitmap::kARGB_4444_Config, width, height); | 
| - thing.allocPixels(); | 
| + bitmap.setConfig(SkBitmap::kARGB_4444_Config, width, height); | 
| + bitmap.allocPixels(); | 
| if (isred) | 
| - thing.eraseRGB(0xff, 0, 0); | 
| + bitmap.eraseRGB(0xff, 0, 0); | 
| else | 
| - thing.eraseRGB(0, 0, 0xff); | 
| + bitmap.eraseRGB(0, 0, 0xff); | 
| - // Confirm size | 
| - NSImage* image = gfx::SkBitmapToNSImage(thing); | 
| - EXPECT_DOUBLE_EQ([image size].width, (double)width); | 
| - EXPECT_DOUBLE_EQ([image size].height, (double)height); | 
| + return bitmap; | 
| +} | 
| - // Get the color of a pixel and make sure it looks fine | 
| +NSImage* SkiaUtilsMacTest::CreateNSImage(int width, int height, bool isred) { | 
| + NSImage* image = [[[NSImage alloc] initWithSize:NSMakeSize(width, height)] | 
| + autorelease]; | 
| [image lockFocus]; | 
| + if (isred) | 
| + [[NSColor colorWithDeviceRed:1.0 green:0.0 blue:0.0 alpha:1.0] set]; | 
| + else | 
| + [[NSColor colorWithDeviceRed:0.0 green:0.0 blue:1.0 alpha:1.0] set]; | 
| + NSRectFill(NSMakeRect(0, 0, width, height)); | 
| + [image unlockFocus]; | 
| + return image; | 
| +} | 
| - int x = width > 17 ? 17 : 0; | 
| - int y = height > 17 ? 17 : 0; | 
| - NSColor* color = NSReadPixel(NSMakePoint(x, y)); | 
| +void SkiaUtilsMacTest::TestImageRep(NSBitmapImageRep* imageRep, bool isred) { | 
| + // Get the color of a pixel and make sure it looks fine | 
| + int x = [imageRep size].width > 17 ? 17 : 0; | 
| + int y = [imageRep size].height > 17 ? 17 : 0; | 
| + NSColor* color = [imageRep colorAtX:x y:y]; | 
| CGFloat red = 0, green = 0, blue = 0, alpha = 0; | 
| - [image unlockFocus]; | 
| // SkBitmapToNSImage returns a bitmap in the calibrated color space (sRGB), | 
| // while NSReadPixel returns a color in the device color space. Convert back | 
| @@ -52,14 +73,45 @@ void SkiaUtilsMacTest::ShapeHelper(int width, int height, | 
| // Be tolerant of floating point rounding and lossy color space conversions. | 
| if (isred) { | 
| - EXPECT_GT(red, 0.95); | 
| - EXPECT_LT(blue, 0.05); | 
| + EXPECT_NEAR(red, 1.0, 0.025); | 
| + EXPECT_NEAR(blue, 0.0, 0.025); | 
| + } else { | 
| + EXPECT_NEAR(red, 0.0, 0.025); | 
| + EXPECT_NEAR(blue, 1.0, 0.025); | 
| + } | 
| + EXPECT_NEAR(green, 0.0, 0.025); | 
| + EXPECT_NEAR(alpha, 1.0, 0.025); | 
| +} | 
| + | 
| +void SkiaUtilsMacTest::TestSkBitmap(const SkBitmap& bitmap, bool isred) { | 
| + int x = bitmap.width() > 17 ? 17 : 0; | 
| + int y = bitmap.height() > 17 ? 17 : 0; | 
| + SkColor color = bitmap.getColor(x, y); | 
| + | 
| + if (isred) { | 
| + EXPECT_EQ(255u, SkColorGetR(color)); | 
| + EXPECT_EQ(0u, SkColorGetB(color)); | 
| } else { | 
| - EXPECT_LT(red, 0.05); | 
| - EXPECT_GT(blue, 0.95); | 
| + EXPECT_EQ(0u, SkColorGetR(color)); | 
| + EXPECT_EQ(255u, SkColorGetB(color)); | 
| } | 
| - EXPECT_LT(green, 0.05); | 
| - EXPECT_GT(alpha, 0.95); | 
| + EXPECT_EQ(0u, SkColorGetG(color)); | 
| + EXPECT_EQ(255u, SkColorGetA(color)); | 
| +} | 
| + | 
| +void SkiaUtilsMacTest::ShapeHelper(int width, int height, | 
| + bool isred, bool tfbit) { | 
| + SkBitmap thing(CreateSkBitmap(width, height, isred, tfbit)); | 
| + | 
| + // Confirm size | 
| + NSImage* image = gfx::SkBitmapToNSImage(thing); | 
| + EXPECT_DOUBLE_EQ([image size].width, (double)width); | 
| + EXPECT_DOUBLE_EQ([image size].height, (double)height); | 
| + | 
| + EXPECT_TRUE([[image representations] count] == 1); | 
| + EXPECT_TRUE([[[image representations] lastObject] | 
| + isKindOfClass:[NSBitmapImageRep class]]); | 
| + TestImageRep([[image representations] lastObject], isred); | 
| } | 
| TEST_F(SkiaUtilsMacTest, BitmapToNSImage_RedSquare64x64) { | 
| @@ -74,4 +126,49 @@ TEST_F(SkiaUtilsMacTest, BitmapToNSImage_BlueRectangle444) { | 
| ShapeHelper(200, 200, false, false); | 
| } | 
| +TEST_F(SkiaUtilsMacTest, MultipleBitmapsToNSImage) { | 
| + int redWidth = 10; | 
| 
Robert Sesek
2011/04/19 20:53:18
nit: under_scores
 | 
| + int redHeight = 15; | 
| + int blueWidth = 20; | 
| + int blueHeight = 30; | 
| + | 
| + SkBitmap redBitmap(CreateSkBitmap(redWidth, redHeight, true, true)); | 
| + SkBitmap blueBitmap(CreateSkBitmap(blueWidth, blueHeight, false, true)); | 
| + std::vector<const SkBitmap*> bitmaps; | 
| + bitmaps.push_back(&redBitmap); | 
| + bitmaps.push_back(&blueBitmap); | 
| + | 
| + NSImage* image = gfx::SkBitmapsToNSImage(bitmaps); | 
| + | 
| + // Image size should be the same as the smallest bitmap. | 
| + EXPECT_DOUBLE_EQ(redWidth, [image size].width); | 
| + EXPECT_DOUBLE_EQ(redHeight, [image size].height); | 
| + | 
| + EXPECT_EQ(2u, [[image representations] count]); | 
| + | 
| + for (NSBitmapImageRep* imageRep in [image representations]) { | 
| + NSBitmapImageRep* imageRep = [[image representations] objectAtIndex:0]; | 
| + bool isred = [imageRep size].width == redWidth; | 
| + if (isred) { | 
| + EXPECT_DOUBLE_EQ(redHeight, [imageRep size].height); | 
| + } else { | 
| + EXPECT_DOUBLE_EQ(blueWidth, [imageRep size].width); | 
| + EXPECT_DOUBLE_EQ(blueHeight, [imageRep size].height); | 
| + } | 
| + TestImageRep(imageRep, isred); | 
| + } | 
| +} | 
| + | 
| +TEST_F(SkiaUtilsMacTest, NSImageRepToSkBitmap) { | 
| + int width = 10; | 
| + int height = 15; | 
| + bool isred = true; | 
| + | 
| + NSImage* image = CreateNSImage(width, height, isred); | 
| + EXPECT_EQ(1u, [[image representations] count]); | 
| + NSBitmapImageRep* imageRep = [[image representations] lastObject]; | 
| + SkBitmap bitmap(gfx::NSImageRepToSkBitmap(imageRep, [image size], false)); | 
| + TestSkBitmap(bitmap, isred); | 
| +} | 
| + | 
| } // namespace |