| OLD | NEW |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 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 | 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 "base/values.h" | 5 #include "base/values.h" |
| 6 #include "cc/debug/rendering_stats.h" | 6 #include "cc/debug/rendering_stats.h" |
| 7 | 7 |
| 8 namespace cc { | 8 namespace cc { |
| 9 | 9 |
| 10 MainThreadRenderingStats::MainThreadRenderingStats() | 10 MainThreadRenderingStats::MainThreadRenderingStats() |
| 11 : frame_count(0), | 11 : frame_count(0), |
| 12 painted_pixel_count(0), | 12 painted_pixel_count(0), |
| 13 recorded_pixel_count(0) {} | 13 recorded_pixel_count(0) {} |
| 14 | 14 |
| 15 MainThreadRenderingStats::~MainThreadRenderingStats() { |
| 16 } |
| 17 |
| 15 scoped_refptr<base::debug::ConvertableToTraceFormat> | 18 scoped_refptr<base::debug::ConvertableToTraceFormat> |
| 16 MainThreadRenderingStats::AsTraceableData() const { | 19 MainThreadRenderingStats::AsTraceableData() const { |
| 17 scoped_ptr<base::DictionaryValue> record_data(new base::DictionaryValue()); | 20 scoped_ptr<base::DictionaryValue> record_data(new base::DictionaryValue()); |
| 18 record_data->SetInteger("frame_count", frame_count); | 21 record_data->SetInteger("frame_count", frame_count); |
| 19 record_data->SetDouble("paint_time", paint_time.InSecondsF()); | 22 record_data->SetDouble("paint_time", paint_time.InSecondsF()); |
| 20 record_data->SetInteger("painted_pixel_count", painted_pixel_count); | 23 record_data->SetInteger("painted_pixel_count", painted_pixel_count); |
| 21 record_data->SetDouble("record_time", record_time.InSecondsF()); | 24 record_data->SetDouble("record_time", record_time.InSecondsF()); |
| 22 record_data->SetInteger("recorded_pixel_count", recorded_pixel_count); | 25 record_data->SetInteger("recorded_pixel_count", recorded_pixel_count); |
| 23 return TracedValue::FromValue(record_data.release()); | 26 return TracedValue::FromValue(record_data.release()); |
| 24 } | 27 } |
| 25 | 28 |
| 26 void MainThreadRenderingStats::Add(const MainThreadRenderingStats& other) { | 29 void MainThreadRenderingStats::Add(const MainThreadRenderingStats& other) { |
| 27 frame_count += other.frame_count; | 30 frame_count += other.frame_count; |
| 28 paint_time += other.paint_time; | 31 paint_time += other.paint_time; |
| 29 painted_pixel_count += other.painted_pixel_count; | 32 painted_pixel_count += other.painted_pixel_count; |
| 30 record_time += other.record_time; | 33 record_time += other.record_time; |
| 31 recorded_pixel_count += other.recorded_pixel_count; | 34 recorded_pixel_count += other.recorded_pixel_count; |
| 32 } | 35 } |
| 33 | 36 |
| 37 TimeDeltaList::TimeDeltaList() { |
| 38 } |
| 39 |
| 40 TimeDeltaList::~TimeDeltaList() { |
| 41 } |
| 42 |
| 43 void TimeDeltaList::Append(base::TimeDelta value) { |
| 44 values.push_back(value); |
| 45 } |
| 46 |
| 47 scoped_ptr<base::ListValue> TimeDeltaList::AsListValueInMilliseconds() const { |
| 48 scoped_ptr<base::ListValue> list_value(new base::ListValue); |
| 49 std::list<base::TimeDelta>::const_iterator iter; |
| 50 for (iter = values.begin(); iter != values.end(); ++iter) { |
| 51 list_value->AppendDouble(iter->InMillisecondsF()); |
| 52 } |
| 53 return list_value.Pass(); |
| 54 } |
| 55 |
| 56 void TimeDeltaList::Add(const TimeDeltaList& other) { |
| 57 values.insert(values.end(), other.values.begin(), other.values.end()); |
| 58 } |
| 59 |
| 34 ImplThreadRenderingStats::ImplThreadRenderingStats() | 60 ImplThreadRenderingStats::ImplThreadRenderingStats() |
| 35 : frame_count(0), | 61 : frame_count(0), |
| 36 rasterized_pixel_count(0), | 62 rasterized_pixel_count(0), |
| 37 visible_content_area(0), | 63 visible_content_area(0), |
| 38 approximated_visible_content_area(0) { | 64 approximated_visible_content_area(0) { |
| 39 } | 65 } |
| 40 | 66 |
| 67 ImplThreadRenderingStats::~ImplThreadRenderingStats() { |
| 68 } |
| 69 |
| 41 scoped_refptr<base::debug::ConvertableToTraceFormat> | 70 scoped_refptr<base::debug::ConvertableToTraceFormat> |
| 42 ImplThreadRenderingStats::AsTraceableData() const { | 71 ImplThreadRenderingStats::AsTraceableData() const { |
| 43 scoped_ptr<base::DictionaryValue> record_data(new base::DictionaryValue()); | 72 scoped_ptr<base::DictionaryValue> record_data(new base::DictionaryValue()); |
| 44 record_data->SetInteger("frame_count", frame_count); | 73 record_data->SetInteger("frame_count", frame_count); |
| 45 record_data->SetDouble("rasterize_time", rasterize_time.InSecondsF()); | 74 record_data->SetDouble("rasterize_time", rasterize_time.InSecondsF()); |
| 46 record_data->SetInteger("rasterized_pixel_count", rasterized_pixel_count); | 75 record_data->SetInteger("rasterized_pixel_count", rasterized_pixel_count); |
| 47 record_data->SetInteger("visible_content_area", visible_content_area); | 76 record_data->SetInteger("visible_content_area", visible_content_area); |
| 48 record_data->SetInteger("approximated_visible_content_area", | 77 record_data->SetInteger("approximated_visible_content_area", |
| 49 approximated_visible_content_area); | 78 approximated_visible_content_area); |
| 79 record_data->Set("draw_duration_ms", |
| 80 draw_duration.AsListValueInMilliseconds().release()); |
| 81 record_data->Set( |
| 82 "draw_duration_estimate_ms", |
| 83 draw_duration_estimate.AsListValueInMilliseconds().release()); |
| 84 record_data->Set( |
| 85 "begin_main_frame_to_commit_duration_ms", |
| 86 begin_main_frame_to_commit_duration.AsListValueInMilliseconds() |
| 87 .release()); |
| 88 record_data->Set( |
| 89 "begin_main_frame_to_commit_duration_estimate_ms", |
| 90 begin_main_frame_to_commit_duration_estimate.AsListValueInMilliseconds() |
| 91 .release()); |
| 92 record_data->Set( |
| 93 "commit_to_activate_duration_ms", |
| 94 commit_to_activate_duration.AsListValueInMilliseconds().release()); |
| 95 record_data->Set( |
| 96 "commit_to_activate_duration_estimate_ms", |
| 97 commit_to_activate_duration_estimate.AsListValueInMilliseconds() |
| 98 .release()); |
| 50 return TracedValue::FromValue(record_data.release()); | 99 return TracedValue::FromValue(record_data.release()); |
| 51 } | 100 } |
| 52 | 101 |
| 53 void ImplThreadRenderingStats::Add(const ImplThreadRenderingStats& other) { | 102 void ImplThreadRenderingStats::Add(const ImplThreadRenderingStats& other) { |
| 54 frame_count += other.frame_count; | 103 frame_count += other.frame_count; |
| 55 rasterize_time += other.rasterize_time; | 104 rasterize_time += other.rasterize_time; |
| 56 analysis_time += other.analysis_time; | 105 analysis_time += other.analysis_time; |
| 57 rasterized_pixel_count += other.rasterized_pixel_count; | 106 rasterized_pixel_count += other.rasterized_pixel_count; |
| 58 visible_content_area += other.visible_content_area; | 107 visible_content_area += other.visible_content_area; |
| 59 approximated_visible_content_area += other.approximated_visible_content_area; | 108 approximated_visible_content_area += other.approximated_visible_content_area; |
| 109 |
| 110 draw_duration.Add(other.draw_duration); |
| 111 draw_duration_estimate.Add(other.draw_duration_estimate); |
| 112 begin_main_frame_to_commit_duration.Add( |
| 113 other.begin_main_frame_to_commit_duration); |
| 114 begin_main_frame_to_commit_duration_estimate.Add( |
| 115 other.begin_main_frame_to_commit_duration_estimate); |
| 116 commit_to_activate_duration.Add(other.commit_to_activate_duration); |
| 117 commit_to_activate_duration_estimate.Add( |
| 118 other.commit_to_activate_duration_estimate); |
| 60 } | 119 } |
| 61 | 120 |
| 62 void RenderingStats::Add(const RenderingStats& other) { | 121 void RenderingStats::Add(const RenderingStats& other) { |
| 63 main_stats.Add(other.main_stats); | 122 main_stats.Add(other.main_stats); |
| 64 impl_stats.Add(other.impl_stats); | 123 impl_stats.Add(other.impl_stats); |
| 65 } | 124 } |
| 66 | 125 |
| 67 } // namespace cc | 126 } // namespace cc |
| OLD | NEW |