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

Unified Diff: third_party/WebKit/Source/web/CompositorProxyClientImpl.cpp

Issue 1547893003: WIP - compositor worker mega patch. Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 11 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
Index: third_party/WebKit/Source/web/CompositorProxyClientImpl.cpp
diff --git a/third_party/WebKit/Source/web/CompositorProxyClientImpl.cpp b/third_party/WebKit/Source/web/CompositorProxyClientImpl.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..5ad76399bd2d0b8834ac4b13646359c3436a5b13
--- /dev/null
+++ b/third_party/WebKit/Source/web/CompositorProxyClientImpl.cpp
@@ -0,0 +1,126 @@
+// 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.
+
+#include "web/CompositorProxyClientImpl.h"
+
+#include "core/dom/CompositorProxy.h"
+#include "modules/compositorworker/CompositorWorkerGlobalScope.h"
+#include "platform/TraceEvent.h"
+#include "platform/graphics/CompositorMutableState.h"
+#include "platform/graphics/CompositorMutableStateProvider.h"
+#include "web/CompositorMutatorImpl.h"
+
+namespace blink {
+
+CompositorProxyClientImpl::CompositorProxyClientImpl(CompositorMutatorImpl* mutator)
+ : m_mutator(mutator)
+ , m_globalScope(nullptr)
+ , m_executingAnimationFrameCallbacks(false)
+{
+}
+
+CompositorProxyClientImpl::~CompositorProxyClientImpl()
+{
+ m_mutator->unregisterClient(this);
+ for (auto& iter : m_proxies) {
+ for (CompositorProxy* proxy : iter.second)
+ proxy->clearClient();
+ }
+}
+
+void CompositorProxyClientImpl::registerCompositorProxy(CompositorProxy* proxy)
+{
+ uint64_t elementId = proxy->elementId();
+
+ TRACE_EVENT2("compositor-worker,compositor-proxy",
+ "CompositorProxyClientImpl::registerCompositorProxy",
+ "elementId", static_cast<int>(elementId),
+ "proxy", proxy);
+
+ if (!m_proxies.count(elementId)) {
+ m_proxies[elementId] = ProxyVector();
+ }
+ m_proxies[elementId].push_back(proxy);
+}
+
+void CompositorProxyClientImpl::unregisterCompositorProxy(CompositorProxy* proxy)
+{
+ uint64_t elementId = proxy->elementId();
+ if (!m_proxies.count(elementId))
+ return;
+
+ TRACE_EVENT2("compositor-worker,compositor-proxy",
+ "CompositorProxyClientImpl::unregisterCompositorProxy",
+ "elementId", static_cast<int>(elementId),
+ "proxy", proxy);
+
+ ProxyVector& proxies = m_proxies[elementId];
+ proxies.erase(std::find(proxies.begin(), proxies.end(), proxy));
+ if (proxies.size() == 0)
+ m_proxies.erase(elementId);
+}
+
+void CompositorProxyClientImpl::requestSync(CompositorProxy* proxy)
+{
+ TRACE_EVENT0("compositor-worker", "CompositorProxyClientImpl::requestSync");
+ ASSERT(m_executingAnimationFrameCallbacks);
+ m_requiresSync.add(proxy->elementId());
+}
+
+void CompositorProxyClientImpl::setGlobalScope(WorkerGlobalScope* scope)
+{
+ TRACE_EVENT0("compositor-worker", "CompositorProxyClientImpl::setGlobalScope");
+ m_globalScope = static_cast<CompositorWorkerGlobalScope*>(scope);
+ m_mutator->registerClient(this);
+}
+
+void CompositorProxyClientImpl::requestMutation()
+{
+ TRACE_EVENT0("compositor-worker", "CompositorProxyClientImpl::requestMutation");
+ m_requestedAnimationFrameCallbacks = true;
+ m_mutator->setNeedsMutate();
+}
+
+bool CompositorProxyClientImpl::mutate(double timeNow, CompositorMutableStateProvider* stateProvider)
+{
+ if (!m_globalScope)
+ return false;
+
+ TRACE_EVENT0("compositor-worker", "CompositorProxyClientImpl::mutate");
+ willStartCompositorFrameCallbacks(stateProvider);
+
+ if (!m_requestedAnimationFrameCallbacks)
+ return false;
+
+ m_requestedAnimationFrameCallbacks = false;
+ {
+ TemporaryChange<bool> temporary(m_executingAnimationFrameCallbacks, true);
+ m_requestedAnimationFrameCallbacks = executeAnimationFrameCallbacks(timeNow);
+ }
+
+ return m_requestedAnimationFrameCallbacks;
+}
+
+void CompositorProxyClientImpl::willStartCompositorFrameCallbacks(CompositorMutableStateProvider* stateProvider)
+{
+ TRACE_EVENT0("compositor-worker", "CompositorProxyClientImpl::willStartCompositorFrameCallbacks");
+ ASSERT(m_requiresSync.isEmpty());
+ for (auto iter : m_proxies) {
+ for (CompositorProxy* proxy : iter.second)
+ proxy->takeCompositorMutableState(stateProvider->getMutableStateFor(iter.first));
+ }
+}
+
+bool CompositorProxyClientImpl::executeAnimationFrameCallbacks(double time)
+{
+ TRACE_EVENT0("compositor-worker", "CompositorProxyClientImpl::executeAnimationFrameCallbacks");
+ const bool should_reinvoke = m_globalScope->executeAnimationFrameCallbacks(time);
+ for (auto iter : m_proxies) {
+ for (CompositorProxy* proxy : iter.second)
+ proxy->takeCompositorMutableState(nullptr);
+ }
+ return should_reinvoke;
+}
+
+} // namespace blink
« no previous file with comments | « third_party/WebKit/Source/web/CompositorProxyClientImpl.h ('k') | third_party/WebKit/Source/web/WebViewImpl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698