| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // WARNING! This file is copied from third_party/skia/tools/skpdiff and slightly | 5 // WARNING! This file is copied from third_party/skia/tools/skpdiff and slightly |
| 6 // modified to be compilable outside Skia and suit chromium style. Some comments | 6 // modified to be compilable outside Skia and suit chromium style. Some comments |
| 7 // can make no sense. | 7 // can make no sense. |
| 8 // TODO(elizavetai): remove this file and reuse the original one in Skia | 8 // TODO(elizavetai): remove this file and reuse the original one in Skia |
| 9 | 9 |
| 10 #include <cmath> | 10 #include <cmath> |
| (...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 121 } | 121 } |
| 122 lab->l = 116.0f * f[1] - 16.0f; | 122 lab->l = 116.0f * f[1] - 16.0f; |
| 123 lab->a = 500.0f * (f[0] - f[1]); | 123 lab->a = 500.0f * (f[0] - f[1]); |
| 124 lab->b = 200.0f * (f[1] - f[2]); | 124 lab->b = 200.0f * (f[1] - f[2]); |
| 125 } | 125 } |
| 126 | 126 |
| 127 /// Converts a 8888 bitmap to LAB color space and puts it into the output | 127 /// Converts a 8888 bitmap to LAB color space and puts it into the output |
| 128 static bool bitmap_to_cielab(const SkBitmap* bitmap, ImageLAB* outImageLAB) { | 128 static bool bitmap_to_cielab(const SkBitmap* bitmap, ImageLAB* outImageLAB) { |
| 129 SkBitmap bm8888; | 129 SkBitmap bm8888; |
| 130 if (bitmap->colorType() != kN32_SkColorType) { | 130 if (bitmap->colorType() != kN32_SkColorType) { |
| 131 if (!bitmap->copyTo(&bm8888, kN32_SkColorType)) { | 131 SkImageInfo info8888 = bitmap->info().makeColorType(kN32_SkColorType); |
| 132 if (!bm8888.tryAllocPixels(info8888) || |
| 133 !bitmap->readPixels(info8888, bm8888.getPixels(), bm8888.rowBytes(), 0, |
| 134 0)) { |
| 132 return false; | 135 return false; |
| 133 } | 136 } |
| 134 bitmap = &bm8888; | 137 bitmap = &bm8888; |
| 135 } | 138 } |
| 136 | 139 |
| 137 int width = bitmap->width(); | 140 int width = bitmap->width(); |
| 138 int height = bitmap->height(); | 141 int height = bitmap->height(); |
| 139 DCHECK(outImageLAB->width == width); | 142 DCHECK(outImageLAB->width == width); |
| 140 DCHECK(outImageLAB->height == height); | 143 DCHECK(outImageLAB->height == height); |
| 141 | 144 |
| (...skipping 327 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 469 if (!bitmap_to_cielab(baseline, &baselineLAB) || | 472 if (!bitmap_to_cielab(baseline, &baselineLAB) || |
| 470 !bitmap_to_cielab(test, &testLAB)) { | 473 !bitmap_to_cielab(test, &testLAB)) { |
| 471 return true; | 474 return true; |
| 472 } | 475 } |
| 473 | 476 |
| 474 result->poiCount = 0; | 477 result->poiCount = 0; |
| 475 result->result = pmetric(&baselineLAB, &testLAB, &result->poiCount); | 478 result->result = pmetric(&baselineLAB, &testLAB, &result->poiCount); |
| 476 | 479 |
| 477 return true; | 480 return true; |
| 478 } | 481 } |
| OLD | NEW |