OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ui/gfx/compositor/compositor.h" | 5 #include "ui/gfx/compositor/compositor.h" |
6 | 6 |
7 #include "ui/gfx/compositor/compositor_observer.h" | 7 #include "ui/gfx/compositor/compositor_observer.h" |
8 #include "ui/gfx/compositor/layer.h" | 8 #include "ui/gfx/compositor/layer.h" |
9 | 9 |
10 namespace ui { | 10 namespace ui { |
11 | 11 |
12 TextureDrawParams::TextureDrawParams() | 12 TextureDrawParams::TextureDrawParams() |
13 : blend(false), | 13 : blend(false), |
14 has_valid_alpha_channel(false), | 14 has_valid_alpha_channel(false), |
15 opacity(1.0f), | 15 opacity(1.0f), |
16 vertically_flipped(false) { | 16 vertically_flipped(false) { |
17 } | 17 } |
18 | 18 |
19 Compositor::Compositor(CompositorDelegate* delegate, const gfx::Size& size) | 19 Compositor::Compositor(CompositorDelegate* delegate, const gfx::Size& size) |
20 : delegate_(delegate), | 20 : delegate_(delegate), |
21 size_(size), | 21 size_(size), |
22 root_layer_(NULL) { | 22 root_layer_(NULL) { |
23 } | 23 } |
24 | 24 |
25 Compositor::~Compositor() { | 25 Compositor::~Compositor() { |
26 } | 26 } |
27 | 27 |
28 void Compositor::OnRootLayerChanged() { | |
Ben Goodger (Google)
2011/10/16 22:39:51
please keep the order of functions in the .cc in s
piman
2011/10/19 17:53:23
Done.
| |
29 ScheduleDraw(); | |
30 } | |
31 | |
28 void Compositor::SetRootLayer(Layer* root_layer) { | 32 void Compositor::SetRootLayer(Layer* root_layer) { |
29 root_layer_ = root_layer; | 33 root_layer_ = root_layer; |
30 if (!root_layer_->GetCompositor()) | 34 if (!root_layer_->GetCompositor()) |
31 root_layer_->SetCompositor(this); | 35 root_layer_->SetCompositor(this); |
36 OnRootLayerChanged(); | |
32 } | 37 } |
33 | 38 |
34 void Compositor::Draw(bool force_clear) { | 39 void Compositor::Draw(bool force_clear) { |
35 if (!root_layer_) | 40 if (!root_layer_) |
36 return; | 41 return; |
37 | 42 |
38 NotifyStart(force_clear); | 43 NotifyStart(force_clear); |
44 DrawTree(); | |
45 NotifyEnd(); | |
46 } | |
47 | |
48 void Compositor::DrawTree() { | |
39 root_layer_->DrawTree(); | 49 root_layer_->DrawTree(); |
40 NotifyEnd(); | |
41 } | 50 } |
42 | 51 |
43 void Compositor::AddObserver(CompositorObserver* observer) { | 52 void Compositor::AddObserver(CompositorObserver* observer) { |
44 observer_list_.AddObserver(observer); | 53 observer_list_.AddObserver(observer); |
45 } | 54 } |
46 | 55 |
47 void Compositor::RemoveObserver(CompositorObserver* observer) { | 56 void Compositor::RemoveObserver(CompositorObserver* observer) { |
48 observer_list_.RemoveObserver(observer); | 57 observer_list_.RemoveObserver(observer); |
49 } | 58 } |
50 | 59 |
51 bool Compositor::HasObserver(CompositorObserver* observer) { | 60 bool Compositor::HasObserver(CompositorObserver* observer) { |
52 return observer_list_.HasObserver(observer); | 61 return observer_list_.HasObserver(observer); |
53 } | 62 } |
54 | 63 |
55 void Compositor::NotifyStart(bool clear) { | 64 void Compositor::NotifyStart(bool clear) { |
56 OnNotifyStart(clear); | 65 OnNotifyStart(clear); |
57 } | 66 } |
58 | 67 |
59 void Compositor::NotifyEnd() { | 68 void Compositor::NotifyEnd() { |
60 OnNotifyEnd(); | 69 OnNotifyEnd(); |
61 FOR_EACH_OBSERVER(CompositorObserver, | 70 FOR_EACH_OBSERVER(CompositorObserver, |
62 observer_list_, | 71 observer_list_, |
63 OnCompositingEnded(this)); | 72 OnCompositingEnded(this)); |
64 } | 73 } |
65 | 74 |
66 } // namespace ui | 75 } // namespace ui |
OLD | NEW |