| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CONTENT_BROWSER_WEB_CONTENTS_WEB_CONTENTS_SCREENSHOT_MANAGER_H_ | |
| 6 #define CONTENT_BROWSER_WEB_CONTENTS_WEB_CONTENTS_SCREENSHOT_MANAGER_H_ | |
| 7 | |
| 8 #include "base/compiler_specific.h" | |
| 9 #include "base/memory/weak_ptr.h" | |
| 10 #include "base/time/time.h" | |
| 11 #include "content/common/content_export.h" | |
| 12 | |
| 13 class SkBitmap; | |
| 14 | |
| 15 namespace content { | |
| 16 | |
| 17 class NavigationControllerImpl; | |
| 18 class NavigationEntryImpl; | |
| 19 class RenderViewHost; | |
| 20 class ScreenshotData; | |
| 21 | |
| 22 // WebContentsScreenshotManager takes care of taking image-captures for the | |
| 23 // current navigation entry of a NavigationControllerImpl, and managing these | |
| 24 // captured images. These image-captures are used for history navigation using | |
| 25 // overscroll gestures. | |
| 26 class CONTENT_EXPORT WebContentsScreenshotManager { | |
| 27 public: | |
| 28 explicit WebContentsScreenshotManager(NavigationControllerImpl* controller); | |
| 29 virtual ~WebContentsScreenshotManager(); | |
| 30 | |
| 31 // Takes a screenshot of the last-committed entry of the controller. | |
| 32 void TakeScreenshot(); | |
| 33 | |
| 34 // Clears screenshots of all navigation entries. | |
| 35 void ClearAllScreenshots(); | |
| 36 | |
| 37 protected: | |
| 38 virtual void TakeScreenshotImpl(RenderViewHost* host, | |
| 39 NavigationEntryImpl* entry); | |
| 40 | |
| 41 // Called after a screenshot has been set on an NavigationEntryImpl. | |
| 42 // Overridden in tests to get notified of when a screenshot is set. | |
| 43 virtual void OnScreenshotSet(NavigationEntryImpl* entry); | |
| 44 | |
| 45 NavigationControllerImpl* owner() { return owner_; } | |
| 46 | |
| 47 void SetMinScreenshotIntervalMS(int interval_ms); | |
| 48 | |
| 49 // The callback invoked when taking the screenshot of the page is complete. | |
| 50 // This sets the screenshot on the navigation entry. | |
| 51 void OnScreenshotTaken(int unique_id, | |
| 52 bool success, | |
| 53 const SkBitmap& bitmap); | |
| 54 | |
| 55 // Returns the number of entries with screenshots. | |
| 56 int GetScreenshotCount() const; | |
| 57 | |
| 58 private: | |
| 59 // This is called when the screenshot data has beene encoded to PNG in a | |
| 60 // worker thread. | |
| 61 void OnScreenshotEncodeComplete(int unique_id, | |
| 62 scoped_refptr<ScreenshotData> data); | |
| 63 | |
| 64 // Removes the screenshot for the entry, returning true if the entry had a | |
| 65 // screenshot. | |
| 66 bool ClearScreenshot(NavigationEntryImpl* entry); | |
| 67 | |
| 68 // The screenshots in the NavigationEntryImpls can accumulate and consume a | |
| 69 // large amount of memory. This function makes sure that the memory | |
| 70 // consumption is within a certain limit. | |
| 71 void PurgeScreenshotsIfNecessary(); | |
| 72 | |
| 73 // The navigation controller that owns this screenshot-manager. | |
| 74 NavigationControllerImpl* owner_; | |
| 75 | |
| 76 // Taking a screenshot and encoding them can be async. So use a weakptr for | |
| 77 // the callback to make sure that the screenshot/encoding completion callback | |
| 78 // does not trigger on a destroyed WebContentsScreenshotManager. | |
| 79 base::WeakPtrFactory<WebContentsScreenshotManager> screenshot_factory_; | |
| 80 | |
| 81 base::Time last_screenshot_time_; | |
| 82 int min_screenshot_interval_ms_; | |
| 83 | |
| 84 DISALLOW_COPY_AND_ASSIGN(WebContentsScreenshotManager); | |
| 85 }; | |
| 86 | |
| 87 } // namespace content | |
| 88 | |
| 89 #endif // CONTENT_BROWSER_WEB_CONTENTS_WEB_CONTENTS_SCREENSHOT_MANAGER_H_ | |
| OLD | NEW |