mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
The primary goal of this change was to remove EventTarget from the
sky_engine C++ code. Since EventTarget is so core to the entire event
system that sky_engine was based on, this is a rather invasive change.
As such, it had some knock-on effects. I deleted some of the files
that were affected, and cauterised the remainder.
In many cases, a file would depend on another file that it didn't
include directly, but instead included indirectly via another file
that I deleted. When this happened, if the features that this broke
were obsolete, I sometimes just removed the features instead.
Specifically:
- removed EventTarget
- removed EventQueue, since without a target, what's a queue going to
do?
- same with EventDispatch*
- removed ExecutionContext, since it had an EventQueue and nothing
else it did was relevant to Sky anymore
- removed ActiveDOMObject, which was all about ExecutionContexts
- removed ContextLifecycleNotifier since it dependend on
ExecutionContext and ActiveDOMObject
- removed the other Lifecycle classes for consistency, and replaced
them with four booleans in the Document class
- removed some of the attributes that are no longer relevant from
IDLExtendedAttributes (ConstructorCallWith and
CallWith=ExecutionContext)
- removed the Document member on DOMDartState since we never set it to
anything but null.
- removed BuiltinSky::InstallWindow since it relied on the Document
member of DOMDartState
- removed EventHandler, EventListener, and mentions of those in
various binding scripts
- removed NewEventHandler, since we're not using that either
- removed the following interfaces from the Sky Dart API:
- EventTarget
- EventListener (since without a target, there's no way to listen)
- FocusEvent (since it's only member was an EventTarget)
- HashChangeEvent (mostly by accident, but it's defunct anyway)
- FontFace (it used ConstructorCallWith=ExecutionContext)
- changed the following interfaces of the Sky DART API:
- MediaQueryList is no longer an EventTarget
- Node is no longer an EventTarget
- Document no longer has defaultView (depended on
DOMDartState's document)
- DocumentFragment, Element, Range, and Text no longer have a
constructor (they all depended on DOMDartState's document, which
is now gone)
- Event lost its EventTarget members and path.
- Window lost its WindowTimers partial interface (it used
EventTarget and ExecutionContext a lot)
- removed numerous hacks in the bindings around features that are now
gone, like addEventListener
- removed a bunch of console logging code, since that relied on
ExecutionContext
- cauterised the wound in FontFace.cpp by removing constructors and
methods that called now-removed features
- same with MediaQuery and friends
- same with some editor features and focus-related features
- same with Document
- removed DOMTimer classes since they use ExecutionContexts
199 lines
6.9 KiB
C++
199 lines
6.9 KiB
C++
/*
|
|
* Copyright (C) 2011 Google Inc. All Rights Reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND ANY
|
|
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
*/
|
|
|
|
#include "sky/engine/core/dom/ScriptedAnimationController.h"
|
|
|
|
#include "sky/engine/core/css/MediaQueryListListener.h"
|
|
#include "sky/engine/core/dom/Document.h"
|
|
#include "sky/engine/core/dom/RequestAnimationFrameCallback.h"
|
|
#include "sky/engine/core/events/Event.h"
|
|
#include "sky/engine/core/frame/FrameView.h"
|
|
#include "sky/engine/core/frame/LocalDOMWindow.h"
|
|
#include "sky/engine/core/page/Page.h"
|
|
#include "sky/engine/platform/Logging.h"
|
|
|
|
namespace blink {
|
|
|
|
ScriptedAnimationController::ScriptedAnimationController(Document* document)
|
|
: m_document(document)
|
|
, m_nextCallbackId(0)
|
|
, m_suspendCount(0)
|
|
{
|
|
}
|
|
|
|
ScriptedAnimationController::~ScriptedAnimationController()
|
|
{
|
|
}
|
|
|
|
void ScriptedAnimationController::suspend()
|
|
{
|
|
++m_suspendCount;
|
|
WTF_LOG(ScriptedAnimationController, "suspend: count = %d", m_suspendCount);
|
|
}
|
|
|
|
void ScriptedAnimationController::resume()
|
|
{
|
|
// It would be nice to put an ASSERT(m_suspendCount > 0) here, but in WK1 resume() can be called
|
|
// even when suspend hasn't (if a tab was created in the background).
|
|
if (m_suspendCount > 0)
|
|
--m_suspendCount;
|
|
WTF_LOG(ScriptedAnimationController, "resume: count = %d", m_suspendCount);
|
|
scheduleAnimationIfNeeded();
|
|
}
|
|
|
|
ScriptedAnimationController::CallbackId ScriptedAnimationController::registerCallback(PassOwnPtr<RequestAnimationFrameCallback> callback)
|
|
{
|
|
ScriptedAnimationController::CallbackId id = ++m_nextCallbackId;
|
|
WTF_LOG(ScriptedAnimationController, "registerCallback: id = %d", id);
|
|
callback->m_cancelled = false;
|
|
callback->m_id = id;
|
|
m_callbacks.append(callback);
|
|
scheduleAnimationIfNeeded();
|
|
return id;
|
|
}
|
|
|
|
void ScriptedAnimationController::cancelCallback(CallbackId id)
|
|
{
|
|
WTF_LOG(ScriptedAnimationController, "cancelCallback: id = %d", id);
|
|
for (size_t i = 0; i < m_callbacks.size(); ++i) {
|
|
if (m_callbacks[i]->m_id == id) {
|
|
m_callbacks.remove(i);
|
|
return;
|
|
}
|
|
}
|
|
for (size_t i = 0; i < m_callbacksToInvoke.size(); ++i) {
|
|
if (m_callbacksToInvoke[i]->m_id == id) {
|
|
m_callbacksToInvoke[i]->m_cancelled = true;
|
|
// will be removed at the end of executeCallbacks()
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
void ScriptedAnimationController::dispatchEvents()
|
|
{
|
|
Vector<RefPtr<Event> > events;
|
|
events.swap(m_eventQueue);
|
|
}
|
|
|
|
void ScriptedAnimationController::executeCallbacks(double monotonicTimeNow)
|
|
{
|
|
// dispatchEvents() runs script which can cause the document to be destroyed.
|
|
if (!m_document)
|
|
return;
|
|
|
|
double highResNowMs = 1000.0 * monotonicTimeNow;
|
|
|
|
// First, generate a list of callbacks to consider. Callbacks registered from this point
|
|
// on are considered only for the "next" frame, not this one.
|
|
ASSERT(m_callbacksToInvoke.isEmpty());
|
|
m_callbacksToInvoke.swap(m_callbacks);
|
|
|
|
for (size_t i = 0; i < m_callbacksToInvoke.size(); ++i) {
|
|
RequestAnimationFrameCallback* callback = m_callbacksToInvoke[i].get();
|
|
if (!callback->m_cancelled)
|
|
callback->handleEvent(highResNowMs);
|
|
}
|
|
|
|
m_callbacksToInvoke.clear();
|
|
}
|
|
|
|
void ScriptedAnimationController::callMediaQueryListListeners()
|
|
{
|
|
MediaQueryListListeners listeners;
|
|
listeners.swap(m_mediaQueryListListeners);
|
|
|
|
for (MediaQueryListListeners::const_iterator it = listeners.begin(), end = listeners.end();
|
|
it != end; ++it) {
|
|
(*it)->notifyMediaQueryChanged();
|
|
}
|
|
}
|
|
|
|
void ScriptedAnimationController::serviceScriptedAnimations(double monotonicTimeNow)
|
|
{
|
|
WTF_LOG(ScriptedAnimationController, "serviceScriptedAnimations: #callbacks = %d, #events = %d, #mediaQueryListListeners = %d, count = %d",
|
|
static_cast<int>(m_callbacks.size()),
|
|
static_cast<int>(m_eventQueue.size()),
|
|
static_cast<int>(m_mediaQueryListListeners.size()),
|
|
m_suspendCount);
|
|
if (!m_callbacks.size() && !m_eventQueue.size() && !m_mediaQueryListListeners.size())
|
|
return;
|
|
|
|
if (m_suspendCount)
|
|
return;
|
|
|
|
RefPtr<ScriptedAnimationController> protect(this);
|
|
|
|
callMediaQueryListListeners();
|
|
dispatchEvents();
|
|
executeCallbacks(monotonicTimeNow);
|
|
|
|
scheduleAnimationIfNeeded();
|
|
}
|
|
|
|
void ScriptedAnimationController::enqueueEvent(PassRefPtr<Event> event)
|
|
{
|
|
WTF_LOG(ScriptedAnimationController, "enqueueEvent");
|
|
m_eventQueue.append(event);
|
|
scheduleAnimationIfNeeded();
|
|
}
|
|
|
|
void ScriptedAnimationController::enqueuePerFrameEvent(PassRefPtr<Event> event)
|
|
{
|
|
enqueueEvent(event);
|
|
}
|
|
|
|
void ScriptedAnimationController::enqueueMediaQueryChangeListeners(Vector<RefPtr<MediaQueryListListener> >& listeners)
|
|
{
|
|
WTF_LOG(ScriptedAnimationController, "enqueueMediaQueryChangeListeners");
|
|
for (size_t i = 0; i < listeners.size(); ++i) {
|
|
m_mediaQueryListListeners.add(listeners[i]);
|
|
}
|
|
scheduleAnimationIfNeeded();
|
|
}
|
|
|
|
void ScriptedAnimationController::scheduleAnimationIfNeeded()
|
|
{
|
|
WTF_LOG(ScriptedAnimationController, "scheduleAnimationIfNeeded: document = %d, count = %d, #callbacks = %d, #events = %d, #mediaQueryListListeners =%d, frameView = %d",
|
|
m_document ? 1 : 0, m_suspendCount,
|
|
static_cast<int>(m_callbacks.size()),
|
|
static_cast<int>(m_eventQueue.size()),
|
|
static_cast<int>(m_mediaQueryListListeners.size()),
|
|
m_document && m_document->view() ? 1 : 0);
|
|
if (!m_document)
|
|
return;
|
|
|
|
if (m_suspendCount)
|
|
return;
|
|
|
|
if (!m_callbacks.size() && !m_eventQueue.size() && !m_mediaQueryListListeners.size())
|
|
return;
|
|
|
|
// TODO(esprehn): This causes a full raster on every raf even if nothing changed.
|
|
m_document->page()->scheduleVisualUpdate();
|
|
}
|
|
|
|
}
|