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

Unified Diff: chrome/browser/android/thumbnail/thumbnail_cache.h

Issue 262543002: android: add ThumbnailCache (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@codec
Patch Set: separate into multiple files Created 6 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/android/thumbnail/thumbnail_cache.h
diff --git a/chrome/browser/android/thumbnail/thumbnail_cache.h b/chrome/browser/android/thumbnail/thumbnail_cache.h
new file mode 100644
index 0000000000000000000000000000000000000000..6463edbd89b0275f0a921dad0a53f21764178010
--- /dev/null
+++ b/chrome/browser/android/thumbnail/thumbnail_cache.h
@@ -0,0 +1,148 @@
+// 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 CHROME_BROWSER_ANDROID_THUMBNAIL_THUMBNAIL_CACHE_H_
+#define CHROME_BROWSER_ANDROID_THUMBNAIL_THUMBNAIL_CACHE_H_
+
+#include <list>
+#include <set>
+#include <string>
+
+#include "base/bind.h"
+#include "base/containers/hash_tables.h"
+#include "base/files/file_path.h"
+#include "base/memory/ref_counted.h"
+#include "base/observer_list.h"
+#include "base/threading/thread.h"
+#include "base/time/time.h"
+#include "chrome/browser/android/thumbnail/lru_expiring_cache.h"
+#include "chrome/browser/android/thumbnail/thumbnail_impl.h"
+#include "content/public/browser/android/ui_resource_client_android.h"
+#include "content/public/browser/android/ui_resource_provider.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+#include "ui/gfx/geometry/point.h"
+#include "ui/gfx/geometry/size.h"
+#include "ui/gfx/geometry/size_f.h"
+#include "url/gurl.h"
+
+namespace base {
+class File;
+class Time;
+}
+
+namespace content {
+class ContentViewCore;
+}
+
+typedef std::list<TabId> TabIdList;
+
+class ThumbnailCacheObserver {
+ public:
+ virtual void OnFinishedThumbnailRead(TabId tab_id) = 0;
+};
+
+class ThumbnailCache : ThumbnailImplManager {
+ public:
+ ThumbnailCache(const std::string& disk_cache_path_str,
+ size_t default_cache_size,
+ size_t approximation_cache_size,
+ size_t compression_queue_max_size,
+ size_t write_queue_max_size,
+ bool use_approximation_thumbnail);
+
+ ~ThumbnailCache();
+
+ void SetUIResourceProvider(content::UIResourceProvider* ui_resource_provider);
+
+ void AddThumbnailCacheObserver(ThumbnailCacheObserver* observer);
+ void RemoveThumbnailCacheObserver(
+ ThumbnailCacheObserver* observer);
+
+ void Put(TabId tab_id, const SkBitmap& bitmap, float thumbnail_scale);
+ void Remove(TabId tab_id);
+ scoped_refptr<Thumbnail> Get(TabId tab_id);
+
+ void RemoveFromDiskAtAndAboveId(TabId min_id);
+ void InvalidateThumbnailIfChanged(TabId tab_id, const GURL& url);
+ bool CheckAndUpdateThumbnailMetaData(TabId tab_id, const GURL& url);
+ void UpdateVisibleIds(const TabIdList& priority);
+
+ // ThumbnailImplManager implementation
+ virtual void InvalidateCachedThumbnail(
+ scoped_refptr<ThumbnailImpl> thumbnail) OVERRIDE;
+
+ private:
+ class ThumbnailMetaData {
+ public:
+ ThumbnailMetaData();
+ ThumbnailMetaData(const base::Time& current_time, const GURL& url);
+ const GURL& url() const { return url_; }
+ base::Time capture_time() const { return capture_time_; }
+
+ private:
+ base::Time capture_time_;
+ GURL url_;
+ };
+
+ typedef LRUExpiringCache<TabId, scoped_refptr<ThumbnailImpl> >
+ ExpiringThumbnailCache;
+ typedef base::hash_map<TabId, ThumbnailMetaData> ThumbnailMetaDataMap;
+ typedef std::list<scoped_refptr<ThumbnailImpl> > ThumbnailQueue;
+
+ static void RemoveFileFromDisk(const base::FilePath& file_path);
+ static void RemoveFileFromDiskTask(const base::FilePath& file_path);
+ static void RemoveFromDiskAtAndAboveIdTask(const base::FilePath& dir_path,
+ TabId min_id);
+
+ void WriteThumbnailIfNecessary(scoped_refptr<ThumbnailImpl> thumbnail);
+ void CompressThumbnailIfNecessary(scoped_refptr<ThumbnailImpl> thumbnail);
+ void MakeSpaceForNewItemIfNecessary(TabId tab_id);
+
+ void RemoveFromQueues(TabId tab_id);
+ bool RemoveDuplicateIdsFromQueueHelper(
+ ThumbnailQueue& queue,
+ scoped_refptr<ThumbnailImpl> thumbnail);
+ base::FilePath GetFilePath(TabId tab_id) const;
+ base::Time CurrentTime();
+
+ void WriteNextThumbnail();
+ static void WriteTask(scoped_refptr<ThumbnailImpl> thumbnail,
+ const base::FilePath& file_path);
+
+ void ReadNextThumbnail();
+ static void ReadTask(const base::FilePath& file_path,
+ scoped_refptr<ThumbnailImpl> thumbnail);
+ void PostReadTask(scoped_refptr<ThumbnailImpl> thumbnail);
+
+ void CompressNextThumbnail();
+ void PostCompressionTask(scoped_refptr<ThumbnailImpl> compressed_thumbnail);
+
+ void NotifyObserversOfThumbnailRead(TabId tab_id);
+
+ static std::pair<SkBitmap, float> CreateApproximation(const SkBitmap& bitmap,
+ float scale);
+
+ const base::FilePath disk_cache_path_;
+ const size_t compression_queue_max_size_;
+ const size_t write_queue_max_size_;
+ const bool use_approximation_thumbnail_;
+
+ ExpiringThumbnailCache cache_;
+ ExpiringThumbnailCache approximation_cache_;
+ ObserverList<ThumbnailCacheObserver> observers_;
+ ThumbnailMetaDataMap thumbnail_meta_data_;
+ ThumbnailQueue compression_queue_;
+ ThumbnailQueue write_queue_;
+ TabIdList read_queue_;
+ TabIdList visible_ids_;
+
+ content::UIResourceProvider* ui_resource_provider_;
+ base::Thread compression_thread_;
+
+ base::WeakPtrFactory<ThumbnailCache> weak_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(ThumbnailCache);
+};
+
+#endif // CHROME_BROWSER_ANDROID_THUMBNAIL_THUMBNAIL_CACHE_H_

Powered by Google App Engine
This is Rietveld 408576698