#include #include "svg.h" using namespace std; // Функция заголовка. void svg_begin(double width, double height) { cout << "\n"; cout << "\n"; } // Функция окончания. void svg_end() { cout << "\n"; } // Функция вывода строки. void svg_text(double left, double baseline, string text) { cout << "" << text << ""; } // Функция вывода прямоугольника. void svg_rect(double x, double y, double width, double height, string stroke, string fill) { cout << ""; } // Создание гистограммы на основании корзин в формате SVG. void show_histogram_svg(const vector& bins) { // Необходимые константы. const auto IMAGE_WIDTH = 400; const auto IMAGE_HEIGHT = 300; const auto TEXT_LEFT = 20; const auto TEXT_BASELINE = 20; const auto TEXT_WIDTH = 50; const auto BIN_HEIGHT = 30; // const auto BLOCK_WIDTH = 10 size_t max_bins = bins[0]; svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT); // Поиск максимальной корзины. for (size_t x: bins) if (x > max_bins) max_bins = x; // Проверка максимального значения и создание гистограммы. if (max_bins == 0) { string message = "The count of numbers or columns is zero."; svg_text(TEXT_LEFT, TEXT_BASELINE, message); } else { const auto BLOCK_WIDTH = (IMAGE_WIDTH - TEXT_WIDTH)/max_bins; double top = 0; for (size_t bin : bins) { const double bin_width = BLOCK_WIDTH * bin; svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bin)); svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT); top += BIN_HEIGHT; } } svg_end(); }