Chromium Code Reviews| Index: third_party/WebKit/Source/core/dom/ElementVisibilityObserver.cpp |
| diff --git a/third_party/WebKit/Source/core/dom/ElementVisibilityObserver.cpp b/third_party/WebKit/Source/core/dom/ElementVisibilityObserver.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..0cfaf4ce1afd91a8602b2532b9d2d7af6d7cfe65 |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/core/dom/ElementVisibilityObserver.cpp |
| @@ -0,0 +1,53 @@ |
| +// Copyright 2016 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. |
| + |
| +#include "core/dom/ElementVisibilityObserver.h" |
| + |
| +#include "core/dom/Element.h" |
| +#include "core/dom/IntersectionObserverEntry.h" |
| +#include "wtf/Functional.h" |
| + |
| +namespace blink { |
| + |
| +ElementVisibilityObserver::ElementVisibilityObserver(Element* element, std::unique_ptr<VisibilityCallback> callback) |
| + : m_element(element) |
| + , m_callback(std::move(callback)) |
| +{ |
| +} |
| + |
| +ElementVisibilityObserver::~ElementVisibilityObserver() = default; |
| + |
| +void ElementVisibilityObserver::start() |
| +{ |
| + DCHECK(!m_intersectionObserver); |
| + m_intersectionObserver = IntersectionObserver::create( |
| + Vector<Length>(), Vector<float>({std::numeric_limits<float>::min()}), &m_element->document(), |
| + WTF::bind<const HeapVector<Member<IntersectionObserverEntry>>&>(&ElementVisibilityObserver::onVisibilityChanged, WeakPersistentThisPointer<ElementVisibilityObserver>(this))); |
| + DCHECK(m_intersectionObserver); |
| + m_intersectionObserver->observe(m_element); |
| +} |
| + |
| +void ElementVisibilityObserver::stop() |
| +{ |
| + DCHECK(m_intersectionObserver); |
| + |
| + m_intersectionObserver->unobserve(m_element); |
| + m_intersectionObserver = nullptr; |
| +} |
| + |
| +DEFINE_TRACE(ElementVisibilityObserver) |
| +{ |
| + visitor->trace(m_element); |
| + visitor->trace(m_intersectionObserver); |
| +} |
| + |
| +void ElementVisibilityObserver::onVisibilityChanged(const HeapVector<Member<IntersectionObserverEntry>>& entries) |
| +{ |
| + DCHECK_EQ(entries.size(), 1u); |
|
szager1
2016/06/21 21:18:05
This is a bad assumption; observations are taken e
mlamouri (slow - plz ping)
2016/06/21 21:25:50
Good to know! These small things comforts me in ha
|
| + |
| + bool isVisible = entries[0]->intersectionRatio() > 0.f; |
| + (*m_callback.get())(isVisible); |
| +} |
| + |
| +} // namespace blink |