#include "svg.h"
using namespace std;
void
svg_begin(double width, double height){
cout << "\n";
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 = "black" , string fill = "balck"){
cout << "";
}
void
show_histogram_svg(const vector& bins, const std::vector& borders, size_t bin_count, string filling) {
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;
svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT);
vector colors = {"crimson", "darkorange", "gold", "lime", "aqua", "dodgerblue", "mediumpurple"};
size_t max_bin = *max_element(bins.begin(), bins.end());
size_t number_of_blocks;
double top = 0;
size_t paint_swicher = 0;
string color;
size_t border = 0;
for (size_t bin: bins){
if (filling != "base"){
color = filling;
}
else{
color = colors[paint_swicher];
}
number_of_blocks = bin;
if ((max_bin * BLOCK_WIDTH) > (IMAGE_WIDTH - TEXT_WIDTH)){
number_of_blocks = ((IMAGE_WIDTH - TEXT_WIDTH)/10) * (static_cast(bin) / max_bin);
}
const double bin_width = BLOCK_WIDTH * number_of_blocks;
svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bin));
svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT, "black", color);
paint_swicher += 1;
if (paint_swicher > 6){
paint_swicher = 0;
}
if (border < bin_count - 1){
top += BIN_HEIGHT;
svg_text(TEXT_LEFT / 2, top + TEXT_BASELINE , to_string(borders[border]));
border += 1;
top += BIN_HEIGHT;
}
}
svg_end();
}