Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(11)

Side by Side Diff: components/suggestions/image_encoder_ios.mm

Issue 1156003008: Decode ImageManager cached images on demand. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Don't use MessageLoop API Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « components/suggestions/image_encoder.cc ('k') | components/suggestions/image_manager.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #include "components/suggestions/image_encoder.h" 5 #include "components/suggestions/image_encoder.h"
6 6
7 #import <UIKit/UIKit.h> 7 #import <UIKit/UIKit.h>
8 8
9 #include "base/mac/scoped_cftyperef.h" 9 #include "base/mac/scoped_cftyperef.h"
10 #include "skia/ext/skia_utils_ios.h" 10 #include "skia/ext/skia_utils_ios.h"
11 11
12 namespace suggestions { 12 namespace suggestions {
13 13
14 SkBitmap* DecodeJPEGToSkBitmap(const std::vector<unsigned char>& encoded_data) { 14 SkBitmap* DecodeJPEGToSkBitmap(const void* encoded_data, size_t size) {
15 NSData* data = 15 NSData* data = [NSData dataWithBytes:encoded_data length:size];
16 [NSData dataWithBytes:encoded_data.data() length:encoded_data.size()]; 16 UIImage* image = [UIImage imageWithData:data scale:1.0];
17 UIImage* image =
18 [UIImage imageWithData:data scale:1.0];
19 return new SkBitmap(gfx::CGImageToSkBitmap(image.CGImage, [image size], YES)); 17 return new SkBitmap(gfx::CGImageToSkBitmap(image.CGImage, [image size], YES));
20 } 18 }
21 19
22 bool EncodeSkBitmapToJPEG(const SkBitmap& bitmap, 20 bool EncodeSkBitmapToJPEG(const SkBitmap& bitmap,
23 std::vector<unsigned char>* dest) { 21 std::vector<unsigned char>* dest) {
24 base::ScopedCFTypeRef<CGColorSpaceRef> color_space( 22 base::ScopedCFTypeRef<CGColorSpaceRef> color_space(
25 CGColorSpaceCreateDeviceRGB()); 23 CGColorSpaceCreateDeviceRGB());
26 UIImage* image = 24 UIImage* image =
27 gfx::SkBitmapToUIImageWithColorSpace(bitmap, 1 /* scale */, color_space); 25 gfx::SkBitmapToUIImageWithColorSpace(bitmap, 1 /* scale */, color_space);
28 NSData* data = UIImageJPEGRepresentation(image, 1.0); 26 NSData* data = UIImageJPEGRepresentation(image, 1.0);
29 const char* bytes = reinterpret_cast<const char*>([data bytes]); 27 const char* bytes = reinterpret_cast<const char*>([data bytes]);
30 dest->assign(bytes, bytes + [data length]); 28 dest->assign(bytes, bytes + [data length]);
31 return true; 29 return true;
32 } 30 }
33 31
34 } // namespace suggestions 32 } // namespace suggestions
OLDNEW
« no previous file with comments | « components/suggestions/image_encoder.cc ('k') | components/suggestions/image_manager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698