OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "platform/graphics/CompositorMutatorClient.h" | 5 #include "platform/graphics/CompositorMutatorClient.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "base/trace_event/trace_event.h" | 9 #include "base/trace_event/trace_event.h" |
10 #include "cc/trees/layer_tree_impl.h" | 10 #include "cc/trees/layer_tree_impl.h" |
11 #include "platform/graphics/CompositorMutableStateProvider.h" | 11 #include "platform/graphics/CompositorMutableStateProvider.h" |
12 #include "platform/graphics/CompositorMutation.h" | 12 #include "platform/graphics/CompositorMutation.h" |
13 #include "platform/graphics/CompositorMutationsTarget.h" | 13 #include "platform/graphics/CompositorMutationsTarget.h" |
14 #include "platform/graphics/CompositorMutator.h" | 14 #include "platform/graphics/CompositorMutator.h" |
15 #include "wtf/PtrUtil.h" | |
16 #include <memory> | |
17 | 15 |
18 namespace blink { | 16 namespace blink { |
19 | 17 |
20 CompositorMutatorClient::CompositorMutatorClient(CompositorMutator* mutator, Com
positorMutationsTarget* mutationsTarget) | 18 CompositorMutatorClient::CompositorMutatorClient(CompositorMutator* mutator, Com
positorMutationsTarget* mutationsTarget) |
21 : m_client(nullptr) | 19 : m_client(nullptr) |
22 , m_mutationsTarget(mutationsTarget) | 20 , m_mutationsTarget(mutationsTarget) |
23 , m_mutator(mutator) | 21 , m_mutator(mutator) |
24 , m_mutations(nullptr) | 22 , m_mutations(nullptr) |
25 { | 23 { |
26 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositorMuta
torClient::CompositorMutatorClient"); | 24 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositorMuta
torClient::CompositorMutatorClient"); |
27 } | 25 } |
28 | 26 |
29 CompositorMutatorClient::~CompositorMutatorClient() | 27 CompositorMutatorClient::~CompositorMutatorClient() |
30 { | 28 { |
31 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositorMuta
torClient::~CompositorMutatorClient"); | 29 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositorMuta
torClient::~CompositorMutatorClient"); |
32 } | 30 } |
33 | 31 |
34 bool CompositorMutatorClient::Mutate( | 32 bool CompositorMutatorClient::Mutate( |
35 base::TimeTicks monotonicTime, | 33 base::TimeTicks monotonicTime, |
36 cc::LayerTreeImpl* treeImpl) | 34 cc::LayerTreeImpl* treeImpl) |
37 { | 35 { |
38 TRACE_EVENT0("compositor-worker", "CompositorMutatorClient::Mutate"); | 36 TRACE_EVENT0("compositor-worker", "CompositorMutatorClient::Mutate"); |
39 double monotonicTimeNow = (monotonicTime - base::TimeTicks()).InSecondsF(); | 37 double monotonicTimeNow = (monotonicTime - base::TimeTicks()).InSecondsF(); |
40 if (!m_mutations) | 38 if (!m_mutations) |
41 m_mutations = wrapUnique(new CompositorMutations); | 39 m_mutations = adoptPtr(new CompositorMutations); |
42 CompositorMutableStateProvider compositorState(treeImpl, m_mutations.get()); | 40 CompositorMutableStateProvider compositorState(treeImpl, m_mutations.get()); |
43 bool shouldReinvoke = m_mutator->mutate(monotonicTimeNow, &compositorState); | 41 bool shouldReinvoke = m_mutator->mutate(monotonicTimeNow, &compositorState); |
44 return shouldReinvoke; | 42 return shouldReinvoke; |
45 } | 43 } |
46 | 44 |
47 void CompositorMutatorClient::SetClient(cc::LayerTreeMutatorClient* client) | 45 void CompositorMutatorClient::SetClient(cc::LayerTreeMutatorClient* client) |
48 { | 46 { |
49 TRACE_EVENT0("compositor-worker", "CompositorMutatorClient::SetClient"); | 47 TRACE_EVENT0("compositor-worker", "CompositorMutatorClient::SetClient"); |
50 m_client = client; | 48 m_client = client; |
51 setNeedsMutate(); | 49 setNeedsMutate(); |
52 } | 50 } |
53 | 51 |
54 base::Closure CompositorMutatorClient::TakeMutations() | 52 base::Closure CompositorMutatorClient::TakeMutations() |
55 { | 53 { |
56 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositorMuta
torClient::TakeMutations"); | 54 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositorMuta
torClient::TakeMutations"); |
57 if (!m_mutations) | 55 if (!m_mutations) |
58 return base::Closure(); | 56 return base::Closure(); |
59 | 57 |
60 return base::Bind(&CompositorMutationsTarget::applyMutations, | 58 return base::Bind(&CompositorMutationsTarget::applyMutations, |
61 base::Unretained(m_mutationsTarget), | 59 base::Unretained(m_mutationsTarget), |
62 base::Owned(m_mutations.release())); | 60 base::Owned(m_mutations.leakPtr())); |
63 } | 61 } |
64 | 62 |
65 void CompositorMutatorClient::setNeedsMutate() | 63 void CompositorMutatorClient::setNeedsMutate() |
66 { | 64 { |
67 TRACE_EVENT0("compositor-worker", "CompositorMutatorClient::setNeedsMutate")
; | 65 TRACE_EVENT0("compositor-worker", "CompositorMutatorClient::setNeedsMutate")
; |
68 m_client->SetNeedsMutate(); | 66 m_client->SetNeedsMutate(); |
69 } | 67 } |
70 | 68 |
71 void CompositorMutatorClient::setMutationsForTesting(std::unique_ptr<CompositorM
utations> mutations) | 69 void CompositorMutatorClient::setMutationsForTesting(PassOwnPtr<CompositorMutati
ons> mutations) |
72 { | 70 { |
73 m_mutations = std::move(mutations); | 71 m_mutations = std::move(mutations); |
74 } | 72 } |
75 | 73 |
76 } // namespace blink | 74 } // namespace blink |
OLD | NEW |