blob: e6e1adc703313c50b8e3dd4380fb3aaee3fc610c [file] [log] [blame]
tereliusb246a292016-08-23 18:15:25 -07001/*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#include "webrtc/tools/event_log_visualizer/plot_protobuf.h"
12
13#include <memory>
14
15namespace webrtc {
16namespace plotting {
17
18ProtobufPlot::ProtobufPlot() {}
19
20ProtobufPlot::~ProtobufPlot() {}
21
22void ProtobufPlot::Draw() {}
23
skvladf581eb72016-09-07 11:15:37 -070024void ProtobufPlot::ExportProtobuf(webrtc::analytics::Chart* chart) {
tereliusb246a292016-08-23 18:15:25 -070025 for (size_t i = 0; i < series_list_.size(); i++) {
skvladf581eb72016-09-07 11:15:37 -070026 webrtc::analytics::DataSet* data_set = chart->add_data_sets();
tereliusb246a292016-08-23 18:15:25 -070027 for (const auto& point : series_list_[i].points) {
skvladf581eb72016-09-07 11:15:37 -070028 data_set->add_x_values(point.x);
tereliusb246a292016-08-23 18:15:25 -070029 }
30 for (const auto& point : series_list_[i].points) {
skvladf581eb72016-09-07 11:15:37 -070031 data_set->add_y_values(point.y);
tereliusb246a292016-08-23 18:15:25 -070032 }
33
34 if (series_list_[i].style == BAR_GRAPH) {
skvladf581eb72016-09-07 11:15:37 -070035 data_set->set_style(webrtc::analytics::ChartStyle::BAR_CHART);
tereliusb246a292016-08-23 18:15:25 -070036 } else if (series_list_[i].style == LINE_GRAPH) {
skvladf581eb72016-09-07 11:15:37 -070037 data_set->set_style(webrtc::analytics::ChartStyle::LINE_CHART);
tereliusb246a292016-08-23 18:15:25 -070038 } else if (series_list_[i].style == LINE_DOT_GRAPH) {
skvladf581eb72016-09-07 11:15:37 -070039 data_set->set_style(webrtc::analytics::ChartStyle::LINE_CHART);
40 data_set->set_highlight_points(true);
tereliusb246a292016-08-23 18:15:25 -070041 } else {
skvladf581eb72016-09-07 11:15:37 -070042 data_set->set_style(webrtc::analytics::ChartStyle::UNDEFINED);
tereliusb246a292016-08-23 18:15:25 -070043 }
44
45 data_set->set_label(series_list_[i].label);
46 }
47
skvladf581eb72016-09-07 11:15:37 -070048 chart->set_xaxis_min(xaxis_min_);
49 chart->set_xaxis_max(xaxis_max_);
50 chart->set_yaxis_min(yaxis_min_);
51 chart->set_yaxis_max(yaxis_max_);
52 chart->set_xaxis_label(xaxis_label_);
53 chart->set_yaxis_label(yaxis_label_);
54 chart->set_title(title_);
tereliusb246a292016-08-23 18:15:25 -070055}
56
57ProtobufPlotCollection::ProtobufPlotCollection() {}
58
59ProtobufPlotCollection::~ProtobufPlotCollection() {}
60
61void ProtobufPlotCollection::Draw() {}
62
63void ProtobufPlotCollection::ExportProtobuf(
skvladf581eb72016-09-07 11:15:37 -070064 webrtc::analytics::ChartCollection* collection) {
tereliusb246a292016-08-23 18:15:25 -070065 for (const auto& plot : plots_) {
66 // TODO(terelius): Ensure that there is no way to insert plots other than
67 // ProtobufPlots in a ProtobufPlotCollection. Needed to safely static_cast
68 // here.
skvladf581eb72016-09-07 11:15:37 -070069 webrtc::analytics::Chart* protobuf_representation
70 = collection->add_charts();
tereliusb246a292016-08-23 18:15:25 -070071 static_cast<ProtobufPlot*>(plot.get())
72 ->ExportProtobuf(protobuf_representation);
73 }
74}
75
76Plot* ProtobufPlotCollection::AppendNewPlot() {
77 Plot* plot = new ProtobufPlot();
78 plots_.push_back(std::unique_ptr<Plot>(plot));
79 return plot;
80}
81
82} // namespace plotting
83} // namespace webrtc