From f1d40277ae855d71f4276caf2b65e4f716a13f78 Mon Sep 17 00:00:00 2001 From: "Artyom (StepanovAV)" Date: Sun, 21 Apr 2024 00:17:53 +0300 Subject: [PATCH] =?UTF-8?q?code:=20=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=20=D0=BA=D0=BE=D0=B4=20=D0=BF=D0=B5=D1=80=D1=81?= =?UTF-8?q?=D0=BE=D0=BD=D0=B0=D0=BB=D1=8C=D0=BD=D0=BE=D0=B3=D0=BE=20=D0=B2?= =?UTF-8?q?=D0=B0=D1=80=D0=B8=D0=B0=D0=BD=D1=82=D0=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- svg.cpp | 28 ++++++++++++++++++++++++---- 1 file changed, 24 insertions(+), 4 deletions(-) diff --git a/svg.cpp b/svg.cpp index 60b1cfc..026d4ec 100644 --- a/svg.cpp +++ b/svg.cpp @@ -20,15 +20,34 @@ svg_end() { } void -svg_text(double left, double baseline, string text) { - cout << ""<< text << ""; +svg_text(double left, double baseline, string style, string text) { + cout << "" << text << ""; } -void svg_rect(double x, double y, double width, double height, +void +svg_rect(double x, double y, double width, double height, string stroke = "black", string fill = "orange"){ cout << ""; } +string +styled_text_func (){ + string text_style; + cerr << "Do you want to use any text style? (Yes/No)" << endl; + cin >> text_style; + if (text_style == "No") { + text_style = "none"; + } + else { + cerr << "Which text style do you want to use?" << endl; + cin >> text_style; + while ((text_style != "none") && (text_style != "underline") && (text_style != "overline") && (text_style != "line-through")){ + cerr << "You entered the wrong style name. Try again." << endl; + cin >> text_style; + } + } + return text_style; +} void show_histogram_svg(const vector& bins) { @@ -46,9 +65,10 @@ show_histogram_svg(const vector& bins) { maxbin = bin; } } + string text_style = styled_text_func(); for (size_t bin : bins) { double bin_width = (IMAGE_WIDTH - TEXT_WIDTH) * ( bin / maxbin ); - svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bin)); + svg_text(TEXT_LEFT, top + TEXT_BASELINE, text_style, to_string(bin)); svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT); top += BIN_HEIGHT; }