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

Unified Diff: ui/android/view_android.h

Issue 2103243002: Factor out ContentViewAndroidDelegate (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebased Created 4 years, 4 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 | « ui/android/ui_android.gyp ('k') | ui/android/view_android.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/android/view_android.h
diff --git a/ui/android/view_android.h b/ui/android/view_android.h
index 6e7140da3e111d470da0ff73c77a7fa007108d6b..a996e6804bbc10fc38449e43b34be7937fab6942 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;
@@ -23,9 +24,40 @@ class WindowAndroid;
// At the root of the hierarchy is a WindowAndroid, when attached.
class UI_ANDROID_EXPORT ViewAndroid {
public:
+ // 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();
+
+ const base::android::ScopedJavaLocalRef<jobject> view() const;
+
+ 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_;
+
+ // Default copy/assign disabled by move constructor.
+ };
+
// 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();
@@ -33,10 +65,9 @@ class UI_ANDROID_EXPORT ViewAndroid {
// 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);
Ted C 2016/08/24 17:26:54 I think this was a bad rebase. This was removed b
// Used to return and set the layer for this view. May be |null|.
cc::Layer* GetLayer() const;
@@ -51,15 +82,25 @@ class UI_ANDROID_EXPORT ViewAndroid {
void StartDragAndDrop(const base::android::JavaRef<jstring>& jtext,
const base::android::JavaRef<jobject>& jimage);
+ 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::ScopedJavaLocalRef<jobject>
+ GetViewAndroidDelegate() const;
+
std::list<ViewAndroid*> children_;
scoped_refptr<cc::Layer> layer_;
- base::android::ScopedJavaGlobalRef<jobject> delegate_;
+ JavaObjectWeakGlobalRef delegate_;
DISALLOW_COPY_AND_ASSIGN(ViewAndroid);
};
« no previous file with comments | « ui/android/ui_android.gyp ('k') | ui/android/view_android.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698