Chromium Code Reviews| Index: ui/android/view_android.h |
| diff --git a/ui/android/view_android.h b/ui/android/view_android.h |
| index 6e7140da3e111d470da0ff73c77a7fa007108d6b..cbdd0ac65573c3ecb3e03f0450c50c90e38f921d 100644 |
| --- a/ui/android/view_android.h |
| +++ b/ui/android/view_android.h |
| @@ -7,9 +7,10 @@ |
| #include <list> |
| -#include "base/android/scoped_java_ref.h" |
| +#include "base/android/jni_weak_ref.h" |
| #include "base/memory/ref_counted.h" |
| #include "ui/android/ui_android_export.h" |
| +#include "ui/gfx/geometry/rect_f.h" |
| namespace cc { |
| class Layer; |
| @@ -26,17 +27,21 @@ class UI_ANDROID_EXPORT ViewAndroid { |
| // A ViewAndroid may have its own delegate or otherwise will |
| // use the next available parent's delegate. |
| ViewAndroid(const base::android::JavaRef<jobject>& delegate); |
| + |
| ViewAndroid(); |
| virtual ~ViewAndroid(); |
| + // This method is intentionally not called anywhere, since there are |
| + // no native methods that are called from Java. TODO(crbug.com/603936). |
| + static bool RegisterViewAndroid(JNIEnv* env); |
| + |
| // Returns the window at the root of this hierarchy, or |null| |
| // if disconnected. |
| virtual WindowAndroid* GetWindowAndroid() const; |
| - // Returns the Java delegate for this view. This is used to delegate work |
| - // up to the embedding view (or the embedder that can deal with the |
| - // implementation details). |
| - const base::android::JavaRef<jobject>& GetViewAndroidDelegate() const; |
| + // Set the root |WindowAndroid|. This is only valid for root |
| + // nodes and must not be called for children. |
| + void SetWindowAndroid(WindowAndroid* root_window); |
| // Used to return and set the layer for this view. May be |null|. |
| cc::Layer* GetLayer() const; |
| @@ -51,12 +56,52 @@ class UI_ANDROID_EXPORT ViewAndroid { |
| void StartDragAndDrop(const base::android::JavaRef<jstring>& jtext, |
| const base::android::JavaRef<jobject>& jimage); |
| + // Stores an anchored view to delete itself at the end of its lifetime |
| + // automatically. This helps manage the lifecyle without the dependency |
| + // on |ViewAndroid|. |
| + class ScopedAnchorView { |
| + public: |
| + ScopedAnchorView(JNIEnv* env, |
| + const base::android::JavaRef<jobject>& jview, |
| + const base::android::JavaRef<jobject>& jdelegate); |
| + |
| + ScopedAnchorView(); |
| + ScopedAnchorView(ScopedAnchorView&& other); |
| + ScopedAnchorView& operator=(ScopedAnchorView&& other); |
| + |
| + // Calls JNI removeView() on the delegate for cleanup. |
| + ~ScopedAnchorView(); |
| + |
| + void Reset(); |
| + |
| + bool is_null() const { return view_.is_empty(); } |
|
boliu
2016/07/27 16:20:26
this method is no longer valid, since *in theory*,
Jinsuk Kim
2016/07/29 06:09:14
Good to know this. Removed |is_null()|.
|
| + const base::android::ScopedJavaLocalRef<jobject> view(JNIEnv* env) const { |
| + return view_.get(env); |
| + } |
| + |
| + private: |
| + // TODO(jinsukkim): Following weak refs can be cast to strong refs which |
| + // cannot be garbage-collected and leak memory. Rewrite not to use them. |
| + // see comments in crrev.com/2103243002. |
| + JavaObjectWeakGlobalRef view_; |
| + JavaObjectWeakGlobalRef delegate_; |
| + }; |
| + |
| + ScopedAnchorView AcquireAnchorView(); |
| + void SetAnchorRect(const base::android::JavaRef<jobject>& anchor, |
| + const gfx::RectF& bounds); |
| + |
| protected: |
| ViewAndroid* parent_; |
| private: |
| void RemoveChild(ViewAndroid* child); |
| + // Returns the Java delegate for this view. This is used to delegate work |
| + // up to the embedding view (or the embedder that can deal with the |
| + // implementation details). |
| + const base::android::JavaRef<jobject>& GetViewAndroidDelegate() const; |
| + |
| std::list<ViewAndroid*> children_; |
| scoped_refptr<cc::Layer> layer_; |
| base::android::ScopedJavaGlobalRef<jobject> delegate_; |