OLD | NEW |
| (Empty) |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "cc/debug/rendering_stats.h" | |
6 | |
7 namespace cc { | |
8 | |
9 RenderingStats::TimeDeltaList::TimeDeltaList() { | |
10 } | |
11 | |
12 RenderingStats::TimeDeltaList::~TimeDeltaList() { | |
13 } | |
14 | |
15 void RenderingStats::TimeDeltaList::Append(base::TimeDelta value) { | |
16 values.push_back(value); | |
17 } | |
18 | |
19 void RenderingStats::TimeDeltaList::AddToTracedValue( | |
20 const char* name, | |
21 base::trace_event::TracedValue* list_value) const { | |
22 list_value->BeginArray(name); | |
23 for (const auto& value : values) { | |
24 list_value->AppendDouble(value.InMillisecondsF()); | |
25 } | |
26 list_value->EndArray(); | |
27 } | |
28 | |
29 void RenderingStats::TimeDeltaList::Add(const TimeDeltaList& other) { | |
30 values.insert(values.end(), other.values.begin(), other.values.end()); | |
31 } | |
32 | |
33 base::TimeDelta RenderingStats::TimeDeltaList::GetLastTimeDelta() const { | |
34 return values.empty() ? base::TimeDelta() : values.back(); | |
35 } | |
36 | |
37 RenderingStats::RenderingStats() | |
38 : frame_count(0), | |
39 visible_content_area(0), | |
40 approximated_visible_content_area(0) { | |
41 } | |
42 | |
43 RenderingStats::~RenderingStats() { | |
44 } | |
45 | |
46 scoped_refptr<base::trace_event::ConvertableToTraceFormat> | |
47 RenderingStats::AsTraceableData() const { | |
48 scoped_refptr<base::trace_event::TracedValue> record_data = | |
49 new base::trace_event::TracedValue(); | |
50 record_data->SetInteger("frame_count", frame_count); | |
51 record_data->SetInteger("visible_content_area", visible_content_area); | |
52 record_data->SetInteger("approximated_visible_content_area", | |
53 approximated_visible_content_area); | |
54 draw_duration.AddToTracedValue("draw_duration_ms", record_data.get()); | |
55 | |
56 draw_duration_estimate.AddToTracedValue("draw_duration_estimate_ms", | |
57 record_data.get()); | |
58 | |
59 begin_main_frame_to_commit_duration.AddToTracedValue( | |
60 "begin_main_frame_to_commit_duration_ms", record_data.get()); | |
61 | |
62 begin_main_frame_to_commit_duration_estimate.AddToTracedValue( | |
63 "begin_main_frame_to_commit_duration_estimate_ms", record_data.get()); | |
64 | |
65 commit_to_activate_duration.AddToTracedValue("commit_to_activate_duration_ms", | |
66 record_data.get()); | |
67 | |
68 commit_to_activate_duration_estimate.AddToTracedValue( | |
69 "commit_to_activate_duration_estimate_ms", record_data.get()); | |
70 return record_data; | |
71 } | |
72 | |
73 void RenderingStats::Add(const RenderingStats& other) { | |
74 frame_count += other.frame_count; | |
75 visible_content_area += other.visible_content_area; | |
76 approximated_visible_content_area += other.approximated_visible_content_area; | |
77 | |
78 draw_duration.Add(other.draw_duration); | |
79 draw_duration_estimate.Add(other.draw_duration_estimate); | |
80 begin_main_frame_to_commit_duration.Add( | |
81 other.begin_main_frame_to_commit_duration); | |
82 begin_main_frame_to_commit_duration_estimate.Add( | |
83 other.begin_main_frame_to_commit_duration_estimate); | |
84 commit_to_activate_duration.Add(other.commit_to_activate_duration); | |
85 commit_to_activate_duration_estimate.Add( | |
86 other.commit_to_activate_duration_estimate); | |
87 } | |
88 | |
89 } // namespace cc | |
OLD | NEW |