Chromium Code Reviews| Index: ios/chrome/browser/snapshots/snapshot_manager.h |
| diff --git a/ios/chrome/browser/snapshots/snapshot_manager.h b/ios/chrome/browser/snapshots/snapshot_manager.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..b22ce3e32aa13858446416ad10d8c5429842717d |
| --- /dev/null |
| +++ b/ios/chrome/browser/snapshots/snapshot_manager.h |
| @@ -0,0 +1,54 @@ |
| +// Copyright 2012 The Chromium Authors. All rights reserved. |
|
Paweł Hajdan Jr.
2015/01/30 12:24:29
nit: 2015
|
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef IOS_CHROME_BROWSER_SNAPSHOTS_SNAPSHOT_MANAGER_H_ |
| +#define IOS_CHROME_BROWSER_SNAPSHOTS_SNAPSHOT_MANAGER_H_ |
| + |
| +#import <UIKit/UIKit.h> |
| + |
| +// Snapshot manager for contents of a tab. A snapshot is a full-screen image |
| +// of the contents of the page at the current scroll offset and zoom level, |
| +// used to stand in for the UIWebView if it has been purged from memory or when |
| +// quickly switching tabs. Uses |SnapshotCache| to cache (and persist) |
| +// snapshots. |
| +// |
| +// The snapshots are identified by a "session id" which is unique per tab. This |
| +// allows quick identification and replacement as a tab changes pages. |
| +@interface SnapshotManager : NSObject |
| + |
| +// Takes a snapshot for the supplied view. Returns an autoreleased image |
| +// cropped and scaled appropriately. The image is not yet cached. |
| +// The image can also contain overlays (if |overlays| is not nil and not empty). |
| +- (UIImage*)generateSnapshotForView:(UIView*)view |
| + withRect:(CGRect)rect |
| + overlays:(NSArray*)overlays; |
| + |
| +// TODO(shreyasv): Consider passing the sessionID into SnapshotManager from Tab |
| +// in the init method and simplifying the following methods. |
| +// Retrieve a cached snapshot for the |sessionID| and return it via the callback |
| +// if it exists. The callback is garanteed to be called synchronously if the |
| +// image is in memory. It will be called asynchronously if the image is on disk |
| +// or with nil if the image is not present at all. |
| +- (void)retrieveImageForSessionID:(NSString*)sessionID |
| + callback:(void (^)(UIImage*))callback; |
| + |
| +// Request the session's grey snapshot. If the image is already loaded in |
| +// memory, this will immediately call back on |callback|. Otherwise, the grey |
| +// image will be loaded off disk or created by converting an existing color |
| +// snapshot to grey. |
| +- (void)retrieveGreyImageForSessionID:(NSString*)sessionID |
| + callback:(void (^)(UIImage*))callback; |
| + |
| +// Stores the supplied thumbnail for the specified |sessionID|. |
| +- (void)setImage:(UIImage*)img withSessionID:(NSString*)sessionID; |
| + |
| +// Removes the cached thumbnail for the specified |sessionID|. |
| +- (void)removeImageWithSessionID:(NSString*)sessionID; |
| + |
| +// Request the grey image from the in-memory cache only. |
| +- (void)greyImageForSessionID:(NSString*)sessionID |
| + callback:(void (^)(UIImage*))callback; |
| +@end |
| + |
| +#endif // IOS_CHROME_BROWSER_SNAPSHOTS_SNAPSHOT_MANAGER_H_ |