| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #ifndef UI_GFX_COLOR_ANALYSIS_H_ | 5 #ifndef UI_GFX_COLOR_ANALYSIS_H_ |
| 6 #define UI_GFX_COLOR_ANALYSIS_H_ | 6 #define UI_GFX_COLOR_ANALYSIS_H_ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
| 10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 50 int calls_; | 50 int calls_; |
| 51 }; | 51 }; |
| 52 | 52 |
| 53 // Returns a recommended background color for a PNG image. This color might | 53 // Returns a recommended background color for a PNG image. This color might |
| 54 // not even exist in the image, but it is typically representative of the | 54 // not even exist in the image, but it is typically representative of the |
| 55 // image and tinted towards the white end of the spectrum. | 55 // image and tinted towards the white end of the spectrum. |
| 56 // The function CalculateKMeanColorOfPNG is used to grab the KMean calculated | 56 // The function CalculateKMeanColorOfPNG is used to grab the KMean calculated |
| 57 // color of the image, then the color is moved to HSV space so the saturation | 57 // color of the image, then the color is moved to HSV space so the saturation |
| 58 // and luminance can be modified to move the color towards the white end of | 58 // and luminance can be modified to move the color towards the white end of |
| 59 // the spectrum. The color is then moved back to RGB space and returned. | 59 // the spectrum. The color is then moved back to RGB space and returned. |
| 60 SkColor CalculateRecommendedBgColorForPNG(scoped_refptr<RefCountedMemory> png); | 60 SkColor CalculateRecommendedBgColorForPNG( |
| 61 scoped_refptr<base::RefCountedMemory> png); |
| 61 | 62 |
| 62 SkColor CalculateRecommendedBgColorForPNG(scoped_refptr<RefCountedMemory> png, | 63 SkColor CalculateRecommendedBgColorForPNG( |
| 63 KMeanImageSampler& sampler); | 64 scoped_refptr<base::RefCountedMemory> png, |
| 65 KMeanImageSampler& sampler); |
| 64 | 66 |
| 65 // Returns an SkColor that represents the calculated dominant color in the png. | 67 // Returns an SkColor that represents the calculated dominant color in the png. |
| 66 // This uses a KMean clustering algorithm to find clusters of pixel colors in | 68 // This uses a KMean clustering algorithm to find clusters of pixel colors in |
| 67 // RGB space. | 69 // RGB space. |
| 68 // |png| represents the data of a png encoded image. | 70 // |png| represents the data of a png encoded image. |
| 69 // |darkness_limit| represents the minimum sum of the RGB components that is | 71 // |darkness_limit| represents the minimum sum of the RGB components that is |
| 70 // acceptable as a color choice. This can be from 0 to 765. | 72 // acceptable as a color choice. This can be from 0 to 765. |
| 71 // |brightness_limit| represents the maximum sum of the RGB components that is | 73 // |brightness_limit| represents the maximum sum of the RGB components that is |
| 72 // acceptable as a color choice. This can be from 0 to 765. | 74 // acceptable as a color choice. This can be from 0 to 765. |
| 73 // | 75 // |
| (...skipping 18 matching lines...) Expand all Loading... |
| 92 // b) If any centroid moved, repeat step 2 with the new centroids for up | 94 // b) If any centroid moved, repeat step 2 with the new centroids for up |
| 93 // to M iterations. | 95 // to M iterations. |
| 94 // 5.Once the clusters have converged or M iterations have been tried, sort | 96 // 5.Once the clusters have converged or M iterations have been tried, sort |
| 95 // the clusters by weight (where weight is the number of pixels that make up | 97 // the clusters by weight (where weight is the number of pixels that make up |
| 96 // this cluster). | 98 // this cluster). |
| 97 // 6.Going through the sorted list of clusters, pick the first cluster with the | 99 // 6.Going through the sorted list of clusters, pick the first cluster with the |
| 98 // largest weight that's centroid fulfills the equation | 100 // largest weight that's centroid fulfills the equation |
| 99 // |darkness_limit| < SUM(R, G, B) < |brightness_limit|. Return that color. | 101 // |darkness_limit| < SUM(R, G, B) < |brightness_limit|. Return that color. |
| 100 // If no color fulfills that requirement return the color with the largest | 102 // If no color fulfills that requirement return the color with the largest |
| 101 // weight regardless of whether or not it fulfills the equation above. | 103 // weight regardless of whether or not it fulfills the equation above. |
| 102 SkColor CalculateKMeanColorOfPNG(scoped_refptr<RefCountedMemory> png, | 104 SkColor CalculateKMeanColorOfPNG(scoped_refptr<base::RefCountedMemory> png, |
| 103 uint32_t darkness_limit, | 105 uint32_t darkness_limit, |
| 104 uint32_t brightness_limit); | 106 uint32_t brightness_limit); |
| 105 | 107 |
| 106 UI_EXPORT SkColor CalculateKMeanColorOfPNG(scoped_refptr<RefCountedMemory> png, | 108 UI_EXPORT SkColor CalculateKMeanColorOfPNG( |
| 107 uint32_t darkness_limit, | 109 scoped_refptr<base::RefCountedMemory> png, |
| 108 uint32_t brightness_limit, | 110 uint32_t darkness_limit, |
| 109 KMeanImageSampler& sampler); | 111 uint32_t brightness_limit, |
| 112 KMeanImageSampler& sampler); |
| 110 | 113 |
| 111 } // namespace color_utils | 114 } // namespace color_utils |
| 112 | 115 |
| 113 #endif // UI_GFX_COLOR_ANALYSIS_H_ | 116 #endif // UI_GFX_COLOR_ANALYSIS_H_ |
| OLD | NEW |