Index: ui/base/compositor/begin_frame_manager.cc |
diff --git a/ui/base/compositor/begin_frame_manager.cc b/ui/base/compositor/begin_frame_manager.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..6051676c2bcb37722c98bcc73a5df229f48b1bc9 |
--- /dev/null |
+++ b/ui/base/compositor/begin_frame_manager.cc |
@@ -0,0 +1,41 @@ |
+// Copyright 2014 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 "ui/base/compositor/begin_frame_manager.h" |
+ |
+#include "cc/output/begin_frame_args.h" |
+ |
+namespace ui { |
+ |
+BeginFrameManager::BeginFrameManager(Delegate* delegate) : delegate_(delegate) { |
+} |
+ |
+BeginFrameManager::~BeginFrameManager() { |
+} |
+ |
+void BeginFrameManager::SendBeginFrame( |
+ const cc::BeginFrameArgs& args) { |
+ DCHECK(CalledOnValidThread()); |
+ FOR_EACH_OBSERVER(Observer, |
+ observer_list_, |
+ OnSendBeginFrame(args)); |
+} |
+ |
+void BeginFrameManager::RequestBeginFrame() const { |
brianderson
2014/08/21 00:14:00
I think this method can be removed.
Instead, dele
simonhong
2014/08/26 08:24:48
Yes! This also can make code more simpler :)
Remov
|
+ DCHECK(CalledOnValidThread()); |
+ DCHECK(delegate_); |
+ delegate_->RequestBeginFrame(); |
+} |
+ |
+void BeginFrameManager::AddObserver(Observer* observer) { |
brianderson
2014/08/21 00:14:00
You may want to make this:
void BeginFrameManager:
simonhong
2014/08/26 08:24:48
Does we need more heuristics for this like "use la
|
+ DCHECK(CalledOnValidThread()); |
+ observer_list_.AddObserver(observer); |
+} |
+ |
+void BeginFrameManager::RemoveObserver(Observer* observer) { |
+ DCHECK(CalledOnValidThread()); |
+ observer_list_.RemoveObserver(observer); |
+} |
+ |
+} // namespace ui |