| Index: ui/android/resources/resource_manager.h
|
| diff --git a/ui/android/resources/resource_manager.h b/ui/android/resources/resource_manager.h
|
| index 730d4dc5afcf594d58527a768207bc3c249c3fea..9fe29f9221cc0511868c53956a8d4586e0a36cda 100644
|
| --- a/ui/android/resources/resource_manager.h
|
| +++ b/ui/android/resources/resource_manager.h
|
| @@ -5,19 +5,19 @@
|
| #ifndef UI_ANDROID_RESOURCES_RESOURCE_MANAGER_H_
|
| #define UI_ANDROID_RESOURCES_RESOURCE_MANAGER_H_
|
|
|
| +#include <string>
|
| +
|
| #include "base/android/jni_android.h"
|
| #include "base/id_map.h"
|
| #include "cc/resources/ui_resource_client.h"
|
| #include "ui/android/ui_android_export.h"
|
| +#include "ui/base/android/system_ui_resource_manager.h"
|
| #include "ui/gfx/geometry/rect.h"
|
|
|
| -namespace content {
|
| -class UIResourceProvider;
|
| -}
|
| -
|
| namespace ui {
|
|
|
| class UIResourceAndroid;
|
| +class UIResourceProvider;
|
|
|
| // A Java counterpart will be generated for this enum.
|
| // GENERATED_JAVA_ENUM_PACKAGE: org.chromium.ui.resources
|
| @@ -32,7 +32,7 @@ enum AndroidResourceType {
|
| ANDROID_RESOURCE_TYPE_LAST = ANDROID_RESOURCE_TYPE_SYSTEM,
|
| };
|
|
|
| -class UI_ANDROID_EXPORT ResourceManager {
|
| +class UI_ANDROID_EXPORT ResourceManager : public ui::SystemUIResourceManager {
|
| public:
|
| struct Resource {
|
| public:
|
| @@ -49,14 +49,21 @@ class UI_ANDROID_EXPORT ResourceManager {
|
|
|
| static ResourceManager* FromJavaObject(jobject jobj);
|
|
|
| - explicit ResourceManager(content::UIResourceProvider* ui_resource_provider);
|
| - virtual ~ResourceManager();
|
| + explicit ResourceManager(ui::UIResourceProvider* ui_resource_provider);
|
| + ~ResourceManager() override;
|
| +
|
| + // ui::SystemUIResourceManager implementation.
|
| + void PreloadResource(ui::SystemUIResourceType type) override;
|
| + cc::UIResourceId GetUIResourceId(ui::SystemUIResourceType type) override;
|
|
|
| base::android::ScopedJavaLocalRef<jobject> GetJavaObject(JNIEnv* env);
|
|
|
| ResourceManager::Resource* GetResource(AndroidResourceType res_type,
|
| int res_id);
|
| + ResourceManager::Resource* GetResource(AndroidResourceType res_type,
|
| + std::string res_name);
|
| void PreloadResource(AndroidResourceType res_type, int res_id);
|
| + void PreloadResource(AndroidResourceType res_type, std::string res_name);
|
|
|
| // Called from Java ----------------------------------------------------------
|
| void OnResourceReady(JNIEnv* env,
|
| @@ -76,12 +83,23 @@ class UI_ANDROID_EXPORT ResourceManager {
|
| static bool RegisterResourceManager(JNIEnv* env);
|
|
|
| private:
|
| + friend class TestResourceManager;
|
| +
|
| + int GetAndroidResourceIdFromString(std::string res_name);
|
| +
|
| + // Start loading the resource. virtual for testing.
|
| + virtual void PreloadResourceFromJava(AndroidResourceType res_type,
|
| + int res_id);
|
| + virtual void RequestResourceFromJava(AndroidResourceType res_type,
|
| + int res_id);
|
| +
|
| typedef IDMap<Resource, IDMapOwnPointer> ResourceMap;
|
|
|
| - content::UIResourceProvider* ui_resource_provider_;
|
| + ui::UIResourceProvider* ui_resource_provider_;
|
| ResourceMap resources_[ANDROID_RESOURCE_TYPE_COUNT];
|
|
|
| base::android::ScopedJavaGlobalRef<jobject> java_obj_;
|
| + base::hash_map<std::string, int> android_res_name_to_res_id_map_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(ResourceManager);
|
| };
|
|
|