OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "chrome/browser/favicon/favicon_util.h" | 5 #include "chrome/browser/favicon/favicon_util.h" |
6 | 6 |
7 #include "chrome/browser/history/select_favicon_frames.h" | 7 #include "chrome/browser/history/select_favicon_frames.h" |
8 #include "chrome/common/favicon/favicon_types.h" | 8 #include "chrome/common/favicon/favicon_types.h" |
9 #include "skia/ext/image_operations.h" | 9 #include "skia/ext/image_operations.h" |
10 #include "third_party/skia/include/core/SkBitmap.h" | 10 #include "third_party/skia/include/core/SkBitmap.h" |
(...skipping 24 matching lines...) Expand all Loading... |
35 if (favicon_size == 0) { | 35 if (favicon_size == 0) { |
36 int maximum_area = 0; | 36 int maximum_area = 0; |
37 scoped_refptr<base::RefCountedMemory> best_candidate; | 37 scoped_refptr<base::RefCountedMemory> best_candidate; |
38 for (size_t i = 0; i < png_data.size(); ++i) { | 38 for (size_t i = 0; i < png_data.size(); ++i) { |
39 int area = png_data[i].pixel_size.GetArea(); | 39 int area = png_data[i].pixel_size.GetArea(); |
40 if (area > maximum_area) { | 40 if (area > maximum_area) { |
41 maximum_area = area; | 41 maximum_area = area; |
42 best_candidate = png_data[i].bitmap_data; | 42 best_candidate = png_data[i].bitmap_data; |
43 } | 43 } |
44 } | 44 } |
45 png_reps.push_back(gfx::ImagePNGRep(best_candidate, | 45 png_reps.push_back(gfx::ImagePNGRep(best_candidate, 1.0f)); |
46 ui::SCALE_FACTOR_100P)); | |
47 return png_reps; | 46 return png_reps; |
48 } | 47 } |
49 | 48 |
50 // Cache the scale factor for each pixel size as |scale_factors| may contain | 49 // Cache the scale factor for each pixel size as |scale_factors| may contain |
51 // any of GetFaviconScaleFactors() which may include scale factors not | 50 // any of GetFaviconScaleFactors() which may include scale factors not |
52 // supported by the platform. (ui::GetScaleFactorFromScale() cannot be used.) | 51 // supported by the platform. (ui::GetSupportedScaleFactor() cannot be used.) |
53 std::map<int, ui::ScaleFactor> desired_pixel_sizes; | 52 std::map<int, ui::ScaleFactor> desired_pixel_sizes; |
54 for (size_t i = 0; i < scale_factors.size(); ++i) { | 53 for (size_t i = 0; i < scale_factors.size(); ++i) { |
55 int pixel_size = floor(favicon_size * | 54 int pixel_size = floor(favicon_size * |
56 ui::GetScaleFactorScale(scale_factors[i])); | 55 ui::GetImageScale(scale_factors[i])); |
57 desired_pixel_sizes[pixel_size] = scale_factors[i]; | 56 desired_pixel_sizes[pixel_size] = scale_factors[i]; |
58 } | 57 } |
59 | 58 |
60 for (size_t i = 0; i < png_data.size(); ++i) { | 59 for (size_t i = 0; i < png_data.size(); ++i) { |
61 if (!png_data[i].is_valid()) | 60 if (!png_data[i].is_valid()) |
62 continue; | 61 continue; |
63 | 62 |
64 const gfx::Size& pixel_size = png_data[i].pixel_size; | 63 const gfx::Size& pixel_size = png_data[i].pixel_size; |
65 if (pixel_size.width() != pixel_size.height()) | 64 if (pixel_size.width() != pixel_size.height()) |
66 continue; | 65 continue; |
67 | 66 |
68 std::map<int, ui::ScaleFactor>::iterator it = desired_pixel_sizes.find( | 67 std::map<int, ui::ScaleFactor>::iterator it = desired_pixel_sizes.find( |
69 pixel_size.width()); | 68 pixel_size.width()); |
70 if (it == desired_pixel_sizes.end()) | 69 if (it == desired_pixel_sizes.end()) |
71 continue; | 70 continue; |
72 | 71 |
73 png_reps.push_back(gfx::ImagePNGRep(png_data[i].bitmap_data, it->second)); | 72 png_reps.push_back( |
| 73 gfx::ImagePNGRep(png_data[i].bitmap_data, |
| 74 ui::GetImageScale(it->second))); |
74 } | 75 } |
75 | 76 |
76 return png_reps; | 77 return png_reps; |
77 } | 78 } |
78 | 79 |
79 } // namespace | 80 } // namespace |
80 | 81 |
81 // static | 82 // static |
82 std::vector<ui::ScaleFactor> FaviconUtil::GetFaviconScaleFactors() { | 83 std::vector<ui::ScaleFactor> FaviconUtil::GetFaviconScaleFactors() { |
83 const float kScale1x = ui::GetScaleFactorScale(ui::SCALE_FACTOR_100P); | 84 const float kScale1x = ui::GetImageScale(ui::SCALE_FACTOR_100P); |
84 std::vector<ui::ScaleFactor> favicon_scale_factors = | 85 std::vector<ui::ScaleFactor> favicon_scale_factors = |
85 ui::GetSupportedScaleFactors(); | 86 ui::GetSupportedScaleFactors(); |
86 | 87 |
87 // The scale factors returned from ui::GetSupportedScaleFactors() are sorted. | 88 // The scale factors returned from ui::GetSupportedScaleFactors() are sorted. |
88 // Insert the 1x scale factor such that GetFaviconScaleFactors() is sorted as | 89 // Insert the 1x scale factor such that GetFaviconScaleFactors() is sorted as |
89 // well. | 90 // well. |
90 size_t insert_index = favicon_scale_factors.size(); | 91 size_t insert_index = favicon_scale_factors.size(); |
91 for (size_t i = 0; i < favicon_scale_factors.size(); ++i) { | 92 for (size_t i = 0; i < favicon_scale_factors.size(); ++i) { |
92 float scale = ui::GetScaleFactorScale(favicon_scale_factors[i]); | 93 float scale = ui::GetImageScale(favicon_scale_factors[i]); |
93 if (scale == kScale1x) { | 94 if (scale == kScale1x) { |
94 return favicon_scale_factors; | 95 return favicon_scale_factors; |
95 } else if (scale > kScale1x) { | 96 } else if (scale > kScale1x) { |
96 insert_index = i; | 97 insert_index = i; |
97 break; | 98 break; |
98 } | 99 } |
99 } | 100 } |
100 // TODO(ios): 100p should not be necessary on iOS retina devices. However | 101 // TODO(ios): 100p should not be necessary on iOS retina devices. However |
101 // the sync service only supports syncing 100p favicons. Until sync supports | 102 // the sync service only supports syncing 100p favicons. Until sync supports |
102 // other scales 100p is needed in the list of scale factors to retrieve and | 103 // other scales 100p is needed in the list of scale factors to retrieve and |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
137 // SelectFaviconFramesFromPNGsWithoutResizing() should have selected the | 138 // SelectFaviconFramesFromPNGsWithoutResizing() should have selected the |
138 // largest favicon if |favicon_size| == 0. | 139 // largest favicon if |favicon_size| == 0. |
139 if (favicon_size == 0) | 140 if (favicon_size == 0) |
140 return gfx::Image(png_reps); | 141 return gfx::Image(png_reps); |
141 | 142 |
142 std::vector<ui::ScaleFactor> scale_factors_to_generate = scale_factors; | 143 std::vector<ui::ScaleFactor> scale_factors_to_generate = scale_factors; |
143 for (size_t i = 0; i < png_reps.size(); ++i) { | 144 for (size_t i = 0; i < png_reps.size(); ++i) { |
144 std::vector<ui::ScaleFactor>::iterator it = std::find( | 145 std::vector<ui::ScaleFactor>::iterator it = std::find( |
145 scale_factors_to_generate.begin(), | 146 scale_factors_to_generate.begin(), |
146 scale_factors_to_generate.end(), | 147 scale_factors_to_generate.end(), |
147 png_reps[i].scale_factor); | 148 ui::GetSupportedScaleFactor(png_reps[i].scale)); |
148 CHECK(it != scale_factors_to_generate.end()); | 149 CHECK(it != scale_factors_to_generate.end()); |
149 scale_factors_to_generate.erase(it); | 150 scale_factors_to_generate.erase(it); |
150 } | 151 } |
151 | 152 |
152 if (scale_factors_to_generate.empty()) | 153 if (scale_factors_to_generate.empty()) |
153 return gfx::Image(png_reps); | 154 return gfx::Image(png_reps); |
154 | 155 |
155 std::vector<SkBitmap> bitmaps; | 156 std::vector<SkBitmap> bitmaps; |
156 for (size_t i = 0; i < png_data.size(); ++i) { | 157 for (size_t i = 0; i < png_data.size(); ++i) { |
157 if (!png_data[i].is_valid()) | 158 if (!png_data[i].is_valid()) |
(...skipping 16 matching lines...) Expand all Loading... |
174 if (png_reps.empty()) | 175 if (png_reps.empty()) |
175 return gfx::Image(resized_image_skia); | 176 return gfx::Image(resized_image_skia); |
176 | 177 |
177 std::vector<gfx::ImageSkiaRep> resized_image_skia_reps = | 178 std::vector<gfx::ImageSkiaRep> resized_image_skia_reps = |
178 resized_image_skia.image_reps(); | 179 resized_image_skia.image_reps(); |
179 for (size_t i = 0; i < resized_image_skia_reps.size(); ++i) { | 180 for (size_t i = 0; i < resized_image_skia_reps.size(); ++i) { |
180 scoped_refptr<base::RefCountedBytes> png_bytes(new base::RefCountedBytes()); | 181 scoped_refptr<base::RefCountedBytes> png_bytes(new base::RefCountedBytes()); |
181 if (gfx::PNGCodec::EncodeBGRASkBitmap( | 182 if (gfx::PNGCodec::EncodeBGRASkBitmap( |
182 resized_image_skia_reps[i].sk_bitmap(), false, &png_bytes->data())) { | 183 resized_image_skia_reps[i].sk_bitmap(), false, &png_bytes->data())) { |
183 png_reps.push_back(gfx::ImagePNGRep(png_bytes, | 184 png_reps.push_back(gfx::ImagePNGRep(png_bytes, |
184 resized_image_skia_reps[i].scale_factor())); | 185 resized_image_skia_reps[i].scale())); |
185 } | 186 } |
186 } | 187 } |
187 | 188 |
188 return gfx::Image(png_reps); | 189 return gfx::Image(png_reps); |
189 } | 190 } |
190 | 191 |
191 // static | 192 // static |
192 size_t FaviconUtil::SelectBestFaviconFromBitmaps( | 193 size_t FaviconUtil::SelectBestFaviconFromBitmaps( |
193 const std::vector<SkBitmap>& bitmaps, | 194 const std::vector<SkBitmap>& bitmaps, |
194 const std::vector<ui::ScaleFactor>& scale_factors, | 195 const std::vector<ui::ScaleFactor>& scale_factors, |
195 int desired_size) { | 196 int desired_size) { |
196 std::vector<gfx::Size> sizes; | 197 std::vector<gfx::Size> sizes; |
197 for (size_t i = 0; i < bitmaps.size(); ++i) | 198 for (size_t i = 0; i < bitmaps.size(); ++i) |
198 sizes.push_back(gfx::Size(bitmaps[i].width(), bitmaps[i].height())); | 199 sizes.push_back(gfx::Size(bitmaps[i].width(), bitmaps[i].height())); |
199 std::vector<size_t> selected_bitmap_indices; | 200 std::vector<size_t> selected_bitmap_indices; |
200 SelectFaviconFrameIndices(sizes, scale_factors, desired_size, | 201 SelectFaviconFrameIndices(sizes, scale_factors, desired_size, |
201 &selected_bitmap_indices, NULL); | 202 &selected_bitmap_indices, NULL); |
202 DCHECK_EQ(1u, selected_bitmap_indices.size()); | 203 DCHECK_EQ(1u, selected_bitmap_indices.size()); |
203 return selected_bitmap_indices[0]; | 204 return selected_bitmap_indices[0]; |
204 } | 205 } |
OLD | NEW |