Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
92 строки
2.9 KiB
C++
92 строки
2.9 KiB
C++
#include <iostream>
|
|
#include "svg.h"
|
|
#include <vector>
|
|
#include <string>
|
|
|
|
void svg_begin(double width, double height)
|
|
{
|
|
std::cout << "<?xml version='1.0' encoding='UTF-8'?>\n";
|
|
std::cout << "<svg ";
|
|
std::cout << "width='" << width << "' ";
|
|
std::cout << "height='" << height << "' ";
|
|
std::cout << "viewBox='0 0 " << width << " " << height << "' ";
|
|
std::cout << "xmlns='http://www.w3.org/2000/svg'>\n";
|
|
}
|
|
|
|
void svg_end()
|
|
{
|
|
std::cout << "</svg>\n";
|
|
}
|
|
|
|
void svg_text(double left, double baseline, std::string text)
|
|
{
|
|
std::cout << "<text x='" << left << "' y='" << baseline << "'>" << text << "</text>";
|
|
}
|
|
|
|
void show_histogram_svg(const std::vector<size_t>& bins, const size_t length_dsh, const size_t length_invl)
|
|
{
|
|
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;
|
|
const auto MAX_AVAIL_WIDTH = IMAGE_WIDTH - TEXT_WIDTH - 20; // Äîñòóïíàÿ øèðèíà ñ îòñòóïîì
|
|
|
|
svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT);
|
|
|
|
// ìàêñèìàëüíîå çíà÷åíèå â bins
|
|
size_t max_bin = 0;
|
|
for (size_t bin : bins)
|
|
{
|
|
if (bin > max_bin) max_bin = bin;
|
|
}
|
|
|
|
std::string dash_pattern = std::to_string(length_dsh) + " " + std::to_string(length_invl);
|
|
|
|
if (max_bin * BLOCK_WIDTH > MAX_AVAIL_WIDTH)
|
|
{
|
|
// ìàñøòàáíûé êîýôôèöèåíò
|
|
double scale = 1.0;
|
|
scale = static_cast<double>(MAX_AVAIL_WIDTH) / (max_bin * BLOCK_WIDTH);
|
|
double top = 0;
|
|
for (size_t bin : bins)
|
|
{
|
|
const double bin_width = BLOCK_WIDTH * bin * scale;
|
|
|
|
svg_text(TEXT_LEFT, top + TEXT_BASELINE, std::to_string(bin));
|
|
svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT);
|
|
svg_line(0, top + BIN_HEIGHT, IMAGE_WIDTH, top + BIN_HEIGHT, dash_pattern);
|
|
top += BIN_HEIGHT;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
double top = 0;
|
|
for (size_t bin : bins)
|
|
{
|
|
const double bin_width = BLOCK_WIDTH * bin;
|
|
svg_text(TEXT_LEFT, top + TEXT_BASELINE, std::to_string(bin));
|
|
svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT);
|
|
svg_line(0, top + BIN_HEIGHT, IMAGE_WIDTH, top + BIN_HEIGHT, dash_pattern);
|
|
top += BIN_HEIGHT;
|
|
}
|
|
}
|
|
|
|
svg_end();
|
|
}
|
|
|
|
void svg_rect(double x, double y, double width, double height, std::string stroke, std::string fill)
|
|
{
|
|
std::cout << "<rect x='" << x << "' y='" << y << "' width='" << width << "' height='" << height << "' stroke='" << stroke << "' fill='" << fill << "' />";
|
|
}
|
|
|
|
|
|
|
|
//çàùèòà
|
|
void svg_line(double x1, double y1, double x2, double y2, const std::string stroke_dasharray){
|
|
std::cout << "<line x1='" << x1 << "' y1='" << y1 << "' x2='" << x2 << "' y2='" << y2
|
|
<< "' stroke='black' stroke-dasharray='" << stroke_dasharray << "' />\n";
|
|
}
|