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

Unified Diff: chrome/browser/extensions/extension_install_ui.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
Index: chrome/browser/extensions/extension_install_ui.h
===================================================================
--- chrome/browser/extensions/extension_install_ui.h (revision 42362)
+++ chrome/browser/extensions/extension_install_ui.h (working copy)
@@ -1,18 +1,19 @@
-// 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.
#ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_INSTALL_UI_H_
#define CHROME_BROWSER_EXTENSIONS_EXTENSION_INSTALL_UI_H_
+#include <string>
+
#include "base/file_path.h"
#include "base/ref_counted.h"
#include "base/scoped_ptr.h"
+#include "chrome/browser/extensions/image_loading_tracker.h"
#include "gfx/native_widget_types.h"
#include "third_party/skia/include/core/SkBitmap.h"
-#include <string>
-
class Extension;
class ExtensionsService;
class MessageLoop;
@@ -22,7 +23,7 @@
class TabContents;
// Displays all the UI around extension installation and uninstallation.
-class ExtensionInstallUI {
+class ExtensionInstallUI : public ImageLoadingTracker::Observer {
public:
enum PromptType {
INSTALL_PROMPT = 0,
@@ -56,24 +57,21 @@
//
// We *MUST* eventually call either Proceed() or Abort()
// on |delegate|.
- virtual void ConfirmInstall(Delegate* delegate, Extension* extension,
- SkBitmap* icon);
+ virtual void ConfirmInstall(Delegate* delegate, Extension* extension);
// This is called by the extensions management page to verify whether the
// uninstallation should proceed. This is declared virtual for testing.
//
// We *MUST* eventually call either Proceed() or Abort()
// on |delegate|.
- virtual void ConfirmUninstall(Delegate* delegate, Extension* extension,
- SkBitmap* icon);
+ virtual void ConfirmUninstall(Delegate* delegate, Extension* extension);
// This is called by the extensions management page to verify whether the
// uninstallation should proceed. This is declared virtual for testing.
//
// We *MUST* eventually call either Proceed() or Abort()
// on |delegate|.
- virtual void ConfirmEnableIncognito(Delegate* delegate, Extension* extension,
- SkBitmap* icon);
+ virtual void ConfirmEnableIncognito(Delegate* delegate, Extension* extension);
// Installation was successful. This is declared virtual for testing.
virtual void OnInstallSuccess(Extension* extension);
@@ -85,6 +83,9 @@
// installed. This is declared virtual for testing.
virtual void OnOverinstallAttempted(Extension* extension);
+ // ImageLoadingTracker::Observer overrides.
+ virtual void OnImageLoaded(SkBitmap* image, int index);
+
private:
// When a Theme is downloaded it is applied and an info bar is shown to give
// the user a choice to keep it or undo the installation.
@@ -111,9 +112,16 @@
MessageLoop* ui_loop_;
std::string previous_theme_id_; // Used to undo theme installation.
SkBitmap icon_; // The extensions installation icon.
+ Extension* extension_; // The extension we are showing the UI for.
+ Delegate* delegate_; // The delegate we will call Proceed/Abort on after
+ // confirmation UI.
+ // Keeps track of extension images being loaded on the File thread for the
+ // purpose of showing the install UI.
+ ImageLoadingTracker tracker_;
+
#if defined(TOOLKIT_GTK)
- // Also needed to undo theme installation in the linux UI.
+ // Also needed to undo theme installation in the Linux UI.
bool previous_use_gtk_theme_;
#endif
};

Powered by Google App Engine
This is Rietveld 408576698