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

Unified Diff: chrome/browser/extensions/image_loading_tracker.h

Issue 1075006: Eliminate all UI thread decoding of extension images.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 9 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
« no previous file with comments | « chrome/browser/extensions/extensions_ui.cc ('k') | chrome/browser/extensions/image_loading_tracker.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/extensions/image_loading_tracker.h
===================================================================
--- chrome/browser/extensions/image_loading_tracker.h (revision 42429)
+++ chrome/browser/extensions/image_loading_tracker.h (working copy)
@@ -1,4 +1,4 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Copyright (c) 2010 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.
@@ -6,76 +6,67 @@
#define CHROME_BROWSER_EXTENSIONS_IMAGE_LOADING_TRACKER_H_
#include "base/ref_counted.h"
+#include "chrome/common/extensions/extension.h"
class ExtensionResource;
class SkBitmap;
namespace gfx {
-class Size;
+ class Size;
}
// The views need to load their icons asynchronously but might be deleted before
-// the images have loaded. This class stays alive while the request is in
-// progress (manages its own lifetime) and keeps track of whether the view still
-// cares about the icon loading.
-// Consider abstracting out a FilePathProvider (ExtensionResource) and moving
-// back to chrome/browser/ if other subsystems want to use it.
-class ImageLoadingTracker
- : public base::RefCountedThreadSafe<ImageLoadingTracker> {
+// the images have loaded. This class encapsulates a loader class that stays
+// alive while the request is in progress (manages its own lifetime) and keeps
+// track of whether the view still cares about the icon loading.
+//
+// To use this class, have your class derive from ImageLoadingTracker::Observer,
+// and add a member variable ImageLoadingTracker tracker_. Then override
+// Observer::OnImageLoaded and call:
+// tracker_.LoadImage(resource, max_size);
+// ... and wait for OnImageLoaded to be called back on you with a pointer to the
+// SkBitmap loaded.
+class ImageLoadingTracker {
public:
class Observer {
public:
// Will be called when the image with the given index has loaded.
// The |image| is owned by the tracker, so the observer should make a copy
- // if they need to access it after this call.
- virtual void OnImageLoaded(SkBitmap* image, size_t index) = 0;
+ // if they need to access it after this call. |image| can be null if valid
+ // image was not found or it failed to decode. |resource| is the
+ // ExtensionResource where the |image| came from and the |index| represents
+ // the index of the image just loaded (starts at 0 and increments every
+ // time this function is called).
+ virtual void OnImageLoaded(SkBitmap* image, ExtensionResource resource,
+ int index) = 0;
};
- ImageLoadingTracker(Observer* observer, size_t image_count)
- : observer_(observer), image_count_(image_count), posted_count_(0) {
- AddRef(); // We hold on to a reference to ourself to make sure we don't
- // get deleted until we get a response from image loading (see
- // ImageLoadingDone).
- }
+ explicit ImageLoadingTracker(Observer* observer);
+ ~ImageLoadingTracker();
- // If there are remaining images to be loaded, the observing object should
- // call this method on its destruction, so that the tracker will not attempt
- // to make any more callbacks to it.
- void StopTrackingImageLoad() {
- observer_ = NULL;
- }
-
- // Specify image resource to load. This method must be called a number of
- // times equal to the |image_count| arugment to the constructor. Calling it
- // any more or less than that is an error. If the loaded image is larger than
+ // Specify image resource to load. If the loaded image is larger than
// |max_size| it will be resized to those dimensions.
- void PostLoadImageTask(const ExtensionResource& resource,
- const gfx::Size& max_size);
+ void LoadImage(const ExtensionResource& resource,
+ gfx::Size max_size);
private:
- class LoadImageTask;
+ class ImageLoader;
- friend class base::RefCountedThreadSafe<ImageLoadingTracker>;
-
- ~ImageLoadingTracker() {}
-
- // When an image has finished loaded and scaled on the file thread, it is
- // posted back to this method on the original thread. This method then calls
- // the observer's OnImageLoaded and deletes the ImageLoadingTracker if it was
- // the last image in the list.
+ // When an image has finished loaded and been resized on the file thread, it
+ // is posted back to this method on the original thread. This method then
+ // calls the observer's OnImageLoaded and deletes the ImageLoadingTracker if
+ // it was the last image in the list.
// |image| may be null if the file failed to decode.
- void OnImageLoaded(SkBitmap* image, size_t index);
+ void OnImageLoaded(SkBitmap* image, const ExtensionResource& resource);
// The view that is waiting for the image to load.
Observer* observer_;
- // The number of images this ImageTracker should keep track of. This is
- // decremented as each image finishes loading, and the tracker will delete
- // itself when it reaches zero.
- size_t image_count_;
+ // The number of times we've reported back.
+ int responses_;
- // The number of tasks that have been posted so far.
- size_t posted_count_;
+ // The object responsible for loading the image on the File thread.
+ scoped_refptr<ImageLoader> loader_;
DISALLOW_COPY_AND_ASSIGN(ImageLoadingTracker);
};
« no previous file with comments | « chrome/browser/extensions/extensions_ui.cc ('k') | chrome/browser/extensions/image_loading_tracker.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698