2023-05-24 12:38:22 +00:00
|
|
|
/*
|
|
|
|
This file is part of Telegram Desktop,
|
|
|
|
the official desktop application for the Telegram messaging service.
|
|
|
|
|
|
|
|
For license and copyright information please follow this link:
|
|
|
|
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
|
|
|
*/
|
|
|
|
#include "statistics/chart_horizontal_lines_data.h"
|
|
|
|
|
|
|
|
#include "lang/lang_tag.h"
|
|
|
|
|
|
|
|
namespace Statistic {
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
constexpr auto kMinLines = int(2);
|
|
|
|
constexpr auto kMaxLines = int(6);
|
|
|
|
constexpr auto kStep = 5.;
|
|
|
|
|
|
|
|
[[nodiscard]] int Round(int maxValue) {
|
|
|
|
const auto k = int(maxValue / kStep);
|
|
|
|
return (k % 10 == 0) ? maxValue : ((maxValue / 10 + 1) * 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
ChartHorizontalLinesData::ChartHorizontalLinesData(
|
|
|
|
int newMaxHeight,
|
|
|
|
int newMinHeight,
|
|
|
|
bool useMinHeight) {
|
|
|
|
if (!useMinHeight) {
|
|
|
|
const auto v = (newMaxHeight > 100)
|
|
|
|
? Round(newMaxHeight)
|
|
|
|
: newMaxHeight;
|
|
|
|
|
|
|
|
const auto step = std::max(1, int(std::ceil(v / kStep)));
|
|
|
|
|
|
|
|
auto n = kMaxLines;
|
|
|
|
if (v < kMaxLines) {
|
|
|
|
n = std::max(2, v + 1);
|
|
|
|
} else if (v / 2 < kMaxLines) {
|
|
|
|
n = v / 2 + 1;
|
|
|
|
if (v % 2 != 0) {
|
|
|
|
n++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
lines.resize(n);
|
|
|
|
|
|
|
|
for (auto i = 1; i < n; i++) {
|
|
|
|
auto &line = lines[i];
|
|
|
|
line.absoluteValue = i * step;
|
|
|
|
line.caption = Lang::FormatCountToShort(
|
|
|
|
line.absoluteValue).string;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
auto n = int(0);
|
|
|
|
const auto diff = newMaxHeight - newMinHeight;
|
|
|
|
auto step = 0.;
|
|
|
|
if (diff == 0) {
|
|
|
|
newMinHeight--;
|
|
|
|
n = kMaxLines / 2;
|
|
|
|
step = 1.;
|
|
|
|
} else if (diff < kMaxLines) {
|
|
|
|
n = std::max(kMinLines, diff + 1);
|
|
|
|
step = 1.;
|
|
|
|
} else if (diff / 2 < kMaxLines) {
|
|
|
|
n = diff / 2 + diff % 2 + 1;
|
|
|
|
step = 2.;
|
|
|
|
} else {
|
|
|
|
step = (newMaxHeight - newMinHeight) / kStep;
|
|
|
|
if (step <= 0) {
|
|
|
|
step = 1;
|
|
|
|
n = std::max(kMinLines, newMaxHeight - newMinHeight + 1);
|
|
|
|
} else {
|
|
|
|
n = 6;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
lines.resize(n);
|
|
|
|
const auto diffAbsoluteValue = int((n - 1) * step);
|
|
|
|
for (auto i = 0; i < n; i++) {
|
|
|
|
auto &line = lines[i];
|
|
|
|
const auto value = int(i * step);
|
|
|
|
line.absoluteValue = newMinHeight + value;
|
2023-06-09 14:16:58 +00:00
|
|
|
line.relativeValue = 1. - value / float64(diffAbsoluteValue);
|
2023-05-24 12:38:22 +00:00
|
|
|
line.caption = (line.absoluteValue >= 10'000)
|
|
|
|
? Lang::FormatCountToShort(line.absoluteValue).string
|
|
|
|
: QString("%L1").arg(line.absoluteValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-09 14:16:58 +00:00
|
|
|
void ChartHorizontalLinesData::computeRelative(
|
|
|
|
int newMaxHeight,
|
|
|
|
int newMinHeight) {
|
|
|
|
for (auto &line : lines) {
|
|
|
|
line.relativeValue = 1.
|
|
|
|
- ((line.absoluteValue - newMinHeight)
|
|
|
|
/ (newMaxHeight - newMinHeight));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-24 12:38:22 +00:00
|
|
|
int ChartHorizontalLinesData::LookupHeight(int maxValue) {
|
|
|
|
const auto v = (maxValue > 100) ? Round(maxValue) : maxValue;
|
|
|
|
|
|
|
|
const auto step = int(std::ceil(v / kStep));
|
|
|
|
return step * kStep;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace Statistic
|