PARZIVAL (BreganIM) 3 месяцев назад
Родитель c03705d9e6
Сommit 48636765b8

@ -1,20 +1,20 @@
#include "svg.h"
#include "svg.h"
#include <string>
using namespace std;
void svg_begin(double width, double height) {
cout << "<?xml version='1.0' encoding='UTF-8'?>\n";
cout << "<svg ";
cout << "width='" << width << "' ";
cout << "height='" << height << "' ";
cout << "viewBox='0 0 " << width << " " << height << "' ";
cout << "xmlns='http://www.w3.org/2000/svg'>\n";
cout << "<svg "
<< "width='" << width << "' "
<< "height='" << height << "' "
<< "viewBox='0 0 " << width << " " << height << "' "
<< "xmlns='http://www.w3.org/2000/svg'>\n";
}
void svg_end() {
cout << "</svg>\n";
}
void svg_text(double left, double baseline, const string& text) {
cout << "<text x='" << left
<< "' y='" << baseline
@ -23,48 +23,50 @@ void svg_text(double left, double baseline, const string& text) {
}
void svg_rect(double x, double y, double width, double height,
const string& stroke, const string& fill, double razb) {
const string& stroke, const string& fill) {
cout << "<rect x='" << x
<< "' y='" << y
<< "' width='" << width
<< "' height='" << height
<< "' stroke='" << stroke
<< "' fill='" << fill
<< "'tecushee znach:'" << razb
<< "' />\n";
}
void show_histogram_svg(const vector<size_t>& bins, const vector<double>& numbers, double razb) {
void show_histogram_svg(const std::vector<size_t>& bins, double bin_size, double min_val) {
const double IMAGE_WIDTH = 400;
const double IMAGE_HEIGHT = 300;
const double TEXT_LEFT = 20;
const double TEXT_BASELINE = 20;
const double TEXT_WIDTH = 50;
const double BIN_HEIGHT = 30;
const double BLOCK_WIDTH = 10;
const double VSPACE = BIN_HEIGHT + TEXT_BASELINE * 2 + 5;
svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT);
size_t max_count = 0;
for (size_t count : bins) {
if (count > max_count) {
max_count = count;
}
}
for (size_t c : bins)
if (c > max_count)
max_count = c;
double max_width = IMAGE_WIDTH - TEXT_WIDTH - 100;
for (size_t j = 0; j < bins.size(); ++j) {
size_t count = bins[j];
double y = j * VSPACE;
double max_width = IMAGE_WIDTH - TEXT_WIDTH;
double top = 0;
for (size_t count : bins) {
double bin_width;
double width;
if (max_count > 0) {
bin_width = static_cast<double>(count) / max_count * max_width;
width = static_cast<double>(count) / max_count * max_width;
}
else {
bin_width = 0.0;
width = 0.0;
}
svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(count));
svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT, "blue", "blue");
top += BIN_HEIGHT;
svg_text(TEXT_LEFT, y + TEXT_BASELINE, to_string(count));
svg_rect(TEXT_WIDTH, y, width, BIN_HEIGHT, "blue", "blue");
double boundary = min_val + bin_size * (j + 1);
svg_text(TEXT_WIDTH,y + BIN_HEIGHT + TEXT_BASELINE,to_string(boundary)
);
}
svg_end();

Загрузка…
Отмена
Сохранить