code: выполнено масштабирование для гистограммы формата SVG
Этот коммит содержится в:
2
Lab1.cbp
2
Lab1.cbp
@@ -38,6 +38,8 @@
|
|||||||
<Unit filename="histogram_internal.h" />
|
<Unit filename="histogram_internal.h" />
|
||||||
<Unit filename="main.cpp" />
|
<Unit filename="main.cpp" />
|
||||||
<Unit filename="main.h" />
|
<Unit filename="main.h" />
|
||||||
|
<Unit filename="svg.cpp" />
|
||||||
|
<Unit filename="svg.h" />
|
||||||
<Unit filename="text.cpp" />
|
<Unit filename="text.cpp" />
|
||||||
<Unit filename="text.h" />
|
<Unit filename="text.h" />
|
||||||
<Extensions />
|
<Extensions />
|
||||||
|
|||||||
14
svg.cpp
14
svg.cpp
@@ -48,6 +48,20 @@ show_histogram_svg(const vector<size_t>& bins) {
|
|||||||
const auto TEXT_WIDTH = 50;
|
const auto TEXT_WIDTH = 50;
|
||||||
const auto BIN_HEIGHT = 30;
|
const auto BIN_HEIGHT = 30;
|
||||||
const auto BLOCK_WIDTH = 10;
|
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<double>(MAX_WIDTH) / (max_count * BLOCK_WIDTH);
|
||||||
|
if (scale_factor > 1) {
|
||||||
|
scale_factor = 1;
|
||||||
|
}
|
||||||
svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT);
|
svg_begin(IMAGE_WIDTH, IMAGE_HEIGHT);
|
||||||
double top = 0;
|
double top = 0;
|
||||||
for (size_t bin : bins) {
|
for (size_t bin : bins) {
|
||||||
|
|||||||
Ссылка в новой задаче
Block a user