38 #include <OpenMS/VISUAL/OpenMS_GUIConfig.h>
47 #include <QtGui/QColor>
96 void insert(
double position, QColor color);
138 OPENMS_PRECONDITION(pre_.size() != 0,
"MultiGradient::precalculatedColorIndex(double): Precalculation mode not activated!");
139 OPENMS_PRECONDITION(position >= pre_min_, (
String(
"MultiGradient::precalculatedColorIndex(double): position ") + position +
" out of specified range (" + pre_min_ +
"-" + (pre_min_ + pre_size_) +
")!").c_str());
141 Int index = (
Int)((position - pre_min_) / pre_size_ * pre_steps_);
143 return qBound( 0, index, (
Int)pre_.size() - 1 );
149 OPENMS_PRECONDITION(pre_.size() != 0,
"MultiGradient::precalculatedColorByIndex(Int): Precalculation mode not activated!");
150 OPENMS_PRECONDITION( index >= 0,
"MultiGradient::precalculatedColorByIndex(Int): negative indexes not allowed");
151 OPENMS_PRECONDITION( index < (
Int)pre_.size(), (
String(
"MultiGradient::indexedColor(Int): index ") + index +
" out of specified range (0-" + pre_.size() +
")!").c_str());
165 return precalculatedColorByIndex( precalculatedColorIndex( position ) );
A gradient of multiple colors and arbitrary distances between colors.
Definition: MultiGradient.h:68
static MultiGradient getDefaultGradientLinearIntensityMode()
Returns the default gradient for linear intensity mode.
MultiGradient & operator=(const MultiGradient &rhs)
Assignment operator.
static MultiGradient getDefaultGradientLogarithmicIntensityMode()
Returns the default gradient for logarithmic intensity mode.
void deactivatePrecalculationMode()
deactivates the precalculation of values ( and deletes the precalculated values)
std::string toString() const
convert to string representation
std::vector< QColor > pre_
Precalculated colors.
Definition: MultiGradient.h:207
Int precalculatedColorIndex(double position) const
index of color in precalculated table by position in gradient
Definition: MultiGradient.h:136
MultiGradient(const MultiGradient &multigradient)
Copy constructor.
bool exists(double position)
returns if a value for position position exists
Size precalculatedSize() const
size of precalculated colors table
Definition: MultiGradient.h:172
~MultiGradient()
Destructor.
std::map< double, QColor > pos_col_
Map of index and color.
Definition: MultiGradient.h:203
void insert(double position, QColor color)
sets or replaces the color at position position
UInt pre_steps_
Steps of the precalculated color range.
Definition: MultiGradient.h:213
bool remove(double position)
removes the color at position position
void fromString(const std::string &gradient)
Sets the gradient by string representation.
QColor color(UInt index)
returns the color of the index -th point
MultiGradient()
Constructor.
double pre_size_
Width of the precalculated color range.
Definition: MultiGradient.h:211
QColor precalculatedColorByIndex(Int index) const
precalculated color by its index in the table
Definition: MultiGradient.h:147
void activatePrecalculationMode(double min, double max, UInt steps)
activates the precalculation of values (only approximate results are given)
Size size() const
return the number of color points
double pre_min_
Minimum of the precalculated color range.
Definition: MultiGradient.h:209
QColor interpolatedColorAt(double position) const
Returns the color as position.
QColor precalculatedColorAt(double position) const
Returns a precalculated color.
Definition: MultiGradient.h:163
QColor interpolatedColorAt(double position, double min, double max) const
returns the color as position with the gradient stretched between min and max.
InterpolationMode interpolation_mode_
Current interpolation mode.
Definition: MultiGradient.h:205
UInt position(UInt index)
returns the position of the index -th point
InterpolationMode
Interpolation mode.
Definition: MultiGradient.h:78
@ IM_LINEAR
IM_LINEAR returns the linear interpolation (default).
Definition: MultiGradient.h:79
void setInterpolationMode(InterpolationMode mode)
sets the interpolation mode (default or stairs). Default is linear
InterpolationMode getInterpolationMode() const
returns the interpolation mode
A more convenient string class.
Definition: String.h:60
int Int
Signed integer type.
Definition: Types.h:102
unsigned int UInt
Unsigned integer type.
Definition: Types.h:94
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:127
#define OPENMS_PRECONDITION(condition, message)
Precondition macro.
Definition: openms/include/OpenMS/CONCEPT/Macros.h:120
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:48