| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 | 30 |
| 31 #include "config.h" | 31 #include "config.h" |
| 32 | 32 |
| 33 #include "platform/DragImage.h" | 33 #include "platform/DragImage.h" |
| 34 | 34 |
| 35 #include "platform/fonts/FontDescription.h" | 35 #include "platform/fonts/FontDescription.h" |
| 36 #include "platform/fonts/FontTraits.h" | 36 #include "platform/fonts/FontTraits.h" |
| 37 #include "platform/geometry/IntSize.h" | 37 #include "platform/geometry/IntSize.h" |
| 38 #include "platform/graphics/BitmapImage.h" | 38 #include "platform/graphics/BitmapImage.h" |
| 39 #include "platform/graphics/Image.h" | 39 #include "platform/graphics/Image.h" |
| 40 #include "platform/graphics/skia/NativeImageSkia.h" | |
| 41 #include "platform/weborigin/KURL.h" | 40 #include "platform/weborigin/KURL.h" |
| 42 #include "third_party/skia/include/core/SkBitmap.h" | 41 #include "third_party/skia/include/core/SkBitmap.h" |
| 43 #include "third_party/skia/include/core/SkColor.h" | 42 #include "third_party/skia/include/core/SkColor.h" |
| 44 #include "third_party/skia/include/core/SkPixelRef.h" | 43 #include "third_party/skia/include/core/SkPixelRef.h" |
| 45 #include "wtf/OwnPtr.h" | 44 #include "wtf/OwnPtr.h" |
| 46 #include "wtf/PassOwnPtr.h" | 45 #include "wtf/PassOwnPtr.h" |
| 47 #include "wtf/PassRefPtr.h" | 46 #include "wtf/PassRefPtr.h" |
| 48 #include "wtf/RefPtr.h" | 47 #include "wtf/RefPtr.h" |
| 49 | 48 |
| 50 #include <gtest/gtest.h> | 49 #include <gtest/gtest.h> |
| 51 | 50 |
| 52 using namespace blink; | 51 using namespace blink; |
| 53 | 52 |
| 54 namespace { | 53 namespace { |
| 55 | 54 |
| 56 class TestImage : public Image { | 55 class TestImage : public Image { |
| 57 public: | 56 public: |
| 58 | 57 |
| 59 static PassRefPtr<TestImage> create(const IntSize& size) | 58 static PassRefPtr<TestImage> create(const IntSize& size) |
| 60 { | 59 { |
| 61 return adoptRef(new TestImage(size)); | 60 return adoptRef(new TestImage(size)); |
| 62 } | 61 } |
| 63 | 62 |
| 64 explicit TestImage(const IntSize& size) | 63 explicit TestImage(const IntSize& size) |
| 65 : Image(0) | 64 : Image(0) |
| 66 , m_size(size) | 65 , m_size(size) |
| 67 { | 66 { |
| 68 SkBitmap bitmap; | 67 m_bitmap.allocN32Pixels(size.width(), size.height()); |
| 69 bitmap.allocN32Pixels(size.width(), size.height()); | 68 m_bitmap.eraseColor(SK_ColorTRANSPARENT); |
| 70 bitmap.eraseColor(SK_ColorTRANSPARENT); | |
| 71 m_nativeImage = NativeImageSkia::create(bitmap); | |
| 72 } | 69 } |
| 73 | 70 |
| 74 virtual IntSize size() const override | 71 virtual IntSize size() const override |
| 75 { | 72 { |
| 76 return m_size; | 73 return m_size; |
| 77 } | 74 } |
| 78 | 75 |
| 79 virtual PassRefPtr<NativeImageSkia> nativeImageForCurrentFrame() override | 76 virtual bool bitmapForCurrentFrame(SkBitmap* bitmap) override |
| 80 { | 77 { |
| 81 if (m_size.isZero()) | 78 if (m_size.isZero()) |
| 82 return nullptr; | 79 return false; |
| 83 | 80 |
| 84 return m_nativeImage; | 81 *bitmap = m_bitmap; |
| 82 return true; |
| 85 } | 83 } |
| 86 | 84 |
| 87 // Stub implementations of pure virtual Image functions. | 85 // Stub implementations of pure virtual Image functions. |
| 88 virtual void destroyDecodedData(bool) override | 86 virtual void destroyDecodedData(bool) override |
| 89 { | 87 { |
| 90 } | 88 } |
| 91 | 89 |
| 92 virtual bool currentFrameKnownToBeOpaque() override | 90 virtual bool currentFrameKnownToBeOpaque() override |
| 93 { | 91 { |
| 94 return false; | 92 return false; |
| 95 } | 93 } |
| 96 | 94 |
| 97 void draw(GraphicsContext*, const FloatRect&, const FloatRect&, SkXfermode::
Mode, RespectImageOrientationEnum) override | 95 void draw(GraphicsContext*, const FloatRect&, const FloatRect&, SkXfermode::
Mode, RespectImageOrientationEnum) override |
| 98 { | 96 { |
| 99 } | 97 } |
| 100 | 98 |
| 101 private: | 99 private: |
| 102 | 100 |
| 103 IntSize m_size; | 101 IntSize m_size; |
| 104 | 102 |
| 105 RefPtr<NativeImageSkia> m_nativeImage; | 103 SkBitmap m_bitmap; |
| 106 }; | 104 }; |
| 107 | 105 |
| 108 TEST(DragImageTest, NullHandling) | 106 TEST(DragImageTest, NullHandling) |
| 109 { | 107 { |
| 110 EXPECT_FALSE(DragImage::create(0)); | 108 EXPECT_FALSE(DragImage::create(0)); |
| 111 | 109 |
| 112 RefPtr<TestImage> nullTestImage(TestImage::create(IntSize())); | 110 RefPtr<TestImage> nullTestImage(TestImage::create(IntSize())); |
| 113 EXPECT_FALSE(DragImage::create(nullTestImage.get())); | 111 EXPECT_FALSE(DragImage::create(nullTestImage.get())); |
| 114 } | 112 } |
| 115 | 113 |
| 116 TEST(DragImageTest, NonNullHandling) | 114 TEST(DragImageTest, NonNullHandling) |
| 117 { | 115 { |
| 118 RefPtr<TestImage> testImage(TestImage::create(IntSize(2, 2))); | 116 RefPtr<TestImage> testImage(TestImage::create(IntSize(2, 2))); |
| 119 OwnPtr<DragImage> dragImage = DragImage::create(testImage.get()); | 117 OwnPtr<DragImage> dragImage = DragImage::create(testImage.get()); |
| 120 ASSERT_TRUE(dragImage); | 118 ASSERT_TRUE(dragImage); |
| 121 | 119 |
| 122 dragImage->scale(0.5, 0.5); | 120 dragImage->scale(0.5, 0.5); |
| 123 IntSize size = dragImage->size(); | 121 IntSize size = dragImage->size(); |
| 124 EXPECT_EQ(1, size.width()); | 122 EXPECT_EQ(1, size.width()); |
| 125 EXPECT_EQ(1, size.height()); | 123 EXPECT_EQ(1, size.height()); |
| 126 | 124 |
| 127 dragImage->dissolveToFraction(0.5); | 125 dragImage->dissolveToFraction(0.5); |
| 128 } | 126 } |
| 129 | 127 |
| 130 TEST(DragImageTest, CreateDragImage) | 128 TEST(DragImageTest, CreateDragImage) |
| 131 { | 129 { |
| 132 { | 130 { |
| 133 // Tests that the DrageImage implementation doesn't choke on null values | 131 // Tests that the DrageImage implementation doesn't choke on null values |
| 134 // of nativeImageForCurrentFrame(). | 132 // of bitmapForCurrentFrame(). |
| 135 RefPtr<TestImage> testImage(TestImage::create(IntSize())); | 133 RefPtr<TestImage> testImage(TestImage::create(IntSize())); |
| 136 EXPECT_FALSE(DragImage::create(testImage.get())); | 134 EXPECT_FALSE(DragImage::create(testImage.get())); |
| 137 } | 135 } |
| 138 | 136 |
| 139 { | 137 { |
| 140 // Tests that the drag image is a deep copy. | 138 // Tests that the drag image is a deep copy. |
| 141 RefPtr<TestImage> testImage(TestImage::create(IntSize(1, 1))); | 139 RefPtr<TestImage> testImage(TestImage::create(IntSize(1, 1))); |
| 142 OwnPtr<DragImage> dragImage = DragImage::create(testImage.get()); | 140 OwnPtr<DragImage> dragImage = DragImage::create(testImage.get()); |
| 143 ASSERT_TRUE(dragImage); | 141 ASSERT_TRUE(dragImage); |
| 144 SkAutoLockPixels lock1(dragImage->bitmap()), lock2(testImage->nativeImag
eForCurrentFrame()->bitmap()); | 142 SkBitmap bitmap; |
| 145 EXPECT_NE(dragImage->bitmap().getPixels(), testImage->nativeImageForCurr
entFrame()->bitmap().getPixels()); | 143 EXPECT_TRUE(testImage->bitmapForCurrentFrame(&bitmap)); |
| 144 SkAutoLockPixels lock1(dragImage->bitmap()), lock2(bitmap); |
| 145 EXPECT_NE(dragImage->bitmap().getPixels(), bitmap.getPixels()); |
| 146 } | 146 } |
| 147 } | 147 } |
| 148 | 148 |
| 149 TEST(DragImageTest, TrimWhitespace) | 149 TEST(DragImageTest, TrimWhitespace) |
| 150 { | 150 { |
| 151 KURL url(ParsedURLString, "http://www.example.com/"); | 151 KURL url(ParsedURLString, "http://www.example.com/"); |
| 152 String testLabel = " Example Example Example \n "; | 152 String testLabel = " Example Example Example \n "; |
| 153 String expectedLabel = "Example Example Example"; | 153 String expectedLabel = "Example Example Example"; |
| 154 float deviceScaleFactor = 1.0f; | 154 float deviceScaleFactor = 1.0f; |
| 155 | 155 |
| (...skipping 28 matching lines...) Expand all Loading... |
| 184 // This test is mostly useful with MSAN builds, which can actually detect | 184 // This test is mostly useful with MSAN builds, which can actually detect |
| 185 // the use of uninitialized memory. | 185 // the use of uninitialized memory. |
| 186 | 186 |
| 187 // Create a BitmapImage which will fail to produce pixels, and hence not | 187 // Create a BitmapImage which will fail to produce pixels, and hence not |
| 188 // draw. | 188 // draw. |
| 189 SkImageInfo info = SkImageInfo::MakeN32Premul(100, 100); | 189 SkImageInfo info = SkImageInfo::MakeN32Premul(100, 100); |
| 190 RefPtr<SkPixelRef> pixelRef = adoptRef(new InvalidPixelRef(info)); | 190 RefPtr<SkPixelRef> pixelRef = adoptRef(new InvalidPixelRef(info)); |
| 191 SkBitmap invalidBitmap; | 191 SkBitmap invalidBitmap; |
| 192 invalidBitmap.setInfo(info); | 192 invalidBitmap.setInfo(info); |
| 193 invalidBitmap.setPixelRef(pixelRef.get()); | 193 invalidBitmap.setPixelRef(pixelRef.get()); |
| 194 RefPtr<NativeImageSkia> nativeImage = NativeImageSkia::create(invalidBitmap)
; | 194 RefPtr<BitmapImage> image = BitmapImage::createWithOrientationForTesting(inv
alidBitmap, OriginRightTop); |
| 195 RefPtr<BitmapImage> image = BitmapImage::createWithOrientationForTesting(nat
iveImage, OriginRightTop); | |
| 196 | 195 |
| 197 // Create a DragImage from it. In MSAN builds, this will cause a failure if | 196 // Create a DragImage from it. In MSAN builds, this will cause a failure if |
| 198 // the pixel memory is not initialized, if we have to respect non-default | 197 // the pixel memory is not initialized, if we have to respect non-default |
| 199 // orientation. | 198 // orientation. |
| 200 OwnPtr<DragImage> dragImage = DragImage::create(image.get(), RespectImageOri
entation); | 199 OwnPtr<DragImage> dragImage = DragImage::create(image.get(), RespectImageOri
entation); |
| 201 | 200 |
| 202 // The DragImage should be fully transparent. | 201 // The DragImage should be fully transparent. |
| 203 SkBitmap dragImageBitmap = dragImage->bitmap(); | 202 const SkBitmap& dragImageBitmap = dragImage->bitmap(); |
| 204 SkAutoLockPixels lock(dragImageBitmap); | 203 SkAutoLockPixels lock(dragImageBitmap); |
| 205 ASSERT_NE(nullptr, dragImageBitmap.getPixels()); | 204 ASSERT_NE(nullptr, dragImageBitmap.getPixels()); |
| 206 for (int x = 0; x < dragImageBitmap.width(); x++) { | 205 for (int x = 0; x < dragImageBitmap.width(); x++) { |
| 207 for (int y = 0; y < dragImageBitmap.height(); y++) { | 206 for (int y = 0; y < dragImageBitmap.height(); y++) { |
| 208 int alpha = SkColorGetA(dragImageBitmap.getColor(x, y)); | 207 int alpha = SkColorGetA(dragImageBitmap.getColor(x, y)); |
| 209 ASSERT_EQ(0, alpha); | 208 ASSERT_EQ(0, alpha); |
| 210 } | 209 } |
| 211 } | 210 } |
| 212 } | 211 } |
| 213 | 212 |
| 214 TEST(DragImageTest, InterpolationNone) | 213 TEST(DragImageTest, InterpolationNone) |
| 215 { | 214 { |
| 216 SkBitmap expectedBitmap; | 215 SkBitmap expectedBitmap; |
| 217 expectedBitmap.allocN32Pixels(4, 4); | 216 expectedBitmap.allocN32Pixels(4, 4); |
| 218 { | 217 { |
| 219 SkAutoLockPixels lock(expectedBitmap); | 218 SkAutoLockPixels lock(expectedBitmap); |
| 220 expectedBitmap.eraseArea(SkIRect::MakeXYWH(0, 0, 2, 2), 0xFFFFFFFF); | 219 expectedBitmap.eraseArea(SkIRect::MakeXYWH(0, 0, 2, 2), 0xFFFFFFFF); |
| 221 expectedBitmap.eraseArea(SkIRect::MakeXYWH(0, 2, 2, 2), 0xFF000000); | 220 expectedBitmap.eraseArea(SkIRect::MakeXYWH(0, 2, 2, 2), 0xFF000000); |
| 222 expectedBitmap.eraseArea(SkIRect::MakeXYWH(2, 0, 2, 2), 0xFF000000); | 221 expectedBitmap.eraseArea(SkIRect::MakeXYWH(2, 0, 2, 2), 0xFF000000); |
| 223 expectedBitmap.eraseArea(SkIRect::MakeXYWH(2, 2, 2, 2), 0xFFFFFFFF); | 222 expectedBitmap.eraseArea(SkIRect::MakeXYWH(2, 2, 2, 2), 0xFFFFFFFF); |
| 224 } | 223 } |
| 225 | 224 |
| 226 RefPtr<TestImage> testImage(TestImage::create(IntSize(2, 2))); | 225 RefPtr<TestImage> testImage(TestImage::create(IntSize(2, 2))); |
| 227 const SkBitmap& testBitmap = testImage->nativeImageForCurrentFrame()->bitmap
(); | 226 SkBitmap testBitmap; |
| 227 EXPECT_TRUE(testImage->bitmapForCurrentFrame(&testBitmap)); |
| 228 { | 228 { |
| 229 SkAutoLockPixels lock(testBitmap); | 229 SkAutoLockPixels lock(testBitmap); |
| 230 testBitmap.eraseArea(SkIRect::MakeXYWH(0, 0, 1, 1), 0xFFFFFFFF); | 230 testBitmap.eraseArea(SkIRect::MakeXYWH(0, 0, 1, 1), 0xFFFFFFFF); |
| 231 testBitmap.eraseArea(SkIRect::MakeXYWH(0, 1, 1, 1), 0xFF000000); | 231 testBitmap.eraseArea(SkIRect::MakeXYWH(0, 1, 1, 1), 0xFF000000); |
| 232 testBitmap.eraseArea(SkIRect::MakeXYWH(1, 0, 1, 1), 0xFF000000); | 232 testBitmap.eraseArea(SkIRect::MakeXYWH(1, 0, 1, 1), 0xFF000000); |
| 233 testBitmap.eraseArea(SkIRect::MakeXYWH(1, 1, 1, 1), 0xFFFFFFFF); | 233 testBitmap.eraseArea(SkIRect::MakeXYWH(1, 1, 1, 1), 0xFFFFFFFF); |
| 234 } | 234 } |
| 235 | 235 |
| 236 OwnPtr<DragImage> dragImage = DragImage::create(testImage.get(), DoNotRespec
tImageOrientation, 1, InterpolationNone); | 236 OwnPtr<DragImage> dragImage = DragImage::create(testImage.get(), DoNotRespec
tImageOrientation, 1, InterpolationNone); |
| 237 ASSERT_TRUE(dragImage); | 237 ASSERT_TRUE(dragImage); |
| 238 dragImage->scale(2, 2); | 238 dragImage->scale(2, 2); |
| 239 const SkBitmap& dragBitmap = dragImage->bitmap(); | 239 const SkBitmap& dragBitmap = dragImage->bitmap(); |
| 240 { | 240 { |
| 241 SkAutoLockPixels lock1(dragBitmap); | 241 SkAutoLockPixels lock1(dragBitmap); |
| 242 SkAutoLockPixels lock2(expectedBitmap); | 242 SkAutoLockPixels lock2(expectedBitmap); |
| 243 for (int x = 0; x < dragBitmap.width(); ++x) | 243 for (int x = 0; x < dragBitmap.width(); ++x) |
| 244 for (int y = 0; y < dragBitmap.height(); ++y) | 244 for (int y = 0; y < dragBitmap.height(); ++y) |
| 245 EXPECT_EQ(expectedBitmap.getColor(x, y), dragBitmap.getColor(x,
y)); | 245 EXPECT_EQ(expectedBitmap.getColor(x, y), dragBitmap.getColor(x,
y)); |
| 246 } | 246 } |
| 247 } | 247 } |
| 248 | 248 |
| 249 } // anonymous namespace | 249 } // anonymous namespace |
| OLD | NEW |