1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
#pragma once
#include <mbgl/style/property_value.hpp>
#include <mbgl/renderer/property_evaluation_parameters.hpp>
#include <mbgl/renderer/possibly_evaluated_property_value.hpp>
#include <mbgl/renderer/cross_faded_property_evaluator.hpp>
namespace mbgl {
template <typename T>
class DataDrivenPropertyEvaluator {
public:
using ResultType = PossiblyEvaluatedPropertyValue<T>;
DataDrivenPropertyEvaluator(const PropertyEvaluationParameters& parameters_, T defaultValue_)
: parameters(parameters_),
defaultValue(std::move(defaultValue_)) {}
ResultType operator()(const style::Undefined&) const {
return ResultType(defaultValue);
}
ResultType operator()(const T& constant) const {
return ResultType(constant);
}
ResultType operator()(const style::PropertyExpression<T>& expression) const {
if (!expression.isFeatureConstant()) {
auto returnExpression = expression;
returnExpression.useIntegerZoom = parameters.useIntegerZoom;
return ResultType(returnExpression);
} else if (!parameters.useIntegerZoom) {
return ResultType(expression.evaluate(parameters.z));
} else {
return ResultType(expression.evaluate(floor(parameters.z)));
}
}
private:
const PropertyEvaluationParameters& parameters;
T defaultValue;
};
template <typename T>
class DataDrivenPropertyEvaluator<Faded<T>> {
public:
using ResultType = PossiblyEvaluatedPropertyValue<Faded<T>>;
DataDrivenPropertyEvaluator(const PropertyEvaluationParameters& parameters_, T defaultValue_)
: parameters(parameters_),
defaultValue(std::move(defaultValue_)) {}
ResultType operator()(const T& constant) const {
return ResultType(calculate(constant, constant, constant));
}
ResultType operator()(const style::Undefined& ) const {
return ResultType(calculate(defaultValue, defaultValue, defaultValue));
}
ResultType operator()(const style::PropertyExpression<T>& expression) const {
if (!expression.isFeatureConstant()) {
return ResultType(expression);
} else {
const T evaluated = expression.evaluate(floor(parameters.z));
return ResultType(calculate(evaluated, evaluated, evaluated));
}
}
private:
Faded<T> calculate(const T& min, const T& mid, const T& max) const {
const float z = parameters.z;
return z > parameters.zoomHistory.lastIntegerZoom
? Faded<T> { min, mid }
: Faded<T> { max, mid };
};
const PropertyEvaluationParameters& parameters;
T defaultValue;
};
} // namespace mbgl
|