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

Unified Diff: chrome/browser/chromeos/login/user_manager_impl.h

Issue 10375010: Implement user selected wallpaper feature. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Merge Created 8 years, 7 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/chromeos/login/user_manager.h ('k') | chrome/browser/chromeos/login/user_manager_impl.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/chromeos/login/user_manager_impl.h
diff --git a/chrome/browser/chromeos/login/user_manager_impl.h b/chrome/browser/chromeos/login/user_manager_impl.h
index aa1c7289c5cb3fb7a94cd2c48b193db5368a9132..581f4e450e6444a0e2060525049bdec589e8bf49 100644
--- a/chrome/browser/chromeos/login/user_manager_impl.h
+++ b/chrome/browser/chromeos/login/user_manager_impl.h
@@ -74,8 +74,14 @@ class UserManagerImpl : public UserManager,
int image_index) OVERRIDE;
virtual void SaveUserImage(const std::string& username,
const SkBitmap& image) OVERRIDE;
+ virtual void SetLoggedInUserCustomWallpaperLayout(
+ ash::WallpaperLayout layout) OVERRIDE;
virtual void SaveUserImageFromFile(const std::string& username,
const FilePath& path) OVERRIDE;
+ virtual void SaveUserWallpaperFromFile(const std::string& username,
+ const FilePath& path,
+ ash::WallpaperLayout layout,
+ WallpaperDelegate* delegate) OVERRIDE;
virtual void SaveUserImageFromProfileImage(
const std::string& username) OVERRIDE;
virtual void DownloadProfileImage(const std::string& reason) OVERRIDE;
@@ -106,6 +112,10 @@ class UserManagerImpl : public UserManager,
// Returns image filepath for the given user.
FilePath GetImagePathForUser(const std::string& username);
+ // Returns wallpaper/thumbnail filepath for the given user.
+ FilePath GetWallpaperPathForUser(const std::string& username,
+ bool is_thumbnail);
+
private:
friend class UserManagerImplWrapper;
friend class UserManagerTest;
@@ -177,6 +187,32 @@ class UserManagerImpl : public UserManager,
int image_index,
const SkBitmap& image);
+ // Saves wallpaper to file, post task to generate thumbnail and updates local
+ // state preferences.
+ void SaveUserWallpaperInternal(const std::string& username,
+ ash::WallpaperLayout layout,
+ User::WallpaperType type,
+ WallpaperDelegate* delegate,
+ const SkBitmap& image);
+
+ // Loads custom wallpaper thumbnail asynchronously.
+ void LoadCustomWallpaperThumbnail(const std::string& email,
+ ash::WallpaperLayout layout,
+ const SkBitmap& wallpaper);
+
+ // Caches the loaded wallpaper for the given user.
+ void OnCustomWallpaperThumbnailLoaded(const std::string& email,
+ const SkBitmap& wallpaper);
+
+ // Updates the custom wallpaper thumbnail in wallpaper picker UI.
+ void OnThumbnailUpdated(WallpaperDelegate* delegate);
+
+ // Generates a 128x80 thumbnail and saves it to local file system.
+ void GenerateUserWallpaperThumbnail(const std::string& username,
+ User::WallpaperType type,
+ WallpaperDelegate* delegate,
+ const SkBitmap& wallpaper);
+
// Saves image to file with specified path and sends LOGIN_USER_IMAGE_CHANGED
// notification. Runs on FILE thread. Posts task for saving image info to
// Local State on UI thread.
@@ -185,6 +221,14 @@ class UserManagerImpl : public UserManager,
const FilePath& image_path,
int image_index);
+ // Saves wallpaper to file with specified path. Runs on FILE thread. Posts
+ // task for saving wallpaper info to Local State on UI thread.
+ void SaveWallpaperToFile(const std::string& username,
+ const SkBitmap& wallpaper,
+ const FilePath& wallpaper_path,
+ ash::WallpaperLayout layout,
+ User::WallpaperType type);
+
// Stores path to the image and its index in local state. Runs on UI thread.
// If |is_async| is true, it has been posted from the FILE thread after
// saving the image.
@@ -193,6 +237,16 @@ class UserManagerImpl : public UserManager,
int image_index,
bool is_async);
+ // Stores layout and type preference in local state. Runs on UI thread.
+ void SaveWallpaperToLocalState(const std::string& username,
+ const std::string& wallpaper_path,
+ ash::WallpaperLayout layout,
+ User::WallpaperType type);
+
+ // Saves |image| to the specified |image_path|. Runs on FILE thread.
+ bool SaveBitmapToFile(const SkBitmap& image,
+ const FilePath& image_path);
+
// Initializes |downloaded_profile_picture_| with the picture of the logged-in
// user.
void InitDownloadedProfileImage();
« no previous file with comments | « chrome/browser/chromeos/login/user_manager.h ('k') | chrome/browser/chromeos/login/user_manager_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698