diff --git a/svg.cpp b/svg.cpp
index df13906..f0b699d 100644
--- a/svg.cpp
+++ b/svg.cpp
@@ -4,14 +4,23 @@
#include "svg.h"
using namespace std;
+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_WIDTH = IMAGE_WIDTH - TEXT_WIDTH;
+
void
svg_text(double left, double baseline, string text) {
cout << "" << text << "";
}
void
-svg_rect(double x, double y, double width, double height) {
- cout << "\n";
+svg_rect(double x, double y, double width, double height, string stroke = "black", string fill = "aaaaaa") {
+ cout << "\n";
}
void
@@ -31,17 +40,24 @@ svg_end() {
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;
- const auto BLOCK_WIDTH = 10;
+ const auto MAX_WIDTH = IMAGE_WIDTH - TEXT_WIDTH;
+ size_t max_count = 0;
+ for (size_t x : bins) {
+ if (x > max_count) {
+ max_count = x;
+ }
+ }
+ if (max_count == 0) {
+ max_count = 1;
+ }
+ auto scale_factor = static_cast(MAX_WIDTH) / (max_count * BLOCK_WIDTH);
+ if (scale_factor > 1) {
+ scale_factor = 1;
+ }
svg_begin(400, 300);
double top = 0;
for (size_t bin : bins) {
- const double bin_width = BLOCK_WIDTH * bin;
+ double bin_width = BLOCK_WIDTH * bin * scale_factor;
svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bin));
svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT);
top += BIN_HEIGHT;