15#include <libcamera/base/span.h>
51 void setScale(
const float scale) { scale_ = scale; }
52 float effectiveScale()
const {
return (effectiveScaleX_ + effectiveScaleY_) * 0.5; }
81 double rotation_ = 0.0;
83 double effectiveScaleX_;
84 double effectiveScaleY_;
85 Point effectiveOffset_;
89 std::array<double, 12> dewarpCoeffs_;
90 bool lensDewarpEnable_ =
true;
91 bool dewarpParamsValid_ =
false;
Helper class to compute dw100 vertex maps.
Definition converter_dw100_vertexmap.h:26
void setOutputSize(const Size &size)
Set the output size.
Definition converter_dw100_vertexmap.h:45
const Size & outputSize() const
Get the output size.
Definition converter_dw100_vertexmap.h:46
std::vector< uint32_t > getVertexMap()
Get the dw100 vertex map.
Definition converter_dw100_vertexmap.cpp:441
void setScalerCrop(const Rectangle &rect)
Set the requested scaler crop.
Definition converter_dw100_vertexmap.h:42
float effectiveScale() const
Get the effective scale.
Definition converter_dw100_vertexmap.h:52
void setOffset(const Point &offset)
Sets the offset to apply.
Definition converter_dw100_vertexmap.h:57
ScaleMode
The scale modes available for a vertex map.
Definition converter_dw100_vertexmap.h:28
@ Crop
Crop the input.
Definition converter_dw100_vertexmap.h:30
@ Fill
Scale the input to fill the output.
Definition converter_dw100_vertexmap.h:29
const Transform & transform() const
Get the transform.
Definition converter_dw100_vertexmap.h:49
void setTransform(const Transform &transform)
Sets the transform to apply.
Definition converter_dw100_vertexmap.h:48
void setMode(const ScaleMode mode)
Sets the scaling mode to apply.
Definition converter_dw100_vertexmap.h:60
void setRotation(const float rotation)
Sets the rotation to apply.
Definition converter_dw100_vertexmap.h:54
void setScale(const float scale)
Sets the scale to apply.
Definition converter_dw100_vertexmap.h:51
const Rectangle & effectiveScalerCrop() const
Get the effective scaler crop.
Definition converter_dw100_vertexmap.h:43
void setLensDewarpEnable(bool enable)
Enables or disables lens dewarping.
Definition converter_dw100_vertexmap.h:66
float rotation() const
Get the rotation.
Definition converter_dw100_vertexmap.h:55
bool dewarpParamsValid()
Returns if the dewarp parameters are valid.
Definition converter_dw100_vertexmap.h:64
int setDewarpParams(const Matrix< double, 3, 3 > &cm, const Span< const double > &coeffs)
Set the dewarp parameters.
Definition converter_dw100_vertexmap.cpp:580
bool lensDewarpEnable()
Returns if lens dewarping is enabled.
Definition converter_dw100_vertexmap.h:67
const Point & effectiveOffset() const
Get the effective offset.
Definition converter_dw100_vertexmap.h:58
void setInputSize(const Size &size)
Set the size of the input data.
Definition converter_dw100_vertexmap.h:34
void applyLimits()
Apply limits on scale and offset.
Definition converter_dw100_vertexmap.cpp:238
void setSensorCrop(const Rectangle &rect)
Set the crop rectangle that represents the input data.
Definition converter_dw100_vertexmap.h:40
ScaleMode mode() const
Get the scaling mode.
Definition converter_dw100_vertexmap.h:61
Matrix class.
Definition matrix.h:31
static constexpr Matrix identity()
Construct an identity matrix.
Definition matrix.h:49
Describe a point in two-dimensional space.
Definition geometry.h:19
Describe a rectangle's position and dimensions.
Definition geometry.h:247
Describe a two-dimensional size.
Definition geometry.h:51
Vector class.
Definition vector.h:35
Data structures related to geometric objects.
Top-level libcamera namespace.
Definition backtrace.h:17
Transform
Enum to represent a 2D plane transform.
Definition transform.h:14