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

Unified Diff: third_party/WebKit/Source/core/dom/IntersectionObserver.h

Issue 1449623002: IntersectionObserver: second cut. (Closed) Base URL: https://chromium.googlesource.com/chromium/src@master
Patch Set: Implemented root margin Created 5 years 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: third_party/WebKit/Source/core/dom/IntersectionObserver.h
diff --git a/third_party/WebKit/Source/core/dom/IntersectionObserver.h b/third_party/WebKit/Source/core/dom/IntersectionObserver.h
new file mode 100644
index 0000000000000000000000000000000000000000..aa6ccd2500536ce806bac439124a0d2b89e0a915
--- /dev/null
+++ b/third_party/WebKit/Source/core/dom/IntersectionObserver.h
@@ -0,0 +1,76 @@
+// Copyright 2015 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 IntersectionObserver_h
+#define IntersectionObserver_h
+
+#include "bindings/core/v8/ScriptWrappable.h"
+#include "core/dom/Element.h"
+#include "core/dom/IntersectionObservation.h"
+#include "core/dom/IntersectionObserverEntry.h"
+#include "platform/heap/Handle.h"
+#include "wtf/HashSet.h"
+#include "wtf/RefCounted.h"
+#include "wtf/Vector.h"
+
+namespace blink {
+
+class ExceptionState;
+class IntersectionObserverCallback;
+class IntersectionObserverInit;
+
+typedef HeapVector<Member<IntersectionObserverEntry>> IntersectionObserverEntryVector;
esprehn 2015/12/12 00:14:16 remove the typedefs, the name is nearly as long as
szager1 2015/12/16 19:15:36 Done.
+
+class IntersectionObserver final : public GarbageCollectedFinalized<IntersectionObserver>, public ScriptWrappable {
+ DEFINE_WRAPPERTYPEINFO();
+public:
+ typedef HeapHashSet<Member<IntersectionObserver>> HashSet;
+ typedef HeapHashSet<WeakMember<IntersectionObserver>> WeakHashSet;
esprehn 2015/12/12 00:14:16 I'd remove these and just type out the types in th
szager1 2015/12/16 19:15:37 Done.
+
+ static IntersectionObserver* create(const IntersectionObserverInit&, IntersectionObserverCallback*, ExceptionState&);
+ static void resumeSuspendedObservers();
+
+ // API methods
+ void observe(Element*, ExceptionState&);
+ void unobserve(Element*, ExceptionState&);
+ void disconnect();
+ IntersectionObserverEntryVector takeRecords();
+
+ Element* root() { return m_root.get(); }
+ void computeIntersectionObservations(int);
+ void disconnect(IntersectionObservation&);
+ bool isDescendantOfRoot(Element*) const;
esprehn 2015/12/12 00:14:16 reference
szager1 2015/12/16 19:15:36 I'd argue that in this particular case, using a re
+ void enqueueIntersectionObserverEntry(IntersectionObserverEntry*);
esprehn 2015/12/12 00:14:16 reference
szager1 2015/12/16 19:15:36 Done.
+ void applyRootMargin(LayoutRect&) const;
+ size_t firstThresholdGreaterThan(float ratio) const;
+ bool shouldBeSuspended() const;
+ void deliver();
+ void setActive(bool);
+ bool hasPercentMargin() const;
+ const Length& topMargin() const { return m_topMargin; }
+ const Length& rightMargin() const { return m_rightMargin; }
+ const Length& bottomMargin() const { return m_bottomMargin; }
+ const Length& leftMargin() const { return m_leftMargin; }
+
+ DECLARE_TRACE();
+
+private:
+ explicit IntersectionObserver(IntersectionObserverCallback*, Element*, const Vector<Length>&, const Vector<float>&);
esprehn 2015/12/12 00:14:16 reference for most of these I think? Also the two
szager1 2015/12/16 19:15:36 Done.
+
+ void checkRootAndDetachIfNecessary();
+
esprehn 2015/12/12 00:14:16 Needed() not Necessary.
ojan 2015/12/12 01:06:29 Lets just call this checkRootAndDetach. We have to
esprehn 2015/12/12 01:49:52 Actually looking at this function just call it det
szager1 2015/12/16 19:15:36 That's not actually what it does. Rather, it chec
+ Member<IntersectionObserverCallback> m_callback;
+ WeakPtrWillBeWeakMember<Element> m_root;
+ Member<IntersectionObservation::WeakHashSet> m_observations;
esprehn 2015/12/12 00:14:16 just write the types
szager1 2015/12/16 19:15:37 Done.
+ Member<IntersectionObserverEntryVector> m_entries;
+ Vector<float> m_thresholds;
+ Length m_topMargin;
+ Length m_rightMargin;
+ Length m_bottomMargin;
+ Length m_leftMargin;
esprehn 2015/12/12 00:14:16 wow these things are big... you definitely won't w
szager1 2015/12/16 19:15:36 That would be a very strange use case. I agree th
+};
+
+} // namespace blink
+
+#endif // IntersectionObserver_h

Powered by Google App Engine
This is Rietveld 408576698