From 983c07c251a7e12d90934af30a12af00db59e97d Mon Sep 17 00:00:00 2001 From: TarasovEE Date: Tue, 5 Aug 2025 21:30:43 +0300 Subject: [PATCH] =?UTF-8?q?source:=20=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D0=B5=20=D1=84=D1=83=D0=BD=D0=BA=D1=86=D0=B8?= =?UTF-8?q?=D0=B8=20=D1=81=D0=BE=D0=B7=D0=B4=D0=B0=D0=BD=D0=B8=D1=8F=20?= =?UTF-8?q?=D0=B3=D0=B8=D1=81=D1=82=D0=BE=D0=B3=D1=80=D0=B0=D0=BC=D0=BC?= =?UTF-8?q?=D1=8B=20=D0=B2=20SVG?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- histogram.cpp | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/histogram.cpp b/histogram.cpp index 7015072..4dbfc63 100644 --- a/histogram.cpp +++ b/histogram.cpp @@ -1,4 +1,5 @@ #include "histogram.h" +#include "svg.h" using namespace std; // Поиск максимума и минимума среди оценок. @@ -52,3 +53,38 @@ vector make_histogram(const vector& numbers, size_t bin_count) } return bins; } + +// Создание гистограммы на основании корзин в формате 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; + size_t max_bins = bins[0]; + +// Поиск максимальной корзины. + + for (size_t x: bins) + if (x > max_bins) + max_bins = x; + +// Выравнивание гистограммы по максимальному столбцу. + + const auto BLOCK_WIDTH = (IMAGE_WIDTH - TEXT_WIDTH)/max_bins;//BLOCK_WIDTH = 10 + + svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT); + 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(); +}