MeshLib C++ Docs
Loading...
Searching...
No Matches
MRPalette.h
Go to the documentation of this file.
1#pragma once
2
3#include "MRViewerFwd.h"
4#include "MRMesh/MRVector4.h"
6#include "MRMesh/MRColor.h"
7#include "MRMesh/MRExpected.h"
8#include "MRViewer/MRImGui.h"
9#include <algorithm>
10#include <filesystem>
11
12namespace Json{ class Value; }
13
14namespace MR
15{
16
25{
26public:
28 MRVIEWER_API static const std::vector<Color> DefaultColors;
29 [[nodiscard]] static const std::vector<Color> & BlueGreenRedColors() { return DefaultColors; }
30
32 [[nodiscard]] MRVIEWER_API static const std::vector<Color> & GreenRedColors();
33
34 MRVIEWER_API Palette( const std::vector<Color>& colors );
41 MRVIEWER_API void setBaseColors( const std::vector<Color>& colors );
46 MRVIEWER_API void setRangeMinMax( float min, float max );
52 MRVIEWER_API void setRangeMinMaxNegPos( float minNeg, float maxNeg, float minPos, float maxPos );
53
54 // set number of different colors for discrete palette
55 MRVIEWER_API void setDiscretizationNumber( int discretization );
56 // set palette type (linear / discrete)
57 MRVIEWER_API void setFilterType( FilterType type );
58
63 MRVIEWER_API void draw( const std::string& windowName, const ImVec2& pose, const ImVec2& size, bool onlyTopHalf = false );
64
65 // structure for label
66 struct MRVIEWER_CLASS Label
67 {
68 float value = 0.f; // label position according normal scale (from Min to Max)
69 std::string text; // label text
70
71 Label() = default;
72 MRVIEWER_API Label( float val, std::string text );
73 };
74 // reset labels to standard view
75 MRVIEWER_API void resetLabels();
76 // set labels manually
77 MRVIEWER_API void setCustomLabels( const std::vector<Label>& labels );
78 // set labels visible
79 MRVIEWER_API void setLabelsVisible( bool visible );
80
81
82 // Setup palette data from JsonValue
83 // @return return true if loading successful
84 MRVIEWER_API bool loadFromJson( const Json::Value& root );
85 // Serialize this palette data to JsonValue
86 MRVIEWER_API void saveCurrentToJson( Json::Value& root ) const;
87
88
93 MRVIEWER_API Color getColor( float relativeValue ) const;
95 Color getInvalidColor() const { return Color::gray(); }
96
100 MRVIEWER_API VertColors getVertColors( const VertScalars& values, const VertBitSet& region, const VertBitSet* valids ) const;
101
102 const MeshTexture& getTexture() const { return texture_; };
103
104 // get relative position in [0,1], where 0 is for minimum and 1 is for maximum
105 MRVIEWER_API float getRelativePos( float val ) const;
106
109 UVCoord getUVcoord( float val, bool valid = true ) const
110 {
111 return {
112 ( texEnd_ - texStart_ ) * getRelativePos( val ) + texStart_,
113 valid ? 0.25f : 0.75f
114 };
115 }
116
120 MRVIEWER_API VertUVCoords getUVcoords( const VertScalars & values, const VertBitSet & region, const VertPredicate & valids = {} ) const;
121 MRVIEWER_API VertUVCoords getUVcoords( const VertScalars & values, const VertBitSet & region, const VertBitSet * valids ) const;
122
123 // base parameters of palette
125 {
126 std::vector<float> ranges = { 0.f, 1.f }; // range limits for palette
127 std::vector<Color> baseColors; // palette base colors (need for calculate real colors according discretization)
128 int discretization = 7; // number of different colors for discrete palette
129 };
130
131 [[nodiscard]] const Parameters& getParameters() const { return parameters_; }
132
134 [[nodiscard]] float getRangeMin() const { return parameters_.ranges.front(); }
135
137 [[nodiscard]] float getRangeMax() const { return parameters_.ranges.back(); }
138
140 [[nodiscard]] float getRangeSq() const { return std::max( sqr( getRangeMin() ), sqr( getRangeMax() ) ); }
141
142 // returns formated string for this value of palette
143 MRVIEWER_API std::string getStringValue( float value );
144 // returns maximal label count
145 MRVIEWER_API int getMaxLabelCount();
146 // sets maximal label count
147 MRVIEWER_API void setMaxLabelCount( int val );
148
149private:
150 void setRangeLimits_( const std::vector<float>& ranges );
151
152 void updateDiscretizatedColors_();
153 Color getBaseColor_( float val );
154
155
156 // fill labels with equal distance between
157 void setUniformLabels_();
158 // first label is equal to min value, last - to the max val
159 // don't use with MinMaxNegPos mode
160 void setZeroCentredLabels_();
161
162 void updateCustomLabels_();
163
164 void sortLabels_();
165
166 std::vector<Label> customLabels_;
167 std::vector<Label> labels_;
168 bool showLabels_ = false;
169
170 // stores OpenGL textures. Change useDiscrete_ to switch between them
171 MeshTexture texture_;
172
173 // texture positions of min and max values
174 float texStart_ = 0, texEnd_ = 1;
175
176 Parameters parameters_;
177
178 bool isWindowOpen_ = false;
179
180 bool useCustomLabels_ = false;
181
182 int maxLabelCount_ = 0;
183
184 float prevMaxLabelWidth_ = 0.0f;
185
186 static void resizeCallback_( ImGuiSizeCallbackData* data );
187};
188
191{
192public:
194 MRVIEWER_API static const std::vector<std::string>& getPresetNames();
197 MRVIEWER_API static bool loadPreset( const std::string& name, Palette& palette );
199 MRVIEWER_API static Expected<void> savePreset( const std::string& name, const Palette& palette );
201 MRVIEWER_API static std::filesystem::path getPalettePresetsFolder();
202private:
204 ~PalettePresets() = default;
205
206 std::vector<std::string> names_;
207
208 void update_();
209
210 static PalettePresets& instance_();
211};
212
213}
Class to save and load user palette presets.
Definition MRPalette.h:191
static MRVIEWER_API Expected< void > savePreset(const std::string &name, const Palette &palette)
saves given palette to preset with given name
static MRVIEWER_API std::filesystem::path getPalettePresetsFolder()
returns path to presets folder
static MRVIEWER_API bool loadPreset(const std::string &name, Palette &palette)
static MRVIEWER_API const std::vector< std::string > & getPresetNames()
gets names of existing presets
Class to hold one dimension texture with value to UV mapping.
Definition MRPalette.h:25
MRVIEWER_API float getRelativePos(float val) const
MRVIEWER_API VertColors getVertColors(const VertScalars &values, const VertBitSet &region, const VertBitSet *valids) const
MRVIEWER_API void draw(const std::string &windowName, const ImVec2 &pose, const ImVec2 &size, bool onlyTopHalf=false)
float getRangeSq() const
returns minimum squared value, not smaller than all squared values of palette's range
Definition MRPalette.h:140
MRVIEWER_API int getMaxLabelCount()
const MeshTexture & getTexture() const
Definition MRPalette.h:102
MRVIEWER_API Palette(const std::vector< Color > &colors)
MRVIEWER_API bool loadFromJson(const Json::Value &root)
MRVIEWER_API void setFilterType(FilterType type)
const Parameters & getParameters() const
Definition MRPalette.h:131
MRVIEWER_API std::string getStringValue(float value)
static MRVIEWER_API const std::vector< Color > & GreenRedColors()
simpler palette colors: from green to red
MRVIEWER_API void setCustomLabels(const std::vector< Label > &labels)
float getRangeMin() const
returns minimum value in the palette's range
Definition MRPalette.h:134
MRVIEWER_API void setMaxLabelCount(int val)
MRVIEWER_API VertUVCoords getUVcoords(const VertScalars &values, const VertBitSet &region, const VertBitSet *valids) const
MRVIEWER_API void saveCurrentToJson(Json::Value &root) const
MRVIEWER_API void setRangeMinMax(float min, float max)
set range limits for palette (need for find color by value) all palette colors are evenly distributed...
MRVIEWER_API VertUVCoords getUVcoords(const VertScalars &values, const VertBitSet &region, const VertPredicate &valids={}) const
MRVIEWER_API void setDiscretizationNumber(int discretization)
MRVIEWER_API Color getColor(float relativeValue) const
MRVIEWER_API void setRangeMinMaxNegPos(float minNeg, float maxNeg, float minPos, float maxPos)
set range limits for palette (need for find color by value) two half palette colors are evenly distri...
static MRVIEWER_API const std::vector< Color > DefaultColors
preset palette colors: from blue via green to red
Definition MRPalette.h:28
MRVIEWER_API void resetLabels()
float getRangeMax() const
returns maximum value in the palette's range
Definition MRPalette.h:137
static const std::vector< Color > & BlueGreenRedColors()
Definition MRPalette.h:29
UVCoord getUVcoord(float val, bool valid=true) const
Definition MRPalette.h:109
MRVIEWER_API void setLabelsVisible(bool visible)
Color getInvalidColor() const
return invalid color
Definition MRPalette.h:95
MRVIEWER_API void setBaseColors(const std::vector< Color > &colors)
Set base palette colors colors.size() should be more or equal 2 for discrete palette using vector of ...
constexpr T sqr(T x) noexcept
squared value
Definition MRMesh/MRMeshFwd.h:666
ImVec2 size(const ViewportRectangle &rect)
Definition MRViewport.h:29
FilterType
Definition MRMesh/MRMeshFwd.h:644
tl::expected< T, E > Expected
Definition MRExpected.h:59
Vector2f UVCoord
Definition MRMesh/MRMeshFwd.h:435
Definition MRMesh/MRColor.h:9
static constexpr Color gray() noexcept
Definition MRMesh/MRColor.h:29
Definition MRMeshTexture.h:13
Definition MRPalette.h:67
MRVIEWER_API Label(float val, std::string text)
std::string text
Definition MRPalette.h:69
Definition MRPalette.h:125
std::vector< Color > baseColors
Definition MRPalette.h:127
int discretization
Definition MRPalette.h:128
std::vector< float > ranges
Definition MRPalette.h:126