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

Unified Diff: ios/chrome/browser/snapshots/web_controller_snapshot_helper.h

Issue 2585233003: Upstream Chrome on iOS source code [2/11]. (Closed)
Patch Set: Created 4 years 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 side-by-side diff with in-line comments
Download patch
Index: ios/chrome/browser/snapshots/web_controller_snapshot_helper.h
diff --git a/ios/chrome/browser/snapshots/web_controller_snapshot_helper.h b/ios/chrome/browser/snapshots/web_controller_snapshot_helper.h
new file mode 100644
index 0000000000000000000000000000000000000000..6b53243edd2b47922f8ffb78a5b9d743a5544770
--- /dev/null
+++ b/ios/chrome/browser/snapshots/web_controller_snapshot_helper.h
@@ -0,0 +1,76 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// 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_WEB_CONTROLLER_SNAPSHOT_HELPER_H_
+#define IOS_CHROME_BROWSER_SNAPSHOTS_WEB_CONTROLLER_SNAPSHOT_HELPER_H_
+
+#import <UIKit/UIKit.h>
+
+@class CRWWebController;
+@class SnapshotManager;
+@class Tab;
+
+// A class that takes care of creating, storing and returning snapshots of a
+// WebController's web page.
+// TODO(crbug.com/661642): There is a lot of overlap/common functionality
+// between this class and SnapshotManager, coalesce these 2 classes.
+@interface WebControllerSnapshotHelper : NSObject
+
+// Designated initializer. |snapshotManager|, |sessionID|, |webController|
+// should not be nil.
+// TODO(crbug.com/661641): Since we already retain a CRWWebController* and that
+// is the same which is passed to these methods, remove the CRWWebController
+// param from the following methods.
+// TODO(crbug.com/380819): Replace the need to use Tab directly here by using a
+// delegate pattern.
+- (instancetype)initWithSnapshotManager:(SnapshotManager*)snapshotManager
+ tab:(Tab*)tab;
+
+// If |snapshotCoalescingEnabled| is YES snapshots of the web page are
+// coalesced until this method is called with |snapshotCoalescingEnabled| set to
+// NO. When snapshot coalescing is enabled, mutiple calls to generate a snapshot
+// with the same parameters may be coalesced.
+- (void)setSnapshotCoalescingEnabled:(BOOL)snapshotCoalescingEnabled;
+
+// Gets a color snapshot for the WebController's page, calling |callback| if it
+// is found. |overlays| is the array of SnapshotOverlay objects (views currently
+// overlayed), can be nil.
+- (void)retrieveSnapshotForWebController:(CRWWebController*)webController
+ sessionID:(NSString*)sessionID
+ withOverlays:(NSArray*)overlays
+ callback:(void (^)(UIImage* image))callback;
+
+// Gets a grey snapshot for the webController's current page, calling |callback|
+// if it is found. |overlays| is the array of SnapshotOverlay objects
+// (views currently overlayed), can be nil.
+- (void)retrieveGreySnapshotForWebController:(CRWWebController*)webController
+ sessionID:(NSString*)sessionID
+ withOverlays:(NSArray*)overlays
+ callback:(void (^)(UIImage* image))callback;
+
+// Invalidates the cached snapshot for the controller's current session and
+// forces a more recent snapshot to be generated and stored. Returns the
+// snapshot with or without the overlayed views (e.g. infobar, voice search
+// button, etc.), and either of the visible frame or of the full screen.
+// |overlays| is the array of SnapshotOverlay objects (views currently
+// overlayed), can be nil.
+- (UIImage*)updateSnapshotForWebController:(CRWWebController*)webController
+ sessionID:(NSString*)sessionID
+ withOverlays:(NSArray*)overlays
+ visibleFrameOnly:(BOOL)visibleFrameOnly;
+
+// Takes a snapshot image for the current page including optional infobars.
+// Returns an autoreleased image cropped and scaled appropriately, with or
+// without the overlayed views (e.g. infobar, voice search button, etc.), and
+// either of the visible frame or of the full screen.
+// Returns nil if a snapshot cannot be generated.
+// |overlays| is the array of SnapshotOverlay objects (views currently
+// overlayed), can be nil.
+- (UIImage*)generateSnapshotForWebController:(CRWWebController*)webController
+ withOverlays:(NSArray*)overlays
+ visibleFrameOnly:(BOOL)visibleFrameOnly;
+
+@end
+
+#endif // IOS_CHROME_BROWSER_SNAPSHOTS_WEB_CONTROLLER_SNAPSHOT_HELPER_H_

Powered by Google App Engine
This is Rietveld 408576698