mirror of
https://github.com/jkriege2/JKQtPlotter.git
synced 2025-01-24 06:32:12 +08:00
3916 lines
163 KiB
C++
3916 lines
163 KiB
C++
/*
|
|
Copyright (c) 2008-2015 Jan W. Krieger (<jan@jkrieger.de>, <j.krieger@dkfz.de>) (DKFZ) & IWR, University of Heidelberg
|
|
|
|
|
|
|
|
This software is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Lesser General Public License (LGPL) as published by
|
|
the Free Software Foundation, either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Lesser General Public License (LGPL) for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License (LGPL)
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
|
|
/*
|
|
Name: jkqtpfastplotter.h
|
|
Copyright: (c) 2010
|
|
Author: Jan krieger <jan@jkrieger.de>, http://www.jkrieger.de/
|
|
*/
|
|
|
|
/**
|
|
* \defgroup jkqtfastplotter JKQTFastPlotter: Speed-Optimized Plotter class
|
|
*/
|
|
|
|
/** \file jkqtpfastplotter.h
|
|
* \ingroup jkqtfastplotter
|
|
*/
|
|
#ifndef JKQTFASTPLOTTER_H
|
|
#define JKQTFASTPLOTTER_H
|
|
|
|
#include "jkqtplottertools/jkqtp_imexport.h"
|
|
#include <QWidget>
|
|
#include <QVector>
|
|
#include <QSettings>
|
|
#include <QColor>
|
|
#include <QVector>
|
|
#include <QPair>
|
|
#include <QStringList>
|
|
#include <QIcon>
|
|
#include <cmath>
|
|
#include <iostream>
|
|
#include <QMutex>
|
|
#include <QGLWidget>
|
|
|
|
#include "jkqtplottertools/jkqtptools.h"
|
|
#ifdef DEBUG_TIMING
|
|
# include "jkqtplottertools/jkqtphighrestimer.h"
|
|
#endif
|
|
|
|
#define JKQTFASTPLOTTER_ABS_MIN_LINEWIDTH 0.05
|
|
// forward declaration
|
|
class JKQTFPPlot;
|
|
|
|
#ifndef JKQTFASTPLOTTER_NOOPENGL
|
|
# define JKQTFASTPLOTTER_BASEWIDGET QGLWidget
|
|
# define JKQTFASTPLOTTER_BASEWIDGET_CONSTRUCTOR(parent) QGLWidget(QGLFormat(QGL::StencilBuffer | QGL::AlphaChannel | QGL::Rgba), parent)
|
|
#else
|
|
# define JKQTFASTPLOTTER_BASEWIDGET QWidget
|
|
# define JKQTFASTPLOTTER_BASEWIDGET_CONSTRUCTOR(parent) QWidget(parent)
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*! \brief a speed optimized plotter class
|
|
\ingroup jkqtfastplotter
|
|
|
|
This plotter class is (in contrast to JKQTPlotter) optimized for speed. It allows to plot function graphs/data in
|
|
a simple manner. The focus of design was not on a nice output (athough this is not unimportant), but on the speed
|
|
of the output. So the class may be used to di quick plotting of data, i.e. in fast image sequence applications.
|
|
|
|
These measures were taken to increase speed:
|
|
- The coordinate system is drawn onto an internal image which is only updated, when the size of the widget
|
|
or a property of the coordinate system changes. When only the data changes, just the data plot has to be
|
|
updated.
|
|
- The class uses an internal buffer with the complete image, so a repaint does not always trigger a complete
|
|
repaint of all elements, but just measns painting the internal image to the screen. This also allows to
|
|
plot selections ... over the plot, without having to replot the plots.
|
|
- The definition of the coordinate system as well as the definition the system ticks ... is reduced to the absolute
|
|
minimum.
|
|
- The method set_doDrawing() allows to prevent replotting of the class contents, e.g. when you want to set
|
|
a multitude of parameters without triggering a replot every time.
|
|
.
|
|
|
|
The class supports these features:
|
|
- coordinate axes may be linear or logarithmic.
|
|
- ticks and tick labels are drawn by a simple algorithm: The user has to supply two values:
|
|
\c zeroTick is a tick value that exists in any case (i.e. 0) and \c tickDistance which contains the distance
|
|
between two ticks (only applicable to linear axes). Then the class starts to draw at zeroTick and move on to
|
|
\c zeroTick+tickDistance and \c zeroTick-tickDistance until \c min / \c max of the axis is reached. For logarithmic axes
|
|
the class uses \c zeroTick*10 and \c zeroTick/10
|
|
- plot may contain a grid (x and y grid may be switched on/off separately).
|
|
- plots are represented by descendents of JKQTFPPlot and the plotting code is completely
|
|
contained therein (and should be speed optimized).
|
|
- it is possible to keep a specified aspect ration
|
|
- it is possible to couple different plots in a way, that they are plottetd with the same width/height
|
|
both in pixel and world coordinates by using plotterSizesChanged() and synchronizeX() / synchronizeY().
|
|
.
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFastPlotter : public JKQTFASTPLOTTER_BASEWIDGET {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief indicates whether to do full repaint (system and data) at the next repaint (any of the repaint meothods) */
|
|
bool doFullRepaint;
|
|
/** \brief this stores the currently displayed coordinate system */
|
|
QImage systemImage;
|
|
/** \brief this stores the currently displayed plot */
|
|
QImage image;
|
|
|
|
/** \brief this can be used when drawing a zoom rectangle to store an unchanged
|
|
* copy of the currently displayed image.
|
|
*/
|
|
QImage oldImage;
|
|
|
|
/** \brief if \c false the plotting won't be performed (may be used to set more than one parameter without replot */
|
|
bool doDrawing;
|
|
|
|
/** \brief list of plots in this graph */
|
|
QVector<JKQTFPPlot*> plots;
|
|
|
|
|
|
|
|
/** \brief free space between widget left border and plot left border */
|
|
int plotBorderLeft;
|
|
/*! \brief default value for property plotBorderLeft.
|
|
\see plotBorderLeft for more information */
|
|
int def_plotBorderLeft;
|
|
/** \brief free space between widget bottom border and plot bottom border */
|
|
int plotBorderBottom;
|
|
/*! \brief default value for property plotBorderBottom.
|
|
\see plotBorderBottom for more information */
|
|
int def_plotBorderBottom;
|
|
/** \brief free space between widget right border and plot left border */
|
|
int plotBorderRight;
|
|
/*! \brief default value for property plotBorderRight.
|
|
\see plotBorderRight for more information */
|
|
int def_plotBorderRight;
|
|
/** \brief free space between widget top border and plot bottom border */
|
|
int plotBorderTop;
|
|
/*! \brief default value for property plotBorderTop.
|
|
\see plotBorderTop for more information */
|
|
int def_plotBorderTop;
|
|
|
|
/** \brief internally calculated: free space between widget left border and plot left border
|
|
*
|
|
* \note This is the actual border used for plotting, as it may be different from what the user supplied.
|
|
* Note also that this is at least as huge as the suer supplied border value!
|
|
*/
|
|
int internalPlotBorderLeft;
|
|
/** \brief internally calculated: free space between widget bottom border and plot bottom border
|
|
*
|
|
* \note This is the actual border used for plotting, as it may be different from what the user supplied.
|
|
* Note also that this is at least as huge as the suer supplied border value!
|
|
*/
|
|
int internalPlotBorderBottom;
|
|
/** \brief internally calculated: free space between widget right border and plot left border
|
|
*
|
|
* \note This is the actual border used for plotting, as it may be different from what the user supplied.
|
|
* Note also that this is at least as huge as the suer supplied border value!
|
|
*/
|
|
int internalPlotBorderRight;
|
|
/** \brief internally calculated: free space between widget top border and plot bottom border
|
|
*
|
|
* \note This is the actual border used for plotting, as it may be different from what the user supplied.
|
|
* Note also that this is at least as huge as the suer supplied border value!
|
|
*/
|
|
int internalPlotBorderTop;
|
|
|
|
/** \brief plot width in pixels inside the widget (calculated by calcPlotScaling() from plotBorderLeft, plotBorderRight and widgetWidth) */
|
|
int plotWidth;
|
|
/** \brief plot height in pixels inside the widget (calculated by calcPlotScaling() from plotBorderTop, plotBorderBottom and widgetHeight) */
|
|
int plotHeight;
|
|
|
|
/** \brief color of the coordinate system */
|
|
QColor systemColor;
|
|
/*! \brief default value for property systemColor.
|
|
\see systemColor for more information */
|
|
QColor def_systemColor;
|
|
/** \brief width of the coordinate (in pixel) */
|
|
double systemWidth;
|
|
/*! \brief default value for property systemWidth.
|
|
\see systemWidth for more information */
|
|
double def_systemWidth;
|
|
/** \brief color of the background*/
|
|
QColor backgroundColor;
|
|
/*! \brief default value for property backgroundColor.
|
|
\see backgroundColor for more information */
|
|
QColor def_backgroundColor;
|
|
/** \brief color of the plot's background
|
|
*
|
|
* \note the background is not drawn if this color is set to \c QColor(Qt::transparent) !
|
|
*/
|
|
QColor plotBackgroundColor;
|
|
/*! \brief default value for property plotBackgroundColor.
|
|
\see plotBackgroundColor for more information */
|
|
QColor def_plotBackgroundColor;
|
|
/** \brief indicates whether to draw a system box */
|
|
bool drawSystemBox;
|
|
/*! \brief default value for property drawSystemBox.
|
|
\see drawSystemBox for more information */
|
|
bool def_drawSystemBox;
|
|
/** \brief indicates whether to draw axes at x=0/y=0 */
|
|
bool drawZeroAxes;
|
|
/*! \brief default value for property drawZeroAxes.
|
|
\see drawZeroAxes for more information */
|
|
bool def_drawZeroAxes;
|
|
|
|
/** \brief indicates whether to draw a grid */
|
|
bool drawGrid;
|
|
/*! \brief default value for property drawGrid.
|
|
\see drawGrid for more information */
|
|
bool def_drawGrid;
|
|
/** \brief color of the coordinate grid */
|
|
QColor gridColor;
|
|
/*! \brief default value for property gridColor.
|
|
\see gridColor for more information */
|
|
QColor def_gridColor;
|
|
/** \brief style of the coordinate grid */
|
|
Qt::PenStyle gridStyle;
|
|
/*! \brief default value for property gridStyle.
|
|
\see gridStyle for more information */
|
|
Qt::PenStyle def_gridStyle;
|
|
/** \brief width of the coordinate grid (in pixel) */
|
|
double gridWidth;
|
|
/*! \brief default value for property gridWidth.
|
|
\see gridWidth for more information */
|
|
double def_gridWidth;
|
|
/** \brief font size (in points) of the axis labels */
|
|
double labelFontSize;
|
|
/*! \brief default value for property labelFontSize.
|
|
\see labelFontSize for more information */
|
|
double def_labelFontSize;
|
|
/** \brief font name of the axis labels */
|
|
QString labelFontName;
|
|
/*! \brief default value for property labelFontName.
|
|
\see labelFontName for more information */
|
|
QString def_labelFontName;
|
|
/** \brief font size (in points) of the tick labels */
|
|
double tickFontSize;
|
|
/*! \brief default value for property tickFontSize.
|
|
\see tickFontSize for more information */
|
|
double def_tickFontSize;
|
|
/** \brief font name of the tick labels */
|
|
QString tickFontName;
|
|
/*! \brief default value for property tickFontName.
|
|
\see tickFontName for more information */
|
|
QString def_tickFontName;
|
|
|
|
/** \brief length of an axis tick (pixels) */
|
|
double tickLength;
|
|
/*! \brief default value for property tickLength.
|
|
\see tickLength for more information */
|
|
double def_tickLength;
|
|
|
|
|
|
/** \brief minimum value of x axis */
|
|
double xMin;
|
|
/** \brief maximum value of x axis */
|
|
double xMax;
|
|
/** \brief minimum value of y axis */
|
|
double yMin;
|
|
/** \brief maximum value of y axis */
|
|
double yMax;
|
|
/** \brief is x axis logarithmic? */
|
|
bool xAxisLog;
|
|
/** \brief is x axis logarithmic? */
|
|
bool yAxisLog;
|
|
|
|
/** \brief width of plot on x axis (calculated internally) */
|
|
double xWidth;
|
|
/** \brief x axis scaling factor (calculated internally) */
|
|
double xScale;
|
|
/** \brief x axis offset (calculated internally) */
|
|
double xOffset;
|
|
/** \brief width of plot on y axis (calculated internally) */
|
|
double yWidth;
|
|
/** \brief y axis scaling factor (calculated internally) */
|
|
double yScale;
|
|
/** \brief y axis offset (calculated internally) */
|
|
double yOffset;
|
|
/** \brief a label position from which axis label plotting is started for the x axis */
|
|
double xZeroTick;
|
|
/** \brief a label position from which axis label plotting is started for the y axis */
|
|
double yZeroTick;
|
|
/** \brief distance between two labels on x axis */
|
|
double xTickDistance;
|
|
/** \brief distance between two labels on y axis */
|
|
double yTickDistance;
|
|
/** \brief label of x axis */
|
|
QString xAxisLabel;
|
|
/** \brief label of y axis */
|
|
QString yAxisLabel;
|
|
|
|
/** \brief plot y axis label */
|
|
bool yAxisLabelVisible;
|
|
/** \brief plot x axis label */
|
|
bool xAxisLabelVisible;
|
|
|
|
/** \brief synchronize x-axis settings to this plotter */
|
|
JKQTFastPlotter* synchronizeX;
|
|
/** \brief synchronize y-axis settings to this plotter */
|
|
JKQTFastPlotter* synchronizeY;
|
|
|
|
/** \brief aspect ration of the plot, only used when maintainAspectRation is \c true
|
|
*
|
|
* The aspect ratio is defined as \c width/height of the plot in pixels.
|
|
* So if you want to have a plot spanning \c x=0..20 and \c y=0..10 where each 1x1 square should be
|
|
* as wide as high you will have to set aspectRatio to \c 2 .
|
|
*
|
|
* \note Note that aspect ratios only make sense for linear-linear plots. This will be ignored
|
|
* if any one axis is logarithmic.
|
|
*/
|
|
double aspectRatio;
|
|
/** \brief indicates whether to maintain a specific aspect ratio */
|
|
bool maintainAspectRatio;
|
|
|
|
QPoint mouseDragStart;
|
|
QPoint mouseDragEnd;
|
|
bool dragging;
|
|
|
|
QPen dragShapePen;
|
|
bool dragLine;
|
|
|
|
QAction* actCopyImage;
|
|
|
|
/** \brief this simply paints the stored image to the widget's surface */
|
|
virtual void paintEvent(QPaintEvent *event) override;
|
|
|
|
/** \brief resizes the internal representation (image) of the graphs */
|
|
virtual void resizeEvent(QResizeEvent *event) override;
|
|
|
|
|
|
/** \brief event handler for a double click */
|
|
virtual void mouseDoubleClickEvent ( QMouseEvent * event ) override;
|
|
|
|
/** \brief event handler for a mouse move */
|
|
virtual void mouseMoveEvent ( QMouseEvent * event ) override;
|
|
|
|
/** \brief event handler for a mouse button press */
|
|
virtual void mousePressEvent ( QMouseEvent * event ) override;
|
|
|
|
/** \brief event handler for a mouse button is released */
|
|
virtual void mouseReleaseEvent(QMouseEvent* event) override;
|
|
|
|
/** \brief paint the coordinate system */
|
|
void plotSystem(QPainter& painter);
|
|
|
|
/** \brief paint the graphs */
|
|
void plotGraphs(QPainter& painter);
|
|
|
|
/** \brief recalculate the scaling of the plot */
|
|
void calcPlotScaling();
|
|
|
|
QSize minimumSizeHint() const;
|
|
|
|
/** \brief mutex to lock global widget repaint */
|
|
QMutex mutexRepaint;
|
|
|
|
/** \brief mutex to lock data repaint */
|
|
QMutex mutexRepaintData;
|
|
|
|
/** \brief mutex to lock system repaint */
|
|
QMutex mutexRepaintSystem;
|
|
|
|
public:
|
|
/** \brief class constructor */
|
|
JKQTFastPlotter(QWidget *parent = nullptr);
|
|
|
|
/** \brief set the properties of the x axis */
|
|
void setXRange(double min, double max, bool logarithmic=false);
|
|
|
|
/** \brief set the properties of the y axis */
|
|
void setYRange(double min, double max, bool logarithmic=false);
|
|
|
|
/** \brief set the properties of both axes */
|
|
void setXYRange(double xmin, double xmax, double ymin, double ymax, bool xlogarithmic=false, bool ylogarithmic=false);
|
|
|
|
/** \brief clear all plots in the graph
|
|
*
|
|
* \param remove if \c true the object will also be deleted from memory, not just from the list
|
|
*/
|
|
void clearPlots(bool remove=false);
|
|
/** \brief add a new graph */
|
|
void addPlot(JKQTFPPlot* g);
|
|
/** \brief return the internal number (0..N-1) of the given plot, or -1*/
|
|
int getPlotNum(JKQTFPPlot* g);
|
|
/** \brief remove given graph
|
|
*
|
|
* \param id specifies the graph to delete
|
|
* \param remove if \c true the object will also be deleted from memory, not just from the list
|
|
*/
|
|
void deletePlot(int id, bool remove=false);
|
|
/** \brief remove given graph
|
|
*
|
|
* \param g specifies the graph to delete
|
|
* \param remove if \c true the object will also be deleted from memory, not just from the list
|
|
*/
|
|
void deletePlot(JKQTFPPlot* g, bool remove=false);
|
|
|
|
|
|
/** \brief return x-pixel coordinate from x coordinate */
|
|
inline double x2p(double x) {
|
|
if (xAxisLog) {
|
|
if (x<0) return xOffset+log(xMin/10.0)/log(10.0)*xScale;
|
|
return xOffset+log(x)/log(10.0)*xScale;
|
|
} else {
|
|
return xOffset+x*xScale;
|
|
}
|
|
}
|
|
|
|
/** \brief return x coordinate coordinate from x-pixel */
|
|
inline double p2x(long x) {
|
|
if (xAxisLog) {
|
|
return exp(log(10.0)*((double)x-xOffset)/(xScale));
|
|
} else {
|
|
return ((double)x-xOffset)/(xScale);
|
|
}
|
|
}
|
|
|
|
/** \brief return y-pixel coordinate from y coordinate */
|
|
inline double y2p(double y) {
|
|
if (yAxisLog) {
|
|
if (y<0) return yOffset-log(yMin/10.0)/log(10.0)*yScale;
|
|
return yOffset-log(y)/log(10.0)*yScale;
|
|
} else {
|
|
return yOffset-y*yScale;
|
|
}
|
|
}
|
|
|
|
/** \brief return y coordinate coordinate from y-pixel */
|
|
inline double p2y(long y) {
|
|
if (yAxisLog) {
|
|
return exp(log(10.0)*((double)y-yOffset)/(-1.0*yScale));
|
|
} else {
|
|
return ((double)y-yOffset)/(-1.0*yScale);
|
|
}
|
|
}
|
|
|
|
/*! \brief sets the property dragShapePen to the specified \a __value.
|
|
\details Description of the parameter dragShapePen is: <CENTER>\copybrief dragShapePen.</CENTER>
|
|
\see dragShapePen for more information */
|
|
inline virtual void set_dragShapePen(const QPen & __value)
|
|
{
|
|
if (this->dragShapePen != __value) {
|
|
this->dragShapePen = __value;
|
|
update();
|
|
}
|
|
}
|
|
/*! \brief returns the property dragShapePen.
|
|
\details Description of the parameter dragShapePen is: <CENTER>\copybrief dragShapePen.</CENTER>
|
|
\see dragShapePen for more information */
|
|
inline virtual QPen get_dragShapePen() const
|
|
{
|
|
return this->dragShapePen;
|
|
}
|
|
/*! \brief sets the property dragLine to the specified \a __value.
|
|
\details Description of the parameter dragLine is: <CENTER>\copybrief dragLine.</CENTER>
|
|
\see dragLine for more information */
|
|
inline virtual void set_dragLine(bool __value)
|
|
{
|
|
if (this->dragLine != __value) {
|
|
this->dragLine = __value;
|
|
update();
|
|
}
|
|
}
|
|
/*! \brief returns the property dragLine.
|
|
\details Description of the parameter dragLine is: <CENTER>\copybrief dragLine.</CENTER>
|
|
\see dragLine for more information */
|
|
inline virtual bool get_dragLine() const
|
|
{
|
|
return this->dragLine;
|
|
}
|
|
|
|
/*! \brief sets the property plotBorderLeft to the specified \a __value.
|
|
\details Description of the parameter plotBorderLeft is: <CENTER>\copybrief plotBorderLeft.</CENTER>
|
|
\see plotBorderLeft for more information */
|
|
inline virtual void set_plotBorderLeft(int __value)
|
|
{
|
|
if (this->plotBorderLeft != __value) {
|
|
this->plotBorderLeft = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property plotBorderLeft.
|
|
\details Description of the parameter plotBorderLeft is: <CENTER>\copybrief plotBorderLeft.</CENTER>
|
|
\see plotBorderLeft for more information */
|
|
inline virtual int get_plotBorderLeft() const
|
|
{
|
|
return this->plotBorderLeft;
|
|
}
|
|
/*! \brief sets the property plotBorderBottom to the specified \a __value.
|
|
\details Description of the parameter plotBorderBottom is: <CENTER>\copybrief plotBorderBottom.</CENTER>
|
|
\see plotBorderBottom for more information */
|
|
inline virtual void set_plotBorderBottom(int __value)
|
|
{
|
|
if (this->plotBorderBottom != __value) {
|
|
this->plotBorderBottom = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property plotBorderBottom.
|
|
\details Description of the parameter plotBorderBottom is: <CENTER>\copybrief plotBorderBottom.</CENTER>
|
|
\see plotBorderBottom for more information */
|
|
inline virtual int get_plotBorderBottom() const
|
|
{
|
|
return this->plotBorderBottom;
|
|
}
|
|
/*! \brief sets the property plotBorderRight to the specified \a __value.
|
|
\details Description of the parameter plotBorderRight is: <CENTER>\copybrief plotBorderRight.</CENTER>
|
|
\see plotBorderRight for more information */
|
|
inline virtual void set_plotBorderRight(int __value)
|
|
{
|
|
if (this->plotBorderRight != __value) {
|
|
this->plotBorderRight = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property plotBorderRight.
|
|
\details Description of the parameter plotBorderRight is: <CENTER>\copybrief plotBorderRight.</CENTER>
|
|
\see plotBorderRight for more information */
|
|
inline virtual int get_plotBorderRight() const
|
|
{
|
|
return this->plotBorderRight;
|
|
}
|
|
/*! \brief sets the property plotBorderTop to the specified \a __value.
|
|
\details Description of the parameter plotBorderTop is: <CENTER>\copybrief plotBorderTop.</CENTER>
|
|
\see plotBorderTop for more information */
|
|
inline virtual void set_plotBorderTop(int __value)
|
|
{
|
|
if (this->plotBorderTop != __value) {
|
|
this->plotBorderTop = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property plotBorderTop.
|
|
\details Description of the parameter plotBorderTop is: <CENTER>\copybrief plotBorderTop.</CENTER>
|
|
\see plotBorderTop for more information */
|
|
inline virtual int get_plotBorderTop() const
|
|
{
|
|
return this->plotBorderTop;
|
|
}
|
|
/*! \brief returns the property plotWidth.
|
|
\details Description of the parameter plotWidth is: <CENTER>\copybrief plotWidth.</CENTER>.
|
|
\see plotWidth for more information */
|
|
inline int get_plotWidth() const {
|
|
return this->plotWidth;
|
|
}
|
|
/*! \brief returns the property plotHeight.
|
|
\details Description of the parameter plotHeight is: <CENTER>\copybrief plotHeight.</CENTER>.
|
|
\see plotHeight for more information */
|
|
inline int get_plotHeight() const {
|
|
return this->plotHeight;
|
|
}
|
|
/*! \brief sets the property doDrawing to the specified \a __value.
|
|
\details Description of the parameter doDrawing is: <CENTER>\copybrief doDrawing.</CENTER>
|
|
\see doDrawing for more information */
|
|
inline virtual void set_doDrawing(bool __value)
|
|
{
|
|
this->doDrawing = __value;
|
|
}
|
|
/*! \brief returns the property doDrawing.
|
|
\details Description of the parameter doDrawing is: <CENTER>\copybrief doDrawing.</CENTER>
|
|
\see doDrawing for more information */
|
|
inline virtual bool get_doDrawing() const
|
|
{
|
|
return this->doDrawing;
|
|
}
|
|
/*! \brief returns the property internalPlotBorderLeft.
|
|
\details Description of the parameter internalPlotBorderLeft is: <CENTER>\copybrief internalPlotBorderLeft.</CENTER>.
|
|
\see internalPlotBorderLeft for more information */
|
|
inline int get_internalPlotBorderLeft() const {
|
|
return this->internalPlotBorderLeft;
|
|
}
|
|
/*! \brief returns the property internalPlotBorderBottom.
|
|
\details Description of the parameter internalPlotBorderBottom is: <CENTER>\copybrief internalPlotBorderBottom.</CENTER>.
|
|
\see internalPlotBorderBottom for more information */
|
|
inline int get_internalPlotBorderBottom() const {
|
|
return this->internalPlotBorderBottom;
|
|
}
|
|
/*! \brief returns the property internalPlotBorderRight.
|
|
\details Description of the parameter internalPlotBorderRight is: <CENTER>\copybrief internalPlotBorderRight.</CENTER>.
|
|
\see internalPlotBorderRight for more information */
|
|
inline int get_internalPlotBorderRight() const {
|
|
return this->internalPlotBorderRight;
|
|
}
|
|
/*! \brief returns the property internalPlotBorderTop.
|
|
\details Description of the parameter internalPlotBorderTop is: <CENTER>\copybrief internalPlotBorderTop.</CENTER>.
|
|
\see internalPlotBorderTop for more information */
|
|
inline int get_internalPlotBorderTop() const {
|
|
return this->internalPlotBorderTop;
|
|
}
|
|
/*! \brief returns the property xMin.
|
|
\details Description of the parameter xMin is: <CENTER>\copybrief xMin.</CENTER>.
|
|
\see xMin for more information */
|
|
inline double get_xMin() const {
|
|
return this->xMin;
|
|
}
|
|
/*! \brief returns the property xMax.
|
|
\details Description of the parameter xMax is: <CENTER>\copybrief xMax.</CENTER>.
|
|
\see xMax for more information */
|
|
inline double get_xMax() const {
|
|
return this->xMax;
|
|
}
|
|
/*! \brief returns the property yMin.
|
|
\details Description of the parameter yMin is: <CENTER>\copybrief yMin.</CENTER>.
|
|
\see yMin for more information */
|
|
inline double get_yMin() const {
|
|
return this->yMin;
|
|
}
|
|
/*! \brief returns the property yMax.
|
|
\details Description of the parameter yMax is: <CENTER>\copybrief yMax.</CENTER>.
|
|
\see yMax for more information */
|
|
inline double get_yMax() const {
|
|
return this->yMax;
|
|
}
|
|
/*! \brief returns the property xAxisLog.
|
|
\details Description of the parameter xAxisLog is: <CENTER>\copybrief xAxisLog.</CENTER>.
|
|
\see xAxisLog for more information */
|
|
inline bool get_xAxisLog() const {
|
|
return this->xAxisLog;
|
|
}
|
|
/*! \brief returns the property yAxisLog.
|
|
\details Description of the parameter yAxisLog is: <CENTER>\copybrief yAxisLog.</CENTER>.
|
|
\see yAxisLog for more information */
|
|
inline bool get_yAxisLog() const {
|
|
return this->yAxisLog;
|
|
}
|
|
|
|
/*! \brief sets the property backgroundColor to the specified \a __value.
|
|
\details Description of the parameter backgroundColor is: <CENTER>\copybrief backgroundColor.</CENTER>
|
|
\see backgroundColor for more information */
|
|
inline virtual void set_backgroundColor(const QColor & __value)
|
|
{
|
|
if (this->backgroundColor != __value) {
|
|
this->backgroundColor = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property backgroundColor.
|
|
\details Description of the parameter backgroundColor is: <CENTER>\copybrief backgroundColor.</CENTER>
|
|
\see backgroundColor for more information */
|
|
inline virtual QColor get_backgroundColor() const
|
|
{
|
|
return this->backgroundColor;
|
|
}
|
|
/*! \brief sets the property plotBackgroundColor to the specified \a __value.
|
|
\details Description of the parameter plotBackgroundColor is: <CENTER>\copybrief plotBackgroundColor.</CENTER>
|
|
\see plotBackgroundColor for more information */
|
|
inline virtual void set_plotBackgroundColor(const QColor & __value)
|
|
{
|
|
if (this->plotBackgroundColor != __value) {
|
|
this->plotBackgroundColor = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property plotBackgroundColor.
|
|
\details Description of the parameter plotBackgroundColor is: <CENTER>\copybrief plotBackgroundColor.</CENTER>
|
|
\see plotBackgroundColor for more information */
|
|
inline virtual QColor get_plotBackgroundColor() const
|
|
{
|
|
return this->plotBackgroundColor;
|
|
}
|
|
/*! \brief sets the property drawGrid to the specified \a __value.
|
|
\details Description of the parameter drawGrid is: <CENTER>\copybrief drawGrid.</CENTER>
|
|
\see drawGrid for more information */
|
|
inline virtual void set_drawGrid(bool __value)
|
|
{
|
|
if (this->drawGrid != __value) {
|
|
this->drawGrid = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property drawGrid.
|
|
\details Description of the parameter drawGrid is: <CENTER>\copybrief drawGrid.</CENTER>
|
|
\see drawGrid for more information */
|
|
inline virtual bool get_drawGrid() const
|
|
{
|
|
return this->drawGrid;
|
|
}
|
|
/*! \brief sets the property gridColor to the specified \a __value.
|
|
\details Description of the parameter gridColor is: <CENTER>\copybrief gridColor.</CENTER>
|
|
\see gridColor for more information */
|
|
inline virtual void set_gridColor(const QColor & __value)
|
|
{
|
|
if (this->gridColor != __value) {
|
|
this->gridColor = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property gridColor.
|
|
\details Description of the parameter gridColor is: <CENTER>\copybrief gridColor.</CENTER>
|
|
\see gridColor for more information */
|
|
inline virtual QColor get_gridColor() const
|
|
{
|
|
return this->gridColor;
|
|
}
|
|
/*! \brief sets the property gridStyle to the specified \a __value.
|
|
\details Description of the parameter gridStyle is: <CENTER>\copybrief gridStyle.</CENTER>
|
|
\see gridStyle for more information */
|
|
inline virtual void set_gridStyle(const Qt::PenStyle & __value)
|
|
{
|
|
if (this->gridStyle != __value) {
|
|
this->gridStyle = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property gridStyle.
|
|
\details Description of the parameter gridStyle is: <CENTER>\copybrief gridStyle.</CENTER>
|
|
\see gridStyle for more information */
|
|
inline virtual Qt::PenStyle get_gridStyle() const
|
|
{
|
|
return this->gridStyle;
|
|
}
|
|
/*! \brief sets the property gridWidth to the specified \a __value.
|
|
\details Description of the parameter gridWidth is: <CENTER>\copybrief gridWidth.</CENTER>
|
|
\see gridWidth for more information */
|
|
inline virtual void set_gridWidth(double __value)
|
|
{
|
|
if (this->gridWidth != __value) {
|
|
this->gridWidth = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property gridWidth.
|
|
\details Description of the parameter gridWidth is: <CENTER>\copybrief gridWidth.</CENTER>
|
|
\see gridWidth for more information */
|
|
inline virtual double get_gridWidth() const
|
|
{
|
|
return this->gridWidth;
|
|
}
|
|
/*! \brief sets the property labelFontSize to the specified \a __value.
|
|
\details Description of the parameter labelFontSize is: <CENTER>\copybrief labelFontSize.</CENTER>
|
|
\see labelFontSize for more information */
|
|
inline virtual void set_labelFontSize(double __value)
|
|
{
|
|
if (this->labelFontSize != __value) {
|
|
this->labelFontSize = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property labelFontSize.
|
|
\details Description of the parameter labelFontSize is: <CENTER>\copybrief labelFontSize.</CENTER>
|
|
\see labelFontSize for more information */
|
|
inline virtual double get_labelFontSize() const
|
|
{
|
|
return this->labelFontSize;
|
|
}
|
|
/*! \brief sets the property labelFontName to the specified \a __value.
|
|
\details Description of the parameter labelFontName is: <CENTER>\copybrief labelFontName.</CENTER>
|
|
\see labelFontName for more information */
|
|
inline virtual void set_labelFontName(const QString & __value)
|
|
{
|
|
if (this->labelFontName != __value) {
|
|
this->labelFontName = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property labelFontName.
|
|
\details Description of the parameter labelFontName is: <CENTER>\copybrief labelFontName.</CENTER>
|
|
\see labelFontName for more information */
|
|
inline virtual QString get_labelFontName() const
|
|
{
|
|
return this->labelFontName;
|
|
}
|
|
/*! \brief sets the property tickFontSize to the specified \a __value.
|
|
\details Description of the parameter tickFontSize is: <CENTER>\copybrief tickFontSize.</CENTER>
|
|
\see tickFontSize for more information */
|
|
inline virtual void set_tickFontSize(double __value)
|
|
{
|
|
if (this->tickFontSize != __value) {
|
|
this->tickFontSize = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property tickFontSize.
|
|
\details Description of the parameter tickFontSize is: <CENTER>\copybrief tickFontSize.</CENTER>
|
|
\see tickFontSize for more information */
|
|
inline virtual double get_tickFontSize() const
|
|
{
|
|
return this->tickFontSize;
|
|
}
|
|
/*! \brief sets the property tickFontName to the specified \a __value.
|
|
\details Description of the parameter tickFontName is: <CENTER>\copybrief tickFontName.</CENTER>
|
|
\see tickFontName for more information */
|
|
inline virtual void set_tickFontName(const QString & __value)
|
|
{
|
|
if (this->tickFontName != __value) {
|
|
this->tickFontName = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property tickFontName.
|
|
\details Description of the parameter tickFontName is: <CENTER>\copybrief tickFontName.</CENTER>
|
|
\see tickFontName for more information */
|
|
inline virtual QString get_tickFontName() const
|
|
{
|
|
return this->tickFontName;
|
|
}
|
|
/*! \brief sets the property tickLength to the specified \a __value.
|
|
\details Description of the parameter tickLength is: <CENTER>\copybrief tickLength.</CENTER>
|
|
\see tickLength for more information */
|
|
inline virtual void set_tickLength(double __value)
|
|
{
|
|
if (this->tickLength != __value) {
|
|
this->tickLength = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property tickLength.
|
|
\details Description of the parameter tickLength is: <CENTER>\copybrief tickLength.</CENTER>
|
|
\see tickLength for more information */
|
|
inline virtual double get_tickLength() const
|
|
{
|
|
return this->tickLength;
|
|
}
|
|
/*! \brief sets the property drawSystemBox to the specified \a __value.
|
|
\details Description of the parameter drawSystemBox is: <CENTER>\copybrief drawSystemBox.</CENTER>
|
|
\see drawSystemBox for more information */
|
|
inline virtual void set_drawSystemBox(bool __value)
|
|
{
|
|
if (this->drawSystemBox != __value) {
|
|
this->drawSystemBox = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property drawSystemBox.
|
|
\details Description of the parameter drawSystemBox is: <CENTER>\copybrief drawSystemBox.</CENTER>
|
|
\see drawSystemBox for more information */
|
|
inline virtual bool get_drawSystemBox() const
|
|
{
|
|
return this->drawSystemBox;
|
|
}
|
|
/*! \brief sets the property drawZeroAxes to the specified \a __value.
|
|
\details Description of the parameter drawZeroAxes is: <CENTER>\copybrief drawZeroAxes.</CENTER>
|
|
\see drawZeroAxes for more information */
|
|
inline virtual void set_drawZeroAxes(bool __value)
|
|
{
|
|
if (this->drawZeroAxes != __value) {
|
|
this->drawZeroAxes = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property drawZeroAxes.
|
|
\details Description of the parameter drawZeroAxes is: <CENTER>\copybrief drawZeroAxes.</CENTER>
|
|
\see drawZeroAxes for more information */
|
|
inline virtual bool get_drawZeroAxes() const
|
|
{
|
|
return this->drawZeroAxes;
|
|
}
|
|
/*! \brief sets the property systemColor to the specified \a __value.
|
|
\details Description of the parameter systemColor is: <CENTER>\copybrief systemColor.</CENTER>
|
|
\see systemColor for more information */
|
|
inline virtual void set_systemColor(const QColor & __value)
|
|
{
|
|
if (this->systemColor != __value) {
|
|
this->systemColor = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property systemColor.
|
|
\details Description of the parameter systemColor is: <CENTER>\copybrief systemColor.</CENTER>
|
|
\see systemColor for more information */
|
|
inline virtual QColor get_systemColor() const
|
|
{
|
|
return this->systemColor;
|
|
}
|
|
/*! \brief sets the property systemWidth to the specified \a __value.
|
|
\details Description of the parameter systemWidth is: <CENTER>\copybrief systemWidth.</CENTER>
|
|
\see systemWidth for more information */
|
|
inline virtual void set_systemWidth(double __value)
|
|
{
|
|
if (this->systemWidth != __value) {
|
|
this->systemWidth = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property systemWidth.
|
|
\details Description of the parameter systemWidth is: <CENTER>\copybrief systemWidth.</CENTER>
|
|
\see systemWidth for more information */
|
|
inline virtual double get_systemWidth() const
|
|
{
|
|
return this->systemWidth;
|
|
}
|
|
/*! \brief sets the property xZeroTick to the specified \a __value.
|
|
\details Description of the parameter xZeroTick is: <CENTER>\copybrief xZeroTick.</CENTER>
|
|
\see xZeroTick for more information */
|
|
inline virtual void set_xZeroTick(double __value)
|
|
{
|
|
if (this->xZeroTick != __value) {
|
|
this->xZeroTick = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xZeroTick.
|
|
\details Description of the parameter xZeroTick is: <CENTER>\copybrief xZeroTick.</CENTER>
|
|
\see xZeroTick for more information */
|
|
inline virtual double get_xZeroTick() const
|
|
{
|
|
return this->xZeroTick;
|
|
}
|
|
/*! \brief sets the property yZeroTick to the specified \a __value.
|
|
\details Description of the parameter yZeroTick is: <CENTER>\copybrief yZeroTick.</CENTER>
|
|
\see yZeroTick for more information */
|
|
inline virtual void set_yZeroTick(double __value)
|
|
{
|
|
if (this->yZeroTick != __value) {
|
|
this->yZeroTick = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property yZeroTick.
|
|
\details Description of the parameter yZeroTick is: <CENTER>\copybrief yZeroTick.</CENTER>
|
|
\see yZeroTick for more information */
|
|
inline virtual double get_yZeroTick() const
|
|
{
|
|
return this->yZeroTick;
|
|
}
|
|
/*! \brief sets the property xTickDistance to the specified \a __value.
|
|
\details Description of the parameter xTickDistance is: <CENTER>\copybrief xTickDistance.</CENTER>
|
|
\see xTickDistance for more information */
|
|
inline virtual void set_xTickDistance(double __value)
|
|
{
|
|
if (this->xTickDistance != __value) {
|
|
this->xTickDistance = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xTickDistance.
|
|
\details Description of the parameter xTickDistance is: <CENTER>\copybrief xTickDistance.</CENTER>
|
|
\see xTickDistance for more information */
|
|
inline virtual double get_xTickDistance() const
|
|
{
|
|
return this->xTickDistance;
|
|
}
|
|
/*! \brief sets the property yTickDistance to the specified \a __value.
|
|
\details Description of the parameter yTickDistance is: <CENTER>\copybrief yTickDistance.</CENTER>
|
|
\see yTickDistance for more information */
|
|
inline virtual void set_yTickDistance(double __value)
|
|
{
|
|
if (this->yTickDistance != __value) {
|
|
this->yTickDistance = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property yTickDistance.
|
|
\details Description of the parameter yTickDistance is: <CENTER>\copybrief yTickDistance.</CENTER>
|
|
\see yTickDistance for more information */
|
|
inline virtual double get_yTickDistance() const
|
|
{
|
|
return this->yTickDistance;
|
|
}
|
|
/*! \brief sets the property xAxisLabel to the specified \a __value.
|
|
\details Description of the parameter xAxisLabel is: <CENTER>\copybrief xAxisLabel.</CENTER>
|
|
\see xAxisLabel for more information */
|
|
inline virtual void set_xAxisLabel(const QString & __value)
|
|
{
|
|
if (this->xAxisLabel != __value) {
|
|
this->xAxisLabel = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xAxisLabel.
|
|
\details Description of the parameter xAxisLabel is: <CENTER>\copybrief xAxisLabel.</CENTER>
|
|
\see xAxisLabel for more information */
|
|
inline virtual QString get_xAxisLabel() const
|
|
{
|
|
return this->xAxisLabel;
|
|
}
|
|
/*! \brief sets the property yAxisLabel to the specified \a __value.
|
|
\details Description of the parameter yAxisLabel is: <CENTER>\copybrief yAxisLabel.</CENTER>
|
|
\see yAxisLabel for more information */
|
|
inline virtual void set_yAxisLabel(const QString & __value)
|
|
{
|
|
if (this->yAxisLabel != __value) {
|
|
this->yAxisLabel = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property yAxisLabel.
|
|
\details Description of the parameter yAxisLabel is: <CENTER>\copybrief yAxisLabel.</CENTER>
|
|
\see yAxisLabel for more information */
|
|
inline virtual QString get_yAxisLabel() const
|
|
{
|
|
return this->yAxisLabel;
|
|
}
|
|
/*! \brief sets the property aspectRatio to the specified \a __value.
|
|
\details Description of the parameter aspectRatio is: <CENTER>\copybrief aspectRatio.</CENTER>
|
|
\see aspectRatio for more information */
|
|
inline virtual void set_aspectRatio(double __value)
|
|
{
|
|
if (this->aspectRatio != __value) {
|
|
this->aspectRatio = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property aspectRatio.
|
|
\details Description of the parameter aspectRatio is: <CENTER>\copybrief aspectRatio.</CENTER>
|
|
\see aspectRatio for more information */
|
|
inline virtual double get_aspectRatio() const
|
|
{
|
|
return this->aspectRatio;
|
|
}
|
|
/*! \brief sets the property maintainAspectRatio to the specified \a __value.
|
|
\details Description of the parameter maintainAspectRatio is: <CENTER>\copybrief maintainAspectRatio.</CENTER>
|
|
\see maintainAspectRatio for more information */
|
|
inline virtual void set_maintainAspectRatio(bool __value)
|
|
{
|
|
if (this->maintainAspectRatio != __value) {
|
|
this->maintainAspectRatio = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property maintainAspectRatio.
|
|
\details Description of the parameter maintainAspectRatio is: <CENTER>\copybrief maintainAspectRatio.</CENTER>
|
|
\see maintainAspectRatio for more information */
|
|
inline virtual bool get_maintainAspectRatio() const
|
|
{
|
|
return this->maintainAspectRatio;
|
|
}
|
|
/*! \brief sets the property xAxisLabelVisible to the specified \a __value.
|
|
\details Description of the parameter xAxisLabelVisible is: <CENTER>\copybrief xAxisLabelVisible.</CENTER>
|
|
\see xAxisLabelVisible for more information */
|
|
inline virtual void set_xAxisLabelVisible(bool __value)
|
|
{
|
|
if (this->xAxisLabelVisible != __value) {
|
|
this->xAxisLabelVisible = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xAxisLabelVisible.
|
|
\details Description of the parameter xAxisLabelVisible is: <CENTER>\copybrief xAxisLabelVisible.</CENTER>
|
|
\see xAxisLabelVisible for more information */
|
|
inline virtual bool get_xAxisLabelVisible() const
|
|
{
|
|
return this->xAxisLabelVisible;
|
|
}
|
|
/*! \brief sets the property yAxisLabelVisible to the specified \a __value.
|
|
\details Description of the parameter yAxisLabelVisible is: <CENTER>\copybrief yAxisLabelVisible.</CENTER>
|
|
\see yAxisLabelVisible for more information */
|
|
inline virtual void set_yAxisLabelVisible(bool __value)
|
|
{
|
|
if (this->yAxisLabelVisible != __value) {
|
|
this->yAxisLabelVisible = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property yAxisLabelVisible.
|
|
\details Description of the parameter yAxisLabelVisible is: <CENTER>\copybrief yAxisLabelVisible.</CENTER>
|
|
\see yAxisLabelVisible for more information */
|
|
inline virtual bool get_yAxisLabelVisible() const
|
|
{
|
|
return this->yAxisLabelVisible;
|
|
}
|
|
/*! \brief sets the property synchronizeX to the specified \a __value.
|
|
\details Description of the parameter synchronizeX is: <CENTER>\copybrief synchronizeX.</CENTER>
|
|
\see synchronizeX for more information */
|
|
inline virtual void set_synchronizeX(JKQTFastPlotter* & __value)
|
|
{
|
|
if (this->synchronizeX != __value) {
|
|
this->synchronizeX = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property synchronizeX.
|
|
\details Description of the parameter synchronizeX is: <CENTER>\copybrief synchronizeX.</CENTER>
|
|
\see synchronizeX for more information */
|
|
inline virtual JKQTFastPlotter* get_synchronizeX() const
|
|
{
|
|
return this->synchronizeX;
|
|
}
|
|
/*! \brief sets the property synchronizeY to the specified \a __value.
|
|
\details Description of the parameter synchronizeY is: <CENTER>\copybrief synchronizeY.</CENTER>
|
|
\see synchronizeY for more information */
|
|
inline virtual void set_synchronizeY(JKQTFastPlotter* & __value)
|
|
{
|
|
if (this->synchronizeY != __value) {
|
|
this->synchronizeY = __value;
|
|
update_plot();
|
|
}
|
|
}
|
|
/*! \brief returns the property synchronizeY.
|
|
\details Description of the parameter synchronizeY is: <CENTER>\copybrief synchronizeY.</CENTER>
|
|
\see synchronizeY for more information */
|
|
inline virtual JKQTFastPlotter* get_synchronizeY() const
|
|
{
|
|
return this->synchronizeY;
|
|
}
|
|
|
|
/** \brief draw the contents onto any QPainter, starting at (0,0), returns the size of the whole plot in \a size, if supplied with the default background color */
|
|
void draw(QPainter* painter, QSize* size=nullptr);
|
|
|
|
/** \brief draw the contents onto any QPainter, starting at (0,0), returns the size of the whole plot in \a size, if supplied with the supplied\a background color */
|
|
void draw(QPainter* painter, QColor background, QSize* size);
|
|
|
|
signals:
|
|
/** \brief emitted whenever the graph sizes (borders, plotWidth, plotHeight) change*/
|
|
void plotterSizesChanged();
|
|
/** \brief emitted whenever the graph is replotted */
|
|
void replotting();
|
|
/** \brief emitted whenever the mouse is clicked inside the plot */
|
|
void clicked(double x, double y);
|
|
/** \brief emitted whenever the mouse is clicked inside the plot */
|
|
void clicked(double x, double y, Qt::KeyboardModifiers modifiers);
|
|
/** \brief emitted whenever the mouse is double-clicked inside the plot */
|
|
void doubleClicked(double x, double y);
|
|
/** \brief emitted whenever the mouse is double-clicked inside the plot */
|
|
void doubleClicked(double x, double y, Qt::KeyboardModifiers modifiers);
|
|
/** \brief emitted whenever the mouse is clicked inside the plot */
|
|
void mouseMoved(double x, double y);
|
|
/** \brief emitted when the mouse has been dragged with the left button clicked */
|
|
void mouseDragged(double x_start, double y_start, double x_end, double y_end, Qt::KeyboardModifiers modifiers);
|
|
/** \brief emitted after the mouse has been dragged with the left button clicked */
|
|
void mouseDragFinished(double x_start, double y_start, double x_end, double y_end, Qt::KeyboardModifiers modifiers);
|
|
public slots:
|
|
/** \brief copy the current plot image to the clipboard */
|
|
void copyImage();
|
|
/** \brief replot everything (slowest possible plotting) */
|
|
void update_plot();
|
|
/** \brief replot everything (slowest possible plotting) and forces a repaint calling QWidget::repaint() */
|
|
void update_plot_immediate();
|
|
/** \brief replot only the data
|
|
*
|
|
* This internally calls QWidget::update(), so no immediate repaint() is forced! If you want an immediate update,
|
|
* call update_data_immediate() instead!
|
|
*/
|
|
void update_data();
|
|
/** \brief replot only the data, forces a redraw by calling QWidget::repaint() */
|
|
void update_data_immediate();
|
|
|
|
/** \brief set xMin*/
|
|
void set_xMin(double value){
|
|
set_doDrawing(false);
|
|
setXRange(value,xMax,xAxisLog);
|
|
set_doDrawing(true);
|
|
}
|
|
/** \brief set xMax*/
|
|
void set_xMax(double value){
|
|
set_doDrawing(false);
|
|
setXRange(xMin,value,xAxisLog);
|
|
set_doDrawing(true);
|
|
}
|
|
/** \brief set yMin*/
|
|
void set_yMin(double value){
|
|
set_doDrawing(false);
|
|
setYRange(value,yMax,yAxisLog);
|
|
set_doDrawing(true);
|
|
}
|
|
/** \brief set yMax*/
|
|
void set_yMax(double value){
|
|
set_doDrawing(false);
|
|
setYRange(yMin,value,yAxisLog);
|
|
set_doDrawing(true);
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*! \brief base class for all plots that may be plotted by JKQTFastPlotter
|
|
\ingroup jkqtfastplotter
|
|
*/
|
|
class LIB_EXPORT JKQTFPPlot: public QObject {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief parent class, i.e. the plotter to plot on */
|
|
JKQTFastPlotter* parent;
|
|
|
|
/** \brief indicates whether the plot is visible or not */
|
|
bool visible;
|
|
public:
|
|
/** \brief class constructor */
|
|
JKQTFPPlot(JKQTFastPlotter* parent);
|
|
|
|
/** \brief virtual class destructor */
|
|
virtual ~JKQTFPPlot();
|
|
|
|
/** \brief set the parent of the plot */
|
|
void setParent(JKQTFastPlotter* parent) { this->parent=parent; QObject::setParent(parent); }
|
|
|
|
bool isVisible() const { return this->visible; }
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter)=0;
|
|
|
|
/** \brief draw the graph */
|
|
void paint(QPainter& painter);
|
|
|
|
/** \brief start a replot of the parent widget */
|
|
void replot();
|
|
public slots:
|
|
void setVisible(bool visible) { this->visible=visible; replot(); }
|
|
|
|
};
|
|
|
|
|
|
|
|
/*! \brief a simple line plot for JKQTFastPlotter
|
|
\ingroup jkqtfastplotter
|
|
|
|
This class plots data as (x,y) points connected by straight lines. If errors for the y values are
|
|
provided, also y+/-yerr errorlines are drawn.
|
|
*/
|
|
class LIB_EXPORT JKQTFPLinePlot: public JKQTFPPlot {
|
|
public:
|
|
/** \brief used to store which datatype is used for the plot data */
|
|
enum DataType {
|
|
JKQTFPLPPointer,
|
|
JKQTFPLPVector
|
|
};
|
|
protected:
|
|
/** \brief number of datapoints in the plot */
|
|
unsigned int N;
|
|
/** \brief pointer to x-coordinate data to display */
|
|
double* x;
|
|
/** \brief pointer to y-coordinate data to display */
|
|
double* y;
|
|
/** \brief pointer to yerr-coordinate data to display */
|
|
double* yerr;
|
|
/** \brief pointer to x-coordinate data to display */
|
|
QVector<double>* xv;
|
|
/** \brief pointer to y-coordinate data to display */
|
|
QVector<double>* yv;
|
|
/** \brief pointer to yerr-coordinate data to display */
|
|
QVector<double>* yerrv;
|
|
/** \brief which type of data is used for plotting ? */
|
|
DataType datatype;
|
|
/** \brief color of the graph */
|
|
QColor color;
|
|
/** \brief style of the graph */
|
|
Qt::PenStyle style;
|
|
/** \brief width of the graph (in pixels) */
|
|
double width;
|
|
/** \brief color of the graph */
|
|
QColor errorColor;
|
|
/** \brief style of the graph */
|
|
Qt::PenStyle errorStyle;
|
|
/** \brief width of the graph (in pixels) */
|
|
double errorWidth;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param N number of datapoints in the plot
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPLinePlot(JKQTFastPlotter* parent, unsigned int N, double* x, double* y, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1) ;
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPLinePlot(JKQTFastPlotter* parent, QVector<double>* x, QVector<double>* y, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
inline void set_data(double* x, double* y, unsigned int N) {
|
|
this->x=x;
|
|
this->y=y;
|
|
this->yerr=nullptr;
|
|
this->N=N;
|
|
datatype=JKQTFPLPPointer;
|
|
replot();
|
|
};
|
|
|
|
inline void set_data(double* x, double* y, double* yerr, unsigned int N) {
|
|
this->x=x;
|
|
this->y=y;
|
|
this->yerr=yerr;
|
|
this->N=N;
|
|
datatype=JKQTFPLPPointer;
|
|
replot();
|
|
};
|
|
|
|
inline void set_data(QVector<double>* x, QVector<double>* y) {
|
|
this->x=nullptr;
|
|
this->y=nullptr;
|
|
this->yerr=nullptr;
|
|
this->xv=x;
|
|
this->yv=y;
|
|
this->yerrv=nullptr;
|
|
this->N=x->size();
|
|
datatype=JKQTFPLPVector;
|
|
replot();
|
|
};
|
|
|
|
inline void set_data(QVector<double>* x, QVector<double>* y, QVector<double>* yerr) {
|
|
this->x=nullptr;
|
|
this->y=nullptr;
|
|
this->yerr=nullptr;
|
|
this->xv=x;
|
|
this->yv=y;
|
|
this->yerrv=yerr;
|
|
this->N=x->size();
|
|
datatype=JKQTFPLPVector;
|
|
replot();
|
|
};
|
|
|
|
inline unsigned int get_N() {
|
|
if (datatype==JKQTFPLPPointer)
|
|
return N;
|
|
if (datatype==JKQTFPLPVector)
|
|
return xv->size();
|
|
return N;
|
|
}
|
|
|
|
/*! \brief returns the property x.
|
|
\details Description of the parameter x is: <CENTER>\copybrief x.</CENTER>.
|
|
\see x for more information */
|
|
inline double* get_x() const {
|
|
return this->x;
|
|
}
|
|
/*! \brief returns the property y.
|
|
\details Description of the parameter y is: <CENTER>\copybrief y.</CENTER>.
|
|
\see y for more information */
|
|
inline double* get_y() const {
|
|
return this->y;
|
|
}
|
|
/*! \brief returns the property yerr.
|
|
\details Description of the parameter yerr is: <CENTER>\copybrief yerr.</CENTER>.
|
|
\see yerr for more information */
|
|
inline double* get_yerr() const {
|
|
return this->yerr;
|
|
}
|
|
/*! \brief returns the property xv.
|
|
\details Description of the parameter xv is: <CENTER>\copybrief xv.</CENTER>.
|
|
\see xv for more information */
|
|
inline QVector<double>* get_xv() const {
|
|
return this->xv;
|
|
}
|
|
/*! \brief returns the property yv.
|
|
\details Description of the parameter yv is: <CENTER>\copybrief yv.</CENTER>.
|
|
\see yv for more information */
|
|
inline QVector<double>* get_yv() const {
|
|
return this->yv;
|
|
}
|
|
/*! \brief returns the property yerrv.
|
|
\details Description of the parameter yerrv is: <CENTER>\copybrief yerrv.</CENTER>.
|
|
\see yerrv for more information */
|
|
inline QVector<double>* get_yerrv() const {
|
|
return this->yerrv;
|
|
}
|
|
/*! \brief returns the property datatype.
|
|
\details Description of the parameter datatype is: <CENTER>\copybrief datatype.</CENTER>.
|
|
\see datatype for more information */
|
|
inline DataType get_datatype() const {
|
|
return this->datatype;
|
|
}
|
|
/*! \brief sets the property color to the specified \a __value.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual void set_color(const QColor & __value)
|
|
{
|
|
if (this->color != __value) {
|
|
this->color = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property color.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual QColor get_color() const
|
|
{
|
|
return this->color;
|
|
}
|
|
/*! \brief sets the property style to the specified \a __value.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual void set_style(const Qt::PenStyle & __value)
|
|
{
|
|
if (this->style != __value) {
|
|
this->style = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property style.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual Qt::PenStyle get_style() const
|
|
{
|
|
return this->style;
|
|
}
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(double __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual double get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief sets the property errorColor to the specified \a __value.
|
|
\details Description of the parameter errorColor is: <CENTER>\copybrief errorColor.</CENTER>
|
|
\see errorColor for more information */
|
|
inline virtual void set_errorColor(const QColor & __value)
|
|
{
|
|
if (this->errorColor != __value) {
|
|
this->errorColor = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property errorColor.
|
|
\details Description of the parameter errorColor is: <CENTER>\copybrief errorColor.</CENTER>
|
|
\see errorColor for more information */
|
|
inline virtual QColor get_errorColor() const
|
|
{
|
|
return this->errorColor;
|
|
}
|
|
/*! \brief sets the property errorStyle to the specified \a __value.
|
|
\details Description of the parameter errorStyle is: <CENTER>\copybrief errorStyle.</CENTER>
|
|
\see errorStyle for more information */
|
|
inline virtual void set_errorStyle(const Qt::PenStyle & __value)
|
|
{
|
|
if (this->errorStyle != __value) {
|
|
this->errorStyle = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property errorStyle.
|
|
\details Description of the parameter errorStyle is: <CENTER>\copybrief errorStyle.</CENTER>
|
|
\see errorStyle for more information */
|
|
inline virtual Qt::PenStyle get_errorStyle() const
|
|
{
|
|
return this->errorStyle;
|
|
}
|
|
/*! \brief sets the property errorWidth to the specified \a __value.
|
|
\details Description of the parameter errorWidth is: <CENTER>\copybrief errorWidth.</CENTER>
|
|
\see errorWidth for more information */
|
|
inline virtual void set_errorWidth(double __value)
|
|
{
|
|
if (this->errorWidth != __value) {
|
|
this->errorWidth = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property errorWidth.
|
|
\details Description of the parameter errorWidth is: <CENTER>\copybrief errorWidth.</CENTER>
|
|
\see errorWidth for more information */
|
|
inline virtual double get_errorWidth() const
|
|
{
|
|
return this->errorWidth;
|
|
}
|
|
};
|
|
|
|
|
|
|
|
|
|
/*! \brief a simple plot that draws a cross for every datapoint
|
|
\ingroup jkqtfastplotter
|
|
|
|
This class does not support y errors!
|
|
*/
|
|
class LIB_EXPORT JKQTFPVCrossPlot: public JKQTFPLinePlot {
|
|
Q_OBJECT
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param N number of datapoints in the plot
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPVCrossPlot(JKQTFastPlotter* parent, unsigned int N, double* x, double* y, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1) ;
|
|
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPVCrossPlot(JKQTFastPlotter* parent, QVector<double>* x, QVector<double>* y, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
/*! \brief sets the property crossWidth to the specified \a __value.
|
|
\details Description of the parameter crossWidth is: <CENTER>\copybrief crossWidth.</CENTER>
|
|
\see crossWidth for more information */
|
|
inline virtual void set_crossWidth(double __value)
|
|
{
|
|
if (this->crossWidth != __value) {
|
|
this->crossWidth = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property crossWidth.
|
|
\details Description of the parameter crossWidth is: <CENTER>\copybrief crossWidth.</CENTER>
|
|
\see crossWidth for more information */
|
|
inline virtual double get_crossWidth() const
|
|
{
|
|
return this->crossWidth;
|
|
}
|
|
protected:
|
|
/** \brief width of the crosses */
|
|
double crossWidth;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*! \brief a simple vertical bar plot for JKQTFastPlotter
|
|
\ingroup jkqtfastplotter
|
|
|
|
This class does not support y errors!
|
|
*/
|
|
class LIB_EXPORT JKQTFPVBarPlot: public JKQTFPLinePlot {
|
|
Q_OBJECT
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param N number of datapoints in the plot
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPVBarPlot(JKQTFastPlotter* parent, unsigned int N, double* x, double* y, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1) ;
|
|
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPVBarPlot(JKQTFastPlotter* parent, QVector<double>* x, QVector<double>* y, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
};
|
|
|
|
|
|
/*! \brief plot a range of x values
|
|
\ingroup jkqtfastplotter
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPXRangePlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief start of x range */
|
|
double xmin;
|
|
/** \brief end of x range */
|
|
double xmax;
|
|
double centerline;
|
|
bool showCenterline;
|
|
/** \brief color of the graph */
|
|
QColor color;
|
|
/** \brief style of the graph */
|
|
Qt::PenStyle style;
|
|
/** \brief width of the graph (in pixels) */
|
|
double width;
|
|
/** \brief fill color of the graph */
|
|
QColor fillColor;
|
|
/** \brief fill style of the graph */
|
|
Qt::BrushStyle fillStyle;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param N number of datapoints in the plot
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPXRangePlot(JKQTFastPlotter* parent, double xmin, double xmax, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1, Qt::BrushStyle fillStyle=Qt::NoBrush) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
/*! \brief sets the property color to the specified \a __value.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual void set_color(const QColor & __value)
|
|
{
|
|
if (this->color != __value) {
|
|
this->color = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property color.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual QColor get_color() const
|
|
{
|
|
return this->color;
|
|
}
|
|
/*! \brief sets the property fillColor to the specified \a __value.
|
|
\details Description of the parameter fillColor is: <CENTER>\copybrief fillColor.</CENTER>
|
|
\see fillColor for more information */
|
|
inline virtual void set_fillColor(const QColor & __value)
|
|
{
|
|
if (this->fillColor != __value) {
|
|
this->fillColor = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property fillColor.
|
|
\details Description of the parameter fillColor is: <CENTER>\copybrief fillColor.</CENTER>
|
|
\see fillColor for more information */
|
|
inline virtual QColor get_fillColor() const
|
|
{
|
|
return this->fillColor;
|
|
}
|
|
/*! \brief sets the property fillStyle to the specified \a __value.
|
|
\details Description of the parameter fillStyle is: <CENTER>\copybrief fillStyle.</CENTER>
|
|
\see fillStyle for more information */
|
|
inline virtual void set_fillStyle(const Qt::BrushStyle & __value)
|
|
{
|
|
if (this->fillStyle != __value) {
|
|
this->fillStyle = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property fillStyle.
|
|
\details Description of the parameter fillStyle is: <CENTER>\copybrief fillStyle.</CENTER>
|
|
\see fillStyle for more information */
|
|
inline virtual Qt::BrushStyle get_fillStyle() const
|
|
{
|
|
return this->fillStyle;
|
|
}
|
|
/*! \brief sets the property style to the specified \a __value.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual void set_style(const Qt::PenStyle & __value)
|
|
{
|
|
if (this->style != __value) {
|
|
this->style = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property style.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual Qt::PenStyle get_style() const
|
|
{
|
|
return this->style;
|
|
}
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(double __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual double get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief returns the property xmin.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>.
|
|
\see xmin for more information */
|
|
inline double get_xmin() const {
|
|
return this->xmin;
|
|
}
|
|
/*! \brief returns the property xmax.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>.
|
|
\see xmax for more information */
|
|
inline double get_xmax() const {
|
|
return this->xmax;
|
|
}
|
|
/*! \brief returns the property centerline.
|
|
\details Description of the parameter centerline is: <CENTER>\copybrief centerline.</CENTER>.
|
|
\see centerline for more information */
|
|
inline double get_centerline() const {
|
|
return this->centerline;
|
|
}
|
|
/*! \brief sets the property showCenterline to the specified \a __value.
|
|
\details Description of the parameter showCenterline is: <CENTER>\copybrief showCenterline.</CENTER>
|
|
\see showCenterline for more information */
|
|
inline virtual void set_showCenterline(bool __value)
|
|
{
|
|
if (this->showCenterline != __value) {
|
|
this->showCenterline = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property showCenterline.
|
|
\details Description of the parameter showCenterline is: <CENTER>\copybrief showCenterline.</CENTER>
|
|
\see showCenterline for more information */
|
|
inline virtual bool get_showCenterline() const
|
|
{
|
|
return this->showCenterline;
|
|
}
|
|
public slots:
|
|
void set_centerline(int centerline) {
|
|
if (this->centerline!=centerline) {
|
|
this->centerline=centerline;
|
|
replot();
|
|
}
|
|
}
|
|
void set_xmin(double xmin) {
|
|
if (this->xmin!=xmin) {
|
|
this->xmin=xmin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_xmax(double xmax) {
|
|
if (this->xmax!=xmax) {
|
|
this->xmax=xmax;
|
|
replot();
|
|
}
|
|
}
|
|
void set_xmin(int xmin) {
|
|
if (this->xmin!=xmin) {
|
|
this->xmin=xmin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_xmax(int xmax) {
|
|
if (this->xmax!=xmax) {
|
|
this->xmax=xmax;
|
|
replot();
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
|
|
/*! \brief plot a range of x values
|
|
\ingroup jkqtfastplotter
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPYRangePlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief start of x range */
|
|
double ymin;
|
|
/** \brief end of x range */
|
|
double ymax;
|
|
double centerline;
|
|
bool showCenterline;
|
|
/** \brief color of the graph */
|
|
QColor color;
|
|
/** \brief style of the graph */
|
|
Qt::PenStyle style;
|
|
/** \brief width of the graph (in pixels) */
|
|
double width;
|
|
/** \brief fill color of the graph */
|
|
QColor fillColor;
|
|
/** \brief fill style of the graph */
|
|
Qt::BrushStyle fillStyle;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
\param parent parent widget
|
|
\param N number of datapoints in the plot
|
|
\param x points to the x values in the plot
|
|
\param y points to the y values in the plot
|
|
\param color color of the plot
|
|
\param style style of the graph
|
|
\param width width of the plot (in pixels)
|
|
*/
|
|
JKQTFPYRangePlot(JKQTFastPlotter* parent, double ymin, double ymax, QColor color=QColor("red"), Qt::PenStyle style=Qt::SolidLine, double width=1, Qt::BrushStyle fillStyle=Qt::NoBrush) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
/*! \brief sets the property color to the specified \a __value.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual void set_color(const QColor & __value)
|
|
{
|
|
if (this->color != __value) {
|
|
this->color = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property color.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual QColor get_color() const
|
|
{
|
|
return this->color;
|
|
}
|
|
/*! \brief sets the property fillColor to the specified \a __value.
|
|
\details Description of the parameter fillColor is: <CENTER>\copybrief fillColor.</CENTER>
|
|
\see fillColor for more information */
|
|
inline virtual void set_fillColor(const QColor & __value)
|
|
{
|
|
if (this->fillColor != __value) {
|
|
this->fillColor = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property fillColor.
|
|
\details Description of the parameter fillColor is: <CENTER>\copybrief fillColor.</CENTER>
|
|
\see fillColor for more information */
|
|
inline virtual QColor get_fillColor() const
|
|
{
|
|
return this->fillColor;
|
|
}
|
|
/*! \brief sets the property fillStyle to the specified \a __value.
|
|
\details Description of the parameter fillStyle is: <CENTER>\copybrief fillStyle.</CENTER>
|
|
\see fillStyle for more information */
|
|
inline virtual void set_fillStyle(const Qt::BrushStyle & __value)
|
|
{
|
|
if (this->fillStyle != __value) {
|
|
this->fillStyle = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property fillStyle.
|
|
\details Description of the parameter fillStyle is: <CENTER>\copybrief fillStyle.</CENTER>
|
|
\see fillStyle for more information */
|
|
inline virtual Qt::BrushStyle get_fillStyle() const
|
|
{
|
|
return this->fillStyle;
|
|
}
|
|
/*! \brief sets the property style to the specified \a __value.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual void set_style(const Qt::PenStyle & __value)
|
|
{
|
|
if (this->style != __value) {
|
|
this->style = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property style.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual Qt::PenStyle get_style() const
|
|
{
|
|
return this->style;
|
|
}
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(double __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual double get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief returns the property ymin.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>.
|
|
\see ymin for more information */
|
|
inline double get_ymin() const {
|
|
return this->ymin;
|
|
}
|
|
/*! \brief returns the property ymax.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>.
|
|
\see ymax for more information */
|
|
inline double get_ymax() const {
|
|
return this->ymax;
|
|
}
|
|
/*! \brief returns the property centerline.
|
|
\details Description of the parameter centerline is: <CENTER>\copybrief centerline.</CENTER>.
|
|
\see centerline for more information */
|
|
inline double get_centerline() const {
|
|
return this->centerline;
|
|
}
|
|
/*! \brief sets the property showCenterline to the specified \a __value.
|
|
\details Description of the parameter showCenterline is: <CENTER>\copybrief showCenterline.</CENTER>
|
|
\see showCenterline for more information */
|
|
inline virtual void set_showCenterline(bool __value)
|
|
{
|
|
if (this->showCenterline != __value) {
|
|
this->showCenterline = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property showCenterline.
|
|
\details Description of the parameter showCenterline is: <CENTER>\copybrief showCenterline.</CENTER>
|
|
\see showCenterline for more information */
|
|
inline virtual bool get_showCenterline() const
|
|
{
|
|
return this->showCenterline;
|
|
}
|
|
public slots:
|
|
void set_centerline(int centerline) {
|
|
if (this->centerline!=centerline) {
|
|
this->centerline=centerline;
|
|
replot();
|
|
}
|
|
}
|
|
void set_ymin(double xmin) {
|
|
if (this->ymin!=xmin) {
|
|
this->ymin=xmin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_ymax(double xmax) {
|
|
if (this->ymax!=xmax) {
|
|
this->ymax=xmax;
|
|
replot();
|
|
}
|
|
}
|
|
void set_ymin(int xmin) {
|
|
if (this->ymin!=xmin) {
|
|
this->ymin=xmin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_ymax(int xmax) {
|
|
if (this->ymax!=xmax) {
|
|
this->ymax=xmax;
|
|
replot();
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
|
|
/*! \brief a plot of a QImage
|
|
\ingroup jkqtfastplotter
|
|
*/
|
|
class LIB_EXPORT JKQTFPQImagePlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief image to plot */
|
|
QImage* image;
|
|
/** \brief minimum x value of the image */
|
|
double xmin;
|
|
/** \brief maximum x value of the image */
|
|
double xmax;
|
|
/** \brief minimum x value of the image */
|
|
double ymin;
|
|
/** \brief maximum x value of the image */
|
|
double ymax;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
*/
|
|
JKQTFPQImagePlot(JKQTFastPlotter* parent, QImage* image, double xmin, double xmax, double ymin, double ymax) ;
|
|
|
|
JKQTFPQImagePlot(JKQTFastPlotter* parent, QImage* image);
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
/*! \brief sets the property image to the specified \a __value.
|
|
\details Description of the parameter image is: <CENTER>\copybrief image.</CENTER>
|
|
\see image for more information */
|
|
inline virtual void set_image(QImage* __value)
|
|
{
|
|
if (this->image != __value) {
|
|
this->image = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property image.
|
|
\details Description of the parameter image is: <CENTER>\copybrief image.</CENTER>
|
|
\see image for more information */
|
|
inline virtual QImage* get_image() const
|
|
{
|
|
return this->image;
|
|
}
|
|
/*! \brief sets the property xmin to the specified \a __value.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual void set_xmin(double __value)
|
|
{
|
|
if (this->xmin != __value) {
|
|
this->xmin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmin.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual double get_xmin() const
|
|
{
|
|
return this->xmin;
|
|
}
|
|
/*! \brief sets the property xmax to the specified \a __value.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual void set_xmax(double __value)
|
|
{
|
|
if (this->xmax != __value) {
|
|
this->xmax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmax.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual double get_xmax() const
|
|
{
|
|
return this->xmax;
|
|
}
|
|
/*! \brief sets the property ymin to the specified \a __value.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual void set_ymin(double __value)
|
|
{
|
|
if (this->ymin != __value) {
|
|
this->ymin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymin.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual double get_ymin() const
|
|
{
|
|
return this->ymin;
|
|
}
|
|
/*! \brief sets the property ymax to the specified \a __value.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual void set_ymax(double __value)
|
|
{
|
|
if (this->ymax != __value) {
|
|
this->ymax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymax.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual double get_ymax() const
|
|
{
|
|
return this->ymax;
|
|
}
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
\brief An enum for selecting the palette for coloring
|
|
\ingroup jkqtfastplotter
|
|
\details Here, the color palettes are illustrated (left is the color for the minimum and right for the maximum).
|
|
*/
|
|
enum JKQTFPColorPalette {
|
|
JKQTFP_RED=0, /*!< \image html RED.png */
|
|
JKQTFP_INVERTEDRED=1, /*!< \image html RED.png */
|
|
JKQTFP_GREEN=2, /*!< \image html GREEN.png */
|
|
JKQTFP_INVERTEDGREEN=3, /*!< \image html GREEN.png */
|
|
JKQTFP_BLUE=4, /*!< \image html BLUE.png */
|
|
JKQTFP_INVERTEDBLUE=5, /*!< \image html BLUE.png */
|
|
JKQTFP_GRAY=6, /*!< \image html GRAY.png */
|
|
JKQTFP_INVERTEDGRAY=7, /*!< \image html GRAY.png */
|
|
JKQTFP_MATLAB=8, /*!< \image html MATLAB.png */
|
|
JKQTFP_RYGB=9, /*!< \image html RYGB.png */
|
|
JKQTFP_HSV=10, /*!< \image html HSV.png */
|
|
JKQTFP_INVERTED_HSV=11, /*!< \image html INVERTED_HSV.png */
|
|
JKQTFP_RAINBOW=12, /*!< \image html RAINBOW.png */
|
|
JKQTFP_HOT=13, /*!< \image html HOT.png */
|
|
JKQTFP_OCEAN=14, /*!< \image html OCEAN.png */
|
|
JKQTFP_TRAFFICLIGHT=15, /*!< \image html TRAFFICLIGHT.png */
|
|
JKQTFP_BLUEMAGENTAYELLOW=16, /*!< \image html BLUEMAGENTAYELLOW.png */
|
|
JKQTFP_BLUEYELLOW=17, /*!< \image html BLUEYELLOW.png */
|
|
JKQTFP_CYAN=18 /*!< \image html CYAN.png */
|
|
};
|
|
|
|
/*!datatype for an image plotpalette for coloring
|
|
\ingroup jkqtfastplotter
|
|
\details Here, the color palettes are illustrated (left is the color for the minimum and right for the maximum).
|
|
*/
|
|
enum JKQTFPImageFormat {
|
|
JKQTFP_uint8=0, /*!< \image 8 bit unsigned int */
|
|
JKQTFP_uint16=1, /*!< \image 16 bit unsigned int */
|
|
JKQTFP_uint32=2, /*!< \image 32 bit unsigned int */
|
|
JKQTFP_float=3, /*!< \image float */
|
|
JKQTFP_double=4, /*!< \image double */
|
|
JKQTFP_int64=5 /*!< \image 64 bit signed int */
|
|
};
|
|
|
|
|
|
/*! \brief size of the lookup tables used by JKQTFPimagePlot_array2image()
|
|
\ingroup jkqtfastplotter
|
|
*/
|
|
#define JKQTFPimagePlot_LUTSIZE 256
|
|
|
|
|
|
/*! \brief convert a 2D image (as 1D array) into a QImage with given palette (see JKQTFPColorPalette)
|
|
\ingroup jkqtfastplotter
|
|
|
|
This method uses lookup tables which are saved as static variables to convert the 2D array into
|
|
an image. The luts are only created once, and stored then, so mor CPU time is saved. The precompiler define
|
|
JKQTFPimagePlot_LUTSIZE sets the size of the LUTs. Note that if you don't use a specific color palette,
|
|
the according LUT won't be calculated and stored!
|
|
*/
|
|
template <class T>
|
|
inline void JKQTFPimagePlot_array2image(T* dbl, int width, int height, QImage &img, JKQTFPColorPalette palette, T minColor, T maxColor)
|
|
{
|
|
if (!dbl)
|
|
return;
|
|
|
|
#ifdef DEBUG_TIMING
|
|
JKQTPHighResTimer timer;
|
|
double time_sum=0;
|
|
double time_gt=0;
|
|
std::cout<<" timing JKQTFPimagePlot_array2image:\n";
|
|
timer.start();
|
|
#endif
|
|
//std::cout<<"color range: "<<minColor<<"..."<<maxColor<<std::endl;
|
|
double min = *dbl;
|
|
double max = *dbl;
|
|
if (minColor == maxColor) {
|
|
for (int i=1; i<width*height; ++i)
|
|
{
|
|
register T v=dbl[i];
|
|
if (v < min)
|
|
min = v;
|
|
else if (v > max)
|
|
max = v;
|
|
}
|
|
} else {
|
|
min = minColor;
|
|
max = maxColor;
|
|
}
|
|
#ifdef DEBUG_TIMING
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" finding min&max: "<<time_gt/1000.0<<" ms\n";
|
|
timer.start();
|
|
#endif
|
|
//std::cout<<"minColor="<<minColor<<" maxColor="<<maxColor<<" min="<<min<<" max="<<max<<"\n";
|
|
|
|
double delta=max-min;
|
|
|
|
unsigned int* lut_used=nullptr;
|
|
static unsigned int* lut_red=nullptr;
|
|
static unsigned int* lut_green=nullptr;
|
|
static unsigned int* lut_blue=nullptr;
|
|
static unsigned int* lut_gray=nullptr;
|
|
static unsigned int* lut_invred=nullptr;
|
|
static unsigned int* lut_invgreen=nullptr;
|
|
static unsigned int* lut_invblue=nullptr;
|
|
static unsigned int* lut_invgray=nullptr;
|
|
static unsigned int* lut_matlab=nullptr;
|
|
static unsigned int* lut_rygb=nullptr;
|
|
static unsigned int* lut_hsv=nullptr;
|
|
static unsigned int* lut_invhsv=nullptr;
|
|
static unsigned int* lut_rainbow=nullptr;
|
|
static unsigned int* lut_hot=nullptr;
|
|
static unsigned int* lut_ocean=nullptr;
|
|
static unsigned int* lut_trafficlight=nullptr;
|
|
static unsigned int* lut_bluemagentayellow=nullptr;
|
|
static unsigned int* lut_blueyellow=nullptr;
|
|
static unsigned int* lut_cyan=nullptr;
|
|
|
|
|
|
img = QImage(width, height, QImage::Format_ARGB32_Premultiplied);
|
|
if (min == max)
|
|
img.fill(0);
|
|
else
|
|
{
|
|
if (palette == JKQTFP_RED)
|
|
{
|
|
unsigned int** plut=&lut_red;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*v), 0, 0);
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_GREEN)
|
|
{
|
|
unsigned int** plut=&lut_green;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(0, static_cast<int>(255.0*v), 0);
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_BLUE)
|
|
{
|
|
unsigned int** plut=&lut_blue;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(0, 0, static_cast<int>(255.0*v));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
|
|
|
|
else if (palette == JKQTFP_GRAY)
|
|
{
|
|
unsigned int** plut=&lut_gray;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*v),
|
|
static_cast<int>(255.0*v),
|
|
static_cast<int>(255.0*v));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
|
|
else if (palette == JKQTFP_INVERTEDRED)
|
|
{
|
|
unsigned int** plut=&lut_invred;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*(1.0-v)), 0, 0);
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_INVERTEDGREEN)
|
|
{
|
|
unsigned int** plut=&lut_invgreen;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(0, static_cast<int>(255.0*(1.0-v)), 0);
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
else if (palette == JKQTFP_INVERTEDBLUE)
|
|
{
|
|
unsigned int** plut=&lut_invblue;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
(*plut)[l]=qRgb(0, 0, static_cast<int>(255.0*(1.0-v)));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
else if (palette == JKQTFP_INVERTEDGRAY)
|
|
{
|
|
unsigned int** plut=&lut_invgray;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=1.0-(l/static_cast<double>(JKQTFPimagePlot_LUTSIZE));
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*v),
|
|
static_cast<int>(255.0*v),
|
|
static_cast<int>(255.0*v));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
|
|
else if (palette == JKQTFP_MATLAB)
|
|
{
|
|
unsigned int** plut=&lut_matlab;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = 382.5 - 1020.0 * std::abs(v - 0.75);
|
|
if (r > 255.0)
|
|
r = 255.0;
|
|
else if (r < 0.0)
|
|
r = 0.0;
|
|
|
|
double g = 382.5 - 1020.0 * std::abs(v - 0.5);
|
|
if (g > 255.0)
|
|
g = 255.0;
|
|
else if (g < 0.0)
|
|
g = 0.0;
|
|
|
|
double b = 382.5 - 1020.0 * std::abs(v - 0.25);
|
|
if (b > 255.0)
|
|
b = 255.0;
|
|
else if (b < 0.0)
|
|
b = 0.0;
|
|
|
|
(*plut)[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_RYGB) //gnuplot: 30,-13,-23
|
|
{
|
|
unsigned int** plut=&lut_rygb;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = 796.875*v - 199.21875;
|
|
if (r > 255.0)
|
|
r = 255.0;
|
|
else if (r < 0.0)
|
|
r = 0.0;
|
|
|
|
double g = 255.0 * std::sin(M_PI*v);
|
|
|
|
double b = 255.0 - 765.0 * v;
|
|
if (b < 0.0)
|
|
b = 0.0;
|
|
(*plut)[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_HSV)
|
|
{
|
|
unsigned int** plut=&lut_hsv;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
int h = static_cast<int>(floor(6*v));
|
|
double f = 6*v-double(h);
|
|
|
|
switch (h)
|
|
{
|
|
case 0: (*plut)[l]=qRgb(255, static_cast<int>(255.0*f), 0); break;
|
|
case 1: (*plut)[l]=qRgb(static_cast<int>(255.0*(1-f)), 255, 0); break;
|
|
case 2: (*plut)[l]=qRgb(0, 255, static_cast<int>(255.0*f)); break;
|
|
case 3: (*plut)[l]=qRgb(0, static_cast<int>(255.0*(1-f)), 255); break;
|
|
case 4: (*plut)[l]=qRgb(static_cast<int>(255.0*f), 0, 255); break;
|
|
case 5: (*plut)[l]=qRgb(255, 0, static_cast<int>(255.0*(1-f))); break;
|
|
case 6: (*plut)[l]=qRgb(255, static_cast<int>(255.0*f), 0); break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
else if (palette == JKQTFP_INVERTED_HSV)
|
|
{
|
|
unsigned int** plut=&lut_invhsv;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
int h = static_cast<int>(floor(6.0-6.0*v));
|
|
double f = 6.0-6.0*v-double(h);
|
|
|
|
switch (h)
|
|
{
|
|
case 0: (*plut)[l]=qRgb(255, static_cast<int>(255.0*f), 0); break;
|
|
case 1: (*plut)[l]=qRgb(static_cast<int>(255.0*(1-f)), 255, 0); break;
|
|
case 2: (*plut)[l]=qRgb(0, 255, static_cast<int>(255.0*f)); break;
|
|
case 3: (*plut)[l]=qRgb(0, static_cast<int>(255.0*(1-f)), 255); break;
|
|
case 4: (*plut)[l]=qRgb(static_cast<int>(255.0*f), 0, 255); break;
|
|
case 5: (*plut)[l]=qRgb(255, 0, static_cast<int>(255.0*(1-f))); break;
|
|
case 6: (*plut)[l]=qRgb(255, static_cast<int>(255.0*f), 0); break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_RAINBOW) //gnuplot: 33,13,10
|
|
{
|
|
if (lut_rainbow==nullptr) {
|
|
lut_rainbow=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(int));
|
|
//std::cout<<"!!! creating rainbow lut\n";
|
|
if (lut_rainbow!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = 255.0*std::abs(2.0*v-0.5);
|
|
if (r > 255.0)
|
|
r = 255.0;
|
|
|
|
double g = 255.0*sin(M_PI*v);
|
|
|
|
double b = 255.0*cos(0.5*M_PI*v);
|
|
|
|
lut_rainbow[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=lut_rainbow;
|
|
}
|
|
else if (palette == JKQTFP_HOT) //gnuplot: 21,22,23
|
|
{
|
|
unsigned int** plut=&lut_hot;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = 765.0*v;
|
|
if (r > 255.0)
|
|
r = 255.0;
|
|
|
|
double g = 765.0*v-255.0;
|
|
if (g > 255.0)
|
|
g = 255.0;
|
|
else if (g < 0.0)
|
|
g = 0.0;
|
|
|
|
double b = 765.0*v-510.0;
|
|
if (b < 0.0)
|
|
b = 0.0;
|
|
(*plut)[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
else if (palette == JKQTFP_OCEAN) //gnuplot: 23,28,3
|
|
{
|
|
unsigned int** plut=&lut_ocean;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = 765.0*v-510.0;
|
|
if (r < 0.0)
|
|
r = 0.0;
|
|
|
|
double g = std::abs(382.5*v-127.5);
|
|
|
|
double b = 255.0*v;
|
|
(*plut)[l]=qRgb(static_cast<int>(r), static_cast<int>(g), static_cast<int>(b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
else if (palette == JKQTFP_BLUEMAGENTAYELLOW) //gnuplot: 30,31,32
|
|
{
|
|
unsigned int** plut=&lut_bluemagentayellow;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = (v/0.32-0.78125);
|
|
if (r < 0.0) r = 0.0;
|
|
if (r > 1.0) r = 1.0;
|
|
|
|
double g = 2.0*v-0.84;
|
|
if (g < 0.0) g = 0.0;
|
|
if (g > 1.0) g = 1.0;
|
|
|
|
double b = 4.0*v;
|
|
if (b>1 || b<0) b = -2.0*v+1.84;
|
|
if (b>1 || b<0) b = v/0.08-11.5;
|
|
if (b>1 || b<0) b=1;
|
|
|
|
if (b < 0.0) b = 0.0;
|
|
if (b > 1.0) b = 1.0;
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*r), static_cast<int>(255.0*g), static_cast<int>(255.0*b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
}
|
|
else if (palette == JKQTFP_BLUEYELLOW) //gnuplot: 8,9,10
|
|
{
|
|
unsigned int** plut=&lut_blueyellow;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = sqrt(sqrt(v));
|
|
if (r < 0.0) r = 0.0;
|
|
if (r > 1.0) r = 1.0;
|
|
|
|
double g = sin(M_PI/2.0*v);
|
|
if (g < 0.0) g = 0.0;
|
|
if (g > 1.0) g = 1.0;
|
|
|
|
double b = cos(M_PI/2.0*v);
|
|
if (b < 0.0) b = 0.0;
|
|
if (b > 1.0) b = 1.0;
|
|
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*r), static_cast<int>(255.0*g), static_cast<int>(255.0*b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_CYAN)
|
|
{
|
|
unsigned int** plut=&lut_cyan;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = v*0.5;
|
|
if (r < 0.0) r = 0.0;
|
|
if (r > 1.0) r = 1.0;
|
|
|
|
double g = v;
|
|
if (g < 0.0) g = 0.0;
|
|
if (g > 1.0) g = 1.0;
|
|
|
|
double b = v;
|
|
if (b < 0.0) b = 0.0;
|
|
if (b > 1.0) b = 1.0;
|
|
(*plut)[l]=qRgb(static_cast<int>(255.0*r), static_cast<int>(255.0*g), static_cast<int>(255.0*b));
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
else if (palette == JKQTFP_TRAFFICLIGHT)
|
|
{
|
|
unsigned int** plut=&lut_trafficlight;
|
|
if ((*plut)==nullptr) {
|
|
(*plut)=(unsigned int*)malloc((JKQTFPimagePlot_LUTSIZE+2)*sizeof(unsigned int));
|
|
if ((*plut)!=nullptr) {
|
|
for (int l=0; l<=JKQTFPimagePlot_LUTSIZE; l++) {
|
|
double v=l/static_cast<double>(JKQTFPimagePlot_LUTSIZE);
|
|
double r = (v < 0.5) ? 128.0*sin(M_PI*(2.0*v-0.5))+128.0 : 255.0;
|
|
if (r > 255.0)
|
|
r = 255.0;
|
|
|
|
double g = (v < 0.5) ? 512.0*v+128.0 : 512.0-512.0*v;
|
|
if (g > 255.0)
|
|
g = 255.0;
|
|
(*plut)[l]=qRgb(static_cast<int>(r), static_cast<int>(g), 0);
|
|
}
|
|
}
|
|
}
|
|
lut_used=(*plut);
|
|
|
|
}
|
|
|
|
#ifdef DEBUG_TIMING
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" calculated/found LUT: "<<time_gt/1000.0<<" ms\n";
|
|
timer.start();
|
|
#endif
|
|
if (lut_used!=nullptr) {
|
|
// LUT found: collor the image accordingly
|
|
for (register int j=0; j<height; ++j) {
|
|
QRgb* line=(QRgb*)(img.scanLine(height-1-j));
|
|
for (register int i=0; i<width; ++i) {
|
|
int v = (dbl[j*width+i]-min)/delta*JKQTFPimagePlot_LUTSIZE;
|
|
v = (v < 0) ? 0 : ( (v > JKQTFPimagePlot_LUTSIZE) ? JKQTFPimagePlot_LUTSIZE : v);
|
|
line[i]=lut_used[v];
|
|
}
|
|
}
|
|
} else {
|
|
// no LUT found: paint a black image!
|
|
img.fill(0);
|
|
}
|
|
}
|
|
#ifdef DEBUG_TIMING
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" creating colored image: "<<time_gt/1000.0<<" ms\n";
|
|
timer.start();
|
|
#endif
|
|
#ifdef DEBUG_TIMING
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" sum: "<<time_sum/1000.0<<" ms\n";
|
|
timer.start();
|
|
#endif
|
|
};
|
|
|
|
/*! \brief get list with all available palettes
|
|
\ingroup jkqtfastplotter
|
|
\see JKQTFPimagePlot_array2image()
|
|
*/
|
|
LIB_EXPORT QStringList JKQTFPimagePlot_getPalettes();
|
|
/*! \brief get QIcon representing the given palette
|
|
\ingroup jkqtfastplotter
|
|
\see JKQTFPimagePlot_array2image()
|
|
*/
|
|
LIB_EXPORT QIcon JKQTFPimagePlot_getPaletteIcon(int i);
|
|
/*! \brief get QIcon representing the given palette
|
|
\ingroup jkqtfastplotter
|
|
\see JKQTFPimagePlot_array2image()
|
|
*/
|
|
LIB_EXPORT QIcon JKQTFPimagePlot_getPaletteIcon(JKQTFPColorPalette palette);
|
|
|
|
|
|
/*! \brief plots a given grayscale image with a given color palette
|
|
\ingroup jkqtfastplotter
|
|
|
|
- This plot may plot any 2D array of data (8-, 16-, 32-bit integer images, float and double).
|
|
- This class also draws a color bar in the right border of the plot
|
|
.
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPimagePlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief image to plot */
|
|
void* image;
|
|
/** \brief format of the image */
|
|
JKQTFPImageFormat imageFormat;
|
|
/** \brief width of image in pixels */
|
|
unsigned int width;
|
|
/** \brief height of image in pixels */
|
|
unsigned int height;
|
|
/** \brief minimum x value of the image */
|
|
double xmin;
|
|
/** \brief maximum x value of the image */
|
|
double xmax;
|
|
/** \brief minimum x value of the image */
|
|
double ymin;
|
|
/** \brief maximum x value of the image */
|
|
double ymax;
|
|
/** \brief defines the palette to use */
|
|
JKQTFPColorPalette palette;
|
|
/** \brief defines minimum color value */
|
|
double colorMin;
|
|
/** \brief defines maximum color value */
|
|
double colorMax;
|
|
/** \brief draw color bar */
|
|
bool drawColorBar;
|
|
/** \brief color bar width in pixels */
|
|
int colorBarWidth;
|
|
/** \brief rotation of the image when plotting in units of 90 degrees (counter clock wise) */
|
|
int rotation;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
*/
|
|
JKQTFPimagePlot(JKQTFastPlotter* parent, void* image, JKQTFPImageFormat imageFormat, unsigned int width, unsigned int height, double xmin, double xmax, double ymin, double ymax, JKQTFPColorPalette palette=JKQTFP_MATLAB) ;
|
|
|
|
JKQTFPimagePlot(JKQTFastPlotter* parent, void* image, JKQTFPImageFormat imageFormat, unsigned int width, unsigned int height, JKQTFPColorPalette palette=JKQTFP_MATLAB);
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
|
|
|
|
/*! \brief sets the property image to the specified \a __value.
|
|
\details Description of the parameter image is: <CENTER>\copybrief image.</CENTER>
|
|
\see image for more information */
|
|
inline virtual void set_image(void* __value)
|
|
{
|
|
if (this->image != __value) {
|
|
this->image = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property image.
|
|
\details Description of the parameter image is: <CENTER>\copybrief image.</CENTER>
|
|
\see image for more information */
|
|
inline virtual void* get_image() const
|
|
{
|
|
return this->image;
|
|
}
|
|
/*! \brief sets the property imageFormat to the specified \a __value.
|
|
\details Description of the parameter imageFormat is: <CENTER>\copybrief imageFormat.</CENTER>
|
|
\see imageFormat for more information */
|
|
inline virtual void set_imageFormat(const JKQTFPImageFormat & __value)
|
|
{
|
|
if (this->imageFormat != __value) {
|
|
this->imageFormat = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property imageFormat.
|
|
\details Description of the parameter imageFormat is: <CENTER>\copybrief imageFormat.</CENTER>
|
|
\see imageFormat for more information */
|
|
inline virtual JKQTFPImageFormat get_imageFormat() const
|
|
{
|
|
return this->imageFormat;
|
|
}
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(const unsigned int & __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual unsigned int get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief sets the property height to the specified \a __value.
|
|
\details Description of the parameter height is: <CENTER>\copybrief height.</CENTER>
|
|
\see height for more information */
|
|
inline virtual void set_height(const unsigned int & __value)
|
|
{
|
|
if (this->height != __value) {
|
|
this->height = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property height.
|
|
\details Description of the parameter height is: <CENTER>\copybrief height.</CENTER>
|
|
\see height for more information */
|
|
inline virtual unsigned int get_height() const
|
|
{
|
|
return this->height;
|
|
}
|
|
/*! \brief sets the property xmin to the specified \a __value.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual void set_xmin(double __value)
|
|
{
|
|
if (this->xmin != __value) {
|
|
this->xmin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmin.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual double get_xmin() const
|
|
{
|
|
return this->xmin;
|
|
}
|
|
/*! \brief sets the property xmax to the specified \a __value.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual void set_xmax(double __value)
|
|
{
|
|
if (this->xmax != __value) {
|
|
this->xmax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmax.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual double get_xmax() const
|
|
{
|
|
return this->xmax;
|
|
}
|
|
/*! \brief sets the property ymin to the specified \a __value.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual void set_ymin(double __value)
|
|
{
|
|
if (this->ymin != __value) {
|
|
this->ymin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymin.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual double get_ymin() const
|
|
{
|
|
return this->ymin;
|
|
}
|
|
/*! \brief sets the property ymax to the specified \a __value.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual void set_ymax(double __value)
|
|
{
|
|
if (this->ymax != __value) {
|
|
this->ymax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymax.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual double get_ymax() const
|
|
{
|
|
return this->ymax;
|
|
}
|
|
/*! \brief sets the property drawColorBar to the specified \a __value.
|
|
\details Description of the parameter drawColorBar is: <CENTER>\copybrief drawColorBar.</CENTER>
|
|
\see drawColorBar for more information */
|
|
inline virtual void set_drawColorBar(bool __value)
|
|
{
|
|
if (this->drawColorBar != __value) {
|
|
this->drawColorBar = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property drawColorBar.
|
|
\details Description of the parameter drawColorBar is: <CENTER>\copybrief drawColorBar.</CENTER>
|
|
\see drawColorBar for more information */
|
|
inline virtual bool get_drawColorBar() const
|
|
{
|
|
return this->drawColorBar;
|
|
}
|
|
/*! \brief sets the property colorBarWidth to the specified \a __value.
|
|
\details Description of the parameter colorBarWidth is: <CENTER>\copybrief colorBarWidth.</CENTER>
|
|
\see colorBarWidth for more information */
|
|
inline virtual void set_colorBarWidth(int __value)
|
|
{
|
|
if (this->colorBarWidth != __value) {
|
|
this->colorBarWidth = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property colorBarWidth.
|
|
\details Description of the parameter colorBarWidth is: <CENTER>\copybrief colorBarWidth.</CENTER>
|
|
\see colorBarWidth for more information */
|
|
inline virtual int get_colorBarWidth() const
|
|
{
|
|
return this->colorBarWidth;
|
|
}
|
|
/*! \brief returns the property rotation.
|
|
\details Description of the parameter rotation is: <CENTER>\copybrief rotation.</CENTER>.
|
|
\see rotation for more information */
|
|
inline int get_rotation() const {
|
|
return this->rotation;
|
|
}
|
|
/*! \brief returns the property palette.
|
|
\details Description of the parameter palette is: <CENTER>\copybrief palette.</CENTER>.
|
|
\see palette for more information */
|
|
inline JKQTFPColorPalette get_palette() const {
|
|
return this->palette;
|
|
}
|
|
/*! \brief returns the property colorMin.
|
|
\details Description of the parameter colorMin is: <CENTER>\copybrief colorMin.</CENTER>.
|
|
\see colorMin for more information */
|
|
inline double get_colorMin() const {
|
|
return this->colorMin;
|
|
}
|
|
/*! \brief returns the property colorMax.
|
|
\details Description of the parameter colorMax is: <CENTER>\copybrief colorMax.</CENTER>.
|
|
\see colorMax for more information */
|
|
inline double get_colorMax() const {
|
|
return this->colorMax;
|
|
}
|
|
void set_image(void* image, JKQTFPImageFormat imageFormat, unsigned int width, unsigned int height) {
|
|
this->image=image;
|
|
this->imageFormat=imageFormat;
|
|
this->width=width;
|
|
this->height=height;
|
|
replot();
|
|
}
|
|
public slots:
|
|
void set_rotation(int rotation) {
|
|
if (this->rotation!=rotation) {
|
|
this->rotation=(JKQTFPColorPalette)rotation;
|
|
replot();
|
|
}
|
|
}
|
|
void set_palette(int palette) {
|
|
if (this->palette!=palette) {
|
|
this->palette=(JKQTFPColorPalette)palette;
|
|
replot();
|
|
}
|
|
};
|
|
void set_palette(JKQTFPColorPalette palette) {
|
|
if (this->palette!=palette) {
|
|
this->palette=palette;
|
|
replot();
|
|
}
|
|
};
|
|
void set_colorMin(uint32_t colorMin) {
|
|
if (this->colorMin!=colorMin) {
|
|
this-> colorMin= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_colorMax(uint32_t colorMax) {
|
|
if (this->colorMax!=colorMax) {
|
|
this->colorMax=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
void set_colorMin(int colorMin) {
|
|
if (this->colorMin!=colorMin) {
|
|
this-> colorMin= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_colorMax(int colorMax) {
|
|
if (this->colorMax!=colorMax) {
|
|
this->colorMax=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
void set_colorMin(double colorMin) {
|
|
if (this->colorMin!=colorMin) {
|
|
this-> colorMin= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
void set_colorMax(double colorMax) {
|
|
if (this->colorMax!=colorMax) {
|
|
this->colorMax=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*! \brief convert a 2D image (as 1D array) into a QImage and puts the image values into one color channel (set by \a channel).
|
|
\ingroup jkqtfastplotter
|
|
|
|
*/
|
|
template <class T>
|
|
inline void JKQTFPRGBImageOverlayPlot_array2image(T* dbl, int width, int height, QImage &img, int channel, T minColor, T maxColor)
|
|
{
|
|
if (!dbl)
|
|
return;
|
|
|
|
#ifdef DEBUG_TIMING
|
|
JKQTPHighResTimer timer;
|
|
double time_sum=0;
|
|
double time_gt=0;
|
|
std::cout<<" timing JKQTFPimagePlot_array2image:\n";
|
|
timer.start();
|
|
#endif
|
|
//qDebug()<<"channel = "<<channel;
|
|
//qDebug()<<"color range: "<<minColor<<"..."<<maxColor;
|
|
double min = *dbl;
|
|
double max = *dbl;
|
|
if (minColor == maxColor) {
|
|
for (int i=1; i<width*height; ++i)
|
|
{
|
|
register T v=dbl[i];
|
|
if (v < min)
|
|
min = v;
|
|
else if (v > max)
|
|
max = v;
|
|
}
|
|
} else {
|
|
min = minColor;
|
|
max = maxColor;
|
|
}
|
|
#ifdef DEBUG_TIMING
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" finding min&max: "<<time_gt/1000.0<<" ms\n";
|
|
timer.start();
|
|
#endif
|
|
//qDebug()<<"minColor="<<minColor<<" maxColor="<<maxColor<<" min="<<min<<" max="<<max<<"\n";
|
|
|
|
double delta=max-min;
|
|
|
|
|
|
if (min != max) {
|
|
// LUT found: collor the image accordingly
|
|
if (channel==0) {
|
|
for (register int j=0; j<height; ++j) {
|
|
QRgb* line=(QRgb*)(img.scanLine(height-1-j));
|
|
for (register int i=0; i<width; ++i) {
|
|
int v = trunc(double(dbl[j*width+i]-min)*255.0/delta);
|
|
v = (v < 0) ? 0 : ( (v > 255) ? 255 : v);
|
|
const register QRgb l=line[i];
|
|
line[i]=qRgb(v,qGreen(l),qBlue(l));
|
|
//if (i==j) qDebug()<<dbl[j*width+i]<<v<<hex<<l<<line[i]<<dec;
|
|
}
|
|
}
|
|
} else if (channel==1) {
|
|
for (register int j=0; j<height; ++j) {
|
|
QRgb* line=(QRgb*)(img.scanLine(height-1-j));
|
|
for (register int i=0; i<width; ++i) {
|
|
int v = (dbl[j*width+i]-min)*255/delta;
|
|
v = (v < 0) ? 0 : ( (v > 255) ? 255 : v);
|
|
const register QRgb l=line[i];
|
|
line[i]=qRgb(qRed(l),v,qBlue(l));
|
|
//if (i==j) qDebug()<<dbl[j*width+i]<<v<<hex<<l<<line[i]<<dec;
|
|
}
|
|
}
|
|
} else if (channel==2) {
|
|
for (register int j=0; j<height; ++j) {
|
|
QRgb* line=(QRgb*)(img.scanLine(height-1-j));
|
|
for (register int i=0; i<width; ++i) {
|
|
int v = (dbl[j*width+i]-min)*255/delta;
|
|
v = (v < 0) ? 0 : ( (v > 255) ? 255 : v);
|
|
const register QRgb l=line[i];
|
|
line[i]=qRgb(qRed(l),qGreen(l),v);
|
|
//if (i==j) qDebug()<<dbl[j*width+i]<<v<<hex<<l<<line[i]<<dec;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
#ifdef DEBUG_TIMING
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" creating colored image: "<<time_gt/1000.0<<" ms\n";
|
|
timer.start();
|
|
|
|
time_gt=timer.get_time();
|
|
time_sum+=time_gt;
|
|
std::cout<<" sum: "<<time_sum/1000.0<<" ms\n";
|
|
timer.start();
|
|
#endif
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*! \brief plots 1,2 or 3 given grayscale images as an overlay plot, where each channel is drawn as one color channel (e.g. red, green or blue).
|
|
\ingroup jkqtfastplotter
|
|
|
|
- This plot may plot any 2D array of data (8-, 16-, 32-bit integer images, float and double).
|
|
- The images all have to have the same size
|
|
.
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPRGBImageOverlayPlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
protected:
|
|
/** \brief image to plot */
|
|
void* imageRed;
|
|
/** \brief format of the image */
|
|
JKQTFPImageFormat imageFormatRed;
|
|
/** \brief image to plot */
|
|
void* imageGreen;
|
|
/** \brief format of the image */
|
|
JKQTFPImageFormat imageFormatGreen;
|
|
/** \brief image to plot */
|
|
void* imageBlue;
|
|
/** \brief format of the image */
|
|
JKQTFPImageFormat imageFormatBlue;
|
|
/** \brief width of image in pixels */
|
|
unsigned int width;
|
|
/** \brief height of image in pixels */
|
|
unsigned int height;
|
|
/** \brief minimum x value of the image */
|
|
double xmin;
|
|
/** \brief maximum x value of the image */
|
|
double xmax;
|
|
/** \brief minimum x value of the image */
|
|
double ymin;
|
|
/** \brief maximum x value of the image */
|
|
double ymax;
|
|
/** \brief defines minimum color value */
|
|
double colorMinRed;
|
|
/** \brief defines maximum color value */
|
|
double colorMaxRed;
|
|
/** \brief defines minimum color value */
|
|
double colorMinGreen;
|
|
/** \brief defines maximum color value */
|
|
double colorMaxGreen;
|
|
/** \brief defines minimum color value */
|
|
double colorMinBlue;
|
|
/** \brief defines maximum color value */
|
|
double colorMaxBlue;
|
|
/** \brief rotation of the image when plotting in units of 90 degrees (counter clock wise) */
|
|
int rotation;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
*/
|
|
JKQTFPRGBImageOverlayPlot(JKQTFastPlotter* parent, void* imageRed, JKQTFPImageFormat imageFormat, unsigned int width, unsigned int height, double xmin, double xmax, double ymin, double ymax) ;
|
|
JKQTFPRGBImageOverlayPlot(JKQTFastPlotter* parent, void* imageRed, JKQTFPImageFormat imageFormat, unsigned int width, unsigned int height);
|
|
JKQTFPRGBImageOverlayPlot(JKQTFastPlotter* parent);
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
|
|
|
|
/*! \brief sets the properties imageRed and imageFormatRed to the specified \a __value and \a __value2.
|
|
\details Description of the parameter imageRed is: <CENTER>\copybrief imageRed.</CENTER> \details Description of the parameter imageFormatRed is: <CENTER>\copybrief imageFormatRed.</CENTER>
|
|
\see imageRed and imageFormatRed for more information */
|
|
inline virtual void set_imageRed (void* __value, JKQTFPImageFormat __value2)
|
|
{
|
|
bool set=false;
|
|
if (this->imageRed != __value) {
|
|
this->imageRed = __value;
|
|
set=true;
|
|
}
|
|
if (this->imageFormatRed != __value2) {
|
|
this->imageFormatRed = __value2;
|
|
set=true;
|
|
}
|
|
if (set) {
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property imageRed.
|
|
\details Description of the parameter imageRed is: <CENTER>\copybrief imageRed.</CENTER> \details Description of the parameter imageFormatRed is: <CENTER>\copybrief imageFormatRed.</CENTER>
|
|
\see imageRed for more information */
|
|
inline virtual void* get_imageRed () const { return this->imageRed; }
|
|
/*! \brief returns the property imageFormatRed.
|
|
\details Description of the parameter imageRed is: <CENTER>\copybrief imageRed.</CENTER> \details Description of the parameter imageFormatRed is: <CENTER>\copybrief imageFormatRed.</CENTER>
|
|
\see imageFormatRed for more information */
|
|
inline virtual JKQTFPImageFormat get_imageFormatRed () const { return this->imageFormatRed; }
|
|
/*! \brief sets the properties imageGreen and imageFormatGreen to the specified \a __value and \a __value2.
|
|
\details Description of the parameter imageGreen is: <CENTER>\copybrief imageGreen.</CENTER> \details Description of the parameter imageFormatGreen is: <CENTER>\copybrief imageFormatGreen.</CENTER>
|
|
\see imageGreen and imageFormatGreen for more information */
|
|
inline virtual void set_imageGreen (void* __value, JKQTFPImageFormat __value2)
|
|
{
|
|
bool set=false;
|
|
if (this->imageGreen != __value) {
|
|
this->imageGreen = __value;
|
|
set=true;
|
|
}
|
|
if (this->imageFormatGreen != __value2) {
|
|
this->imageFormatGreen = __value2;
|
|
set=true;
|
|
}
|
|
if (set) {
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property imageGreen.
|
|
\details Description of the parameter imageGreen is: <CENTER>\copybrief imageGreen.</CENTER> \details Description of the parameter imageFormatGreen is: <CENTER>\copybrief imageFormatGreen.</CENTER>
|
|
\see imageGreen for more information */
|
|
inline virtual void* get_imageGreen () const { return this->imageGreen; }
|
|
/*! \brief returns the property imageFormatGreen.
|
|
\details Description of the parameter imageGreen is: <CENTER>\copybrief imageGreen.</CENTER> \details Description of the parameter imageFormatGreen is: <CENTER>\copybrief imageFormatGreen.</CENTER>
|
|
\see imageFormatGreen for more information */
|
|
inline virtual JKQTFPImageFormat get_imageFormatGreen () const { return this->imageFormatGreen; }
|
|
/*! \brief sets the properties imageBlue and imageFormatBlue to the specified \a __value and \a __value2.
|
|
\details Description of the parameter imageBlue is: <CENTER>\copybrief imageBlue.</CENTER> \details Description of the parameter imageFormatBlue is: <CENTER>\copybrief imageFormatBlue.</CENTER>
|
|
\see imageBlue and imageFormatBlue for more information */
|
|
inline virtual void set_imageBlue (void* __value, JKQTFPImageFormat __value2)
|
|
{
|
|
bool set=false;
|
|
if (this->imageBlue != __value) {
|
|
this->imageBlue = __value;
|
|
set=true;
|
|
}
|
|
if (this->imageFormatBlue != __value2) {
|
|
this->imageFormatBlue = __value2;
|
|
set=true;
|
|
}
|
|
if (set) {
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property imageBlue.
|
|
\details Description of the parameter imageBlue is: <CENTER>\copybrief imageBlue.</CENTER> \details Description of the parameter imageFormatBlue is: <CENTER>\copybrief imageFormatBlue.</CENTER>
|
|
\see imageBlue for more information */
|
|
inline virtual void* get_imageBlue () const { return this->imageBlue; }
|
|
/*! \brief returns the property imageFormatBlue.
|
|
\details Description of the parameter imageBlue is: <CENTER>\copybrief imageBlue.</CENTER> \details Description of the parameter imageFormatBlue is: <CENTER>\copybrief imageFormatBlue.</CENTER>
|
|
\see imageFormatBlue for more information */
|
|
inline virtual JKQTFPImageFormat get_imageFormatBlue () const { return this->imageFormatBlue; }
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(const unsigned int & __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual unsigned int get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief sets the property height to the specified \a __value.
|
|
\details Description of the parameter height is: <CENTER>\copybrief height.</CENTER>
|
|
\see height for more information */
|
|
inline virtual void set_height(const unsigned int & __value)
|
|
{
|
|
if (this->height != __value) {
|
|
this->height = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property height.
|
|
\details Description of the parameter height is: <CENTER>\copybrief height.</CENTER>
|
|
\see height for more information */
|
|
inline virtual unsigned int get_height() const
|
|
{
|
|
return this->height;
|
|
}
|
|
/*! \brief sets the property xmin to the specified \a __value.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual void set_xmin(double __value)
|
|
{
|
|
if (this->xmin != __value) {
|
|
this->xmin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmin.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual double get_xmin() const
|
|
{
|
|
return this->xmin;
|
|
}
|
|
/*! \brief sets the property xmax to the specified \a __value.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual void set_xmax(double __value)
|
|
{
|
|
if (this->xmax != __value) {
|
|
this->xmax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmax.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual double get_xmax() const
|
|
{
|
|
return this->xmax;
|
|
}
|
|
/*! \brief sets the property ymin to the specified \a __value.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual void set_ymin(double __value)
|
|
{
|
|
if (this->ymin != __value) {
|
|
this->ymin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymin.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual double get_ymin() const
|
|
{
|
|
return this->ymin;
|
|
}
|
|
/*! \brief sets the property ymax to the specified \a __value.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual void set_ymax(double __value)
|
|
{
|
|
if (this->ymax != __value) {
|
|
this->ymax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymax.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual double get_ymax() const
|
|
{
|
|
return this->ymax;
|
|
}
|
|
/*! \brief returns the property rotation.
|
|
\details Description of the parameter rotation is: <CENTER>\copybrief rotation.</CENTER>.
|
|
\see rotation for more information */
|
|
inline int get_rotation() const {
|
|
return this->rotation;
|
|
}
|
|
/*! \brief returns the property colorMinRed.
|
|
\details Description of the parameter colorMinRed is: <CENTER>\copybrief colorMinRed.</CENTER>.
|
|
\see colorMinRed for more information */
|
|
inline double get_colorMinRed() const {
|
|
return this->colorMinRed;
|
|
}
|
|
/*! \brief returns the property colorMaxRed.
|
|
\details Description of the parameter colorMaxRed is: <CENTER>\copybrief colorMaxRed.</CENTER>.
|
|
\see colorMaxRed for more information */
|
|
inline double get_colorMaxRed() const {
|
|
return this->colorMaxRed;
|
|
}
|
|
/*! \brief returns the property colorMinGreen.
|
|
\details Description of the parameter colorMinGreen is: <CENTER>\copybrief colorMinGreen.</CENTER>.
|
|
\see colorMinGreen for more information */
|
|
inline double get_colorMinGreen() const {
|
|
return this->colorMinGreen;
|
|
}
|
|
/*! \brief returns the property colorMaxGreen.
|
|
\details Description of the parameter colorMaxGreen is: <CENTER>\copybrief colorMaxGreen.</CENTER>.
|
|
\see colorMaxGreen for more information */
|
|
inline double get_colorMaxGreen() const {
|
|
return this->colorMaxGreen;
|
|
}
|
|
/*! \brief returns the property colorMinBlue.
|
|
\details Description of the parameter colorMinBlue is: <CENTER>\copybrief colorMinBlue.</CENTER>.
|
|
\see colorMinBlue for more information */
|
|
inline double get_colorMinBlue() const {
|
|
return this->colorMinBlue;
|
|
}
|
|
/*! \brief returns the property colorMaxBlue.
|
|
\details Description of the parameter colorMaxBlue is: <CENTER>\copybrief colorMaxBlue.</CENTER>.
|
|
\see colorMaxBlue for more information */
|
|
inline double get_colorMaxBlue() const {
|
|
return this->colorMaxBlue;
|
|
}
|
|
void set_image(void* imageRed, JKQTFPImageFormat imageFormatRed, unsigned int width, unsigned int height);
|
|
void set_image(void* imageRed, JKQTFPImageFormat imageFormatRed, void* imageGreen, JKQTFPImageFormat imageFormatGreen, unsigned int width, unsigned int height);
|
|
void set_image(void* imageRed, JKQTFPImageFormat imageFormatRed, void* imageGreen, JKQTFPImageFormat imageFormatGreen, void* imageBlue, JKQTFPImageFormat imageFormatBlue, unsigned int width, unsigned int height);
|
|
void set_image(void* imageRed, JKQTFPImageFormat imageFormatRed, unsigned int width, unsigned int height, double xmin, double xmax, double ymin, double ymax);
|
|
void set_image(void* imageRed, JKQTFPImageFormat imageFormatRed, void* imageGreen, JKQTFPImageFormat imageFormatGreen, unsigned int width, unsigned int height, double xmin, double xmax, double ymin, double ymax);
|
|
void set_image(void* imageRed, JKQTFPImageFormat imageFormatRed, void* imageGreen, JKQTFPImageFormat imageFormatGreen, void* imageBlue, JKQTFPImageFormat imageFormatBlue, unsigned int width, unsigned int height, double xmin, double xmax, double ymin, double ymax);
|
|
public slots:
|
|
inline void set_rotation(int rotation) {
|
|
if (this->rotation!=rotation) {
|
|
this->rotation=(JKQTFPColorPalette)rotation;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinRed(uint32_t colorMin) {
|
|
if (this->colorMinRed!=colorMin) {
|
|
this-> colorMinRed= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxRed(uint32_t colorMax) {
|
|
if (this->colorMaxRed!=colorMax) {
|
|
this->colorMaxRed=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinRed(int colorMin) {
|
|
if (this->colorMinRed!=colorMin) {
|
|
this-> colorMinRed= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxRed(int colorMax) {
|
|
if (this->colorMaxRed!=colorMax) {
|
|
this->colorMaxRed=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinRed(double colorMin) {
|
|
if (this->colorMinRed!=colorMin) {
|
|
this-> colorMinRed= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxRed(double colorMax) {
|
|
if (this->colorMaxRed!=colorMax) {
|
|
this->colorMaxRed=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
|
|
|
|
inline void set_colorMinGreen(uint32_t colorMin) {
|
|
if (this->colorMinGreen!=colorMin) {
|
|
this-> colorMinGreen= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxGreen(uint32_t colorMax) {
|
|
if (this->colorMaxGreen!=colorMax) {
|
|
this->colorMaxGreen=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinGreen(int colorMin) {
|
|
if (this->colorMinGreen!=colorMin) {
|
|
this-> colorMinGreen= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxGreen(int colorMax) {
|
|
if (this->colorMaxGreen!=colorMax) {
|
|
this->colorMaxGreen=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinGreen(double colorMin) {
|
|
if (this->colorMinGreen!=colorMin) {
|
|
this-> colorMinGreen= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxGreen(double colorMax) {
|
|
if (this->colorMaxGreen!=colorMax) {
|
|
this->colorMaxGreen=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
|
|
inline void set_colorMinBlue(uint32_t colorMin) {
|
|
if (this->colorMinBlue!=colorMin) {
|
|
this-> colorMinBlue= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxBlue(uint32_t colorMax) {
|
|
if (this->colorMaxBlue!=colorMax) {
|
|
this->colorMaxBlue=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinBlue(int colorMin) {
|
|
if (this->colorMinBlue!=colorMin) {
|
|
this-> colorMinBlue= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxBlue(int colorMax) {
|
|
if (this->colorMaxBlue!=colorMax) {
|
|
this->colorMaxBlue=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMinBlue(double colorMin) {
|
|
if (this->colorMinBlue!=colorMin) {
|
|
this-> colorMinBlue= colorMin;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_colorMaxBlue(double colorMax) {
|
|
if (this->colorMaxBlue!=colorMax) {
|
|
this->colorMaxBlue=colorMax;
|
|
replot();
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
|
|
/*! \brief plots an image overlay, i.e. a boolean image where each \c true pixel is drawn with a given color
|
|
and the \c false pixels are transparent
|
|
\ingroup jkqtfastplotter
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPimageOverlayPlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
public:
|
|
enum SymbolType {
|
|
stCircle,
|
|
stRectangle
|
|
};
|
|
|
|
protected:
|
|
/** \brief image to plot */
|
|
bool* image;
|
|
/** \brief width of image in pixels */
|
|
unsigned int width;
|
|
/** \brief height of image in pixels */
|
|
unsigned int height;
|
|
/** \brief minimum x value of the image */
|
|
double xmin;
|
|
/** \brief maximum x value of the image */
|
|
double xmax;
|
|
/** \brief minimum x value of the image */
|
|
double ymin;
|
|
/** \brief maximum x value of the image */
|
|
double ymax;
|
|
/** \brief color of the overlay pixels */
|
|
QColor color;
|
|
/** \brief linewidth of symbols */
|
|
double linewidth;
|
|
/** \brief rotation of the image when plotting in units of 90 degrees */
|
|
int rotation;
|
|
SymbolType symboltype;
|
|
bool showAsSymbols;
|
|
public:
|
|
/*! \brief class constructor
|
|
|
|
*/
|
|
JKQTFPimageOverlayPlot(JKQTFastPlotter* parent, bool* image, unsigned int width, unsigned int height, double xmin, double xmax, double ymin, double ymax, QColor color=QColor("red"));
|
|
|
|
JKQTFPimageOverlayPlot(JKQTFastPlotter* parent, bool* image, unsigned int width, unsigned int height, QColor color=QColor("red"));
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
void set_data(bool* image, unsigned int width, unsigned int height) {
|
|
this->image=image;
|
|
this->width=width;
|
|
this->height=height;
|
|
replot();
|
|
}
|
|
|
|
/*! \brief returns the property image.
|
|
\details Description of the parameter image is: <CENTER>\copybrief image.</CENTER>.
|
|
\see image for more information */
|
|
inline bool* get_image() const {
|
|
return this->image;
|
|
}
|
|
/*! \brief returns the property rotation.
|
|
\details Description of the parameter rotation is: <CENTER>\copybrief rotation.</CENTER>.
|
|
\see rotation for more information */
|
|
inline int get_rotation() const {
|
|
return this->rotation;
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>.
|
|
\see width for more information */
|
|
inline unsigned int get_width() const {
|
|
return this->width;
|
|
}
|
|
/*! \brief returns the property height.
|
|
\details Description of the parameter height is: <CENTER>\copybrief height.</CENTER>.
|
|
\see height for more information */
|
|
inline unsigned int get_height() const {
|
|
return this->height;
|
|
}
|
|
/*! \brief sets the property xmin to the specified \a __value.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual void set_xmin(double __value)
|
|
{
|
|
if (this->xmin != __value) {
|
|
this->xmin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmin.
|
|
\details Description of the parameter xmin is: <CENTER>\copybrief xmin.</CENTER>
|
|
\see xmin for more information */
|
|
inline virtual double get_xmin() const
|
|
{
|
|
return this->xmin;
|
|
}
|
|
/*! \brief sets the property xmax to the specified \a __value.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual void set_xmax(double __value)
|
|
{
|
|
if (this->xmax != __value) {
|
|
this->xmax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property xmax.
|
|
\details Description of the parameter xmax is: <CENTER>\copybrief xmax.</CENTER>
|
|
\see xmax for more information */
|
|
inline virtual double get_xmax() const
|
|
{
|
|
return this->xmax;
|
|
}
|
|
/*! \brief sets the property ymin to the specified \a __value.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual void set_ymin(double __value)
|
|
{
|
|
if (this->ymin != __value) {
|
|
this->ymin = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymin.
|
|
\details Description of the parameter ymin is: <CENTER>\copybrief ymin.</CENTER>
|
|
\see ymin for more information */
|
|
inline virtual double get_ymin() const
|
|
{
|
|
return this->ymin;
|
|
}
|
|
/*! \brief sets the property ymax to the specified \a __value.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual void set_ymax(double __value)
|
|
{
|
|
if (this->ymax != __value) {
|
|
this->ymax = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property ymax.
|
|
\details Description of the parameter ymax is: <CENTER>\copybrief ymax.</CENTER>
|
|
\see ymax for more information */
|
|
inline virtual double get_ymax() const
|
|
{
|
|
return this->ymax;
|
|
}
|
|
/*! \brief sets the property showAsSymbols to the specified \a __value.
|
|
\details Description of the parameter showAsSymbols is: <CENTER>\copybrief showAsSymbols.</CENTER>
|
|
\see showAsSymbols for more information */
|
|
inline virtual void set_showAsSymbols(bool __value)
|
|
{
|
|
if (this->showAsSymbols != __value) {
|
|
this->showAsSymbols = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property showAsSymbols.
|
|
\details Description of the parameter showAsSymbols is: <CENTER>\copybrief showAsSymbols.</CENTER>
|
|
\see showAsSymbols for more information */
|
|
inline virtual bool get_showAsSymbols() const
|
|
{
|
|
return this->showAsSymbols;
|
|
}
|
|
/*! \brief returns the property color.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>.
|
|
\see color for more information */
|
|
inline QColor get_color() const {
|
|
return this->color;
|
|
}
|
|
public slots:
|
|
inline void set_rotation(int rotation) {
|
|
if (this->rotation!=rotation) {
|
|
this->rotation=(JKQTFPColorPalette)rotation;
|
|
replot();
|
|
}
|
|
}
|
|
inline void set_color(QColor color) {
|
|
if (this->color!=color) {
|
|
this->color=color;
|
|
replot();
|
|
}
|
|
};
|
|
};
|
|
|
|
|
|
|
|
/*! \brief plot a horizontal scale bar
|
|
\ingroup jkqtfastplotter
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPQScaleBarXPlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
public:
|
|
enum Position {
|
|
TopLeft=0,
|
|
TopRight=1,
|
|
BottomLeft=2,
|
|
BottomRight=3
|
|
};
|
|
protected:
|
|
/** \brief width of scale bar */
|
|
double width;
|
|
/** \brief line width of scale bar */
|
|
double lineWidth;
|
|
/** \brief color of scale bar */
|
|
QColor color;
|
|
/** \brief scale bar label (use %1 to include value of width) */
|
|
QString label;
|
|
/** \brief font of scale bar */
|
|
QFont font;
|
|
/** \brief scale bar position */
|
|
Position position;
|
|
|
|
public:
|
|
|
|
/*! \brief class constructor
|
|
|
|
*/
|
|
JKQTFPQScaleBarXPlot(JKQTFastPlotter* parent, double width=1, const QString& label=QString("%1"), QColor color=QColor("grey"), double lineWidth=2) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(double __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual double get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief sets the property lineWidth to the specified \a __value.
|
|
\details Description of the parameter lineWidth is: <CENTER>\copybrief lineWidth.</CENTER>
|
|
\see lineWidth for more information */
|
|
inline virtual void set_lineWidth(double __value)
|
|
{
|
|
if (this->lineWidth != __value) {
|
|
this->lineWidth = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property lineWidth.
|
|
\details Description of the parameter lineWidth is: <CENTER>\copybrief lineWidth.</CENTER>
|
|
\see lineWidth for more information */
|
|
inline virtual double get_lineWidth() const
|
|
{
|
|
return this->lineWidth;
|
|
}
|
|
/*! \brief sets the property color to the specified \a __value.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual void set_color(const QColor & __value)
|
|
{
|
|
if (this->color != __value) {
|
|
this->color = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property color.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual QColor get_color() const
|
|
{
|
|
return this->color;
|
|
}
|
|
/*! \brief sets the property label to the specified \a __value.
|
|
\details Description of the parameter label is: <CENTER>\copybrief label.</CENTER>
|
|
\see label for more information */
|
|
inline virtual void set_label(const QString & __value)
|
|
{
|
|
if (this->label != __value) {
|
|
this->label = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property label.
|
|
\details Description of the parameter label is: <CENTER>\copybrief label.</CENTER>
|
|
\see label for more information */
|
|
inline virtual QString get_label() const
|
|
{
|
|
return this->label;
|
|
}
|
|
/*! \brief sets the property font to the specified \a __value.
|
|
\details Description of the parameter font is: <CENTER>\copybrief font.</CENTER>
|
|
\see font for more information */
|
|
inline virtual void set_font(const QFont & __value)
|
|
{
|
|
if (this->font != __value) {
|
|
this->font = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property font.
|
|
\details Description of the parameter font is: <CENTER>\copybrief font.</CENTER>
|
|
\see font for more information */
|
|
inline virtual QFont get_font() const
|
|
{
|
|
return this->font;
|
|
}
|
|
/*! \brief sets the property position to the specified \a __value.
|
|
\details Description of the parameter position is: <CENTER>\copybrief position.</CENTER>
|
|
\see position for more information */
|
|
inline virtual void set_position(const Position & __value)
|
|
{
|
|
if (this->position != __value) {
|
|
this->position = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property position.
|
|
\details Description of the parameter position is: <CENTER>\copybrief position.</CENTER>
|
|
\see position for more information */
|
|
inline virtual Position get_position() const
|
|
{
|
|
return this->position;
|
|
}
|
|
public slots:
|
|
void set_position(int pos) {
|
|
set_position((Position)pos);
|
|
}
|
|
};
|
|
|
|
|
|
|
|
|
|
/*! \brief plot a horizontal scale bar
|
|
\ingroup jkqtfastplotter
|
|
|
|
*/
|
|
class LIB_EXPORT JKQTFPQOverlayLinearGridPlot: public JKQTFPPlot {
|
|
Q_OBJECT
|
|
|
|
protected:
|
|
/** \brief distance between grid lines */
|
|
double width;
|
|
/** \brief line width of grid lines */
|
|
double lineWidth;
|
|
/** \brief color of the grid */
|
|
QColor color;
|
|
/** \brief grid line style */
|
|
Qt::PenStyle style;
|
|
public:
|
|
|
|
/*! \brief class constructor
|
|
|
|
*/
|
|
JKQTFPQOverlayLinearGridPlot(JKQTFastPlotter* parent, double width=1, QColor color=QColor("grey"), double lineWidth=1, Qt::PenStyle style=Qt::DashLine) ;
|
|
|
|
/** \brief draw the graph */
|
|
virtual void drawGraph(QPainter& painter) override;
|
|
|
|
/*! \brief sets the property width to the specified \a __value.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual void set_width(double __value)
|
|
{
|
|
if (this->width != __value) {
|
|
this->width = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property width.
|
|
\details Description of the parameter width is: <CENTER>\copybrief width.</CENTER>
|
|
\see width for more information */
|
|
inline virtual double get_width() const
|
|
{
|
|
return this->width;
|
|
}
|
|
/*! \brief sets the property lineWidth to the specified \a __value.
|
|
\details Description of the parameter lineWidth is: <CENTER>\copybrief lineWidth.</CENTER>
|
|
\see lineWidth for more information */
|
|
inline virtual void set_lineWidth(double __value)
|
|
{
|
|
if (this->lineWidth != __value) {
|
|
this->lineWidth = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property lineWidth.
|
|
\details Description of the parameter lineWidth is: <CENTER>\copybrief lineWidth.</CENTER>
|
|
\see lineWidth for more information */
|
|
inline virtual double get_lineWidth() const
|
|
{
|
|
return this->lineWidth;
|
|
}
|
|
/*! \brief sets the property color to the specified \a __value.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual void set_color(const QColor & __value)
|
|
{
|
|
if (this->color != __value) {
|
|
this->color = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property color.
|
|
\details Description of the parameter color is: <CENTER>\copybrief color.</CENTER>
|
|
\see color for more information */
|
|
inline virtual QColor get_color() const
|
|
{
|
|
return this->color;
|
|
}
|
|
/*! \brief sets the property style to the specified \a __value.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual void set_style(const Qt::PenStyle & __value)
|
|
{
|
|
if (this->style != __value) {
|
|
this->style = __value;
|
|
replot();
|
|
}
|
|
}
|
|
/*! \brief returns the property style.
|
|
\details Description of the parameter style is: <CENTER>\copybrief style.</CENTER>
|
|
\see style for more information */
|
|
inline virtual Qt::PenStyle get_style() const
|
|
{
|
|
return this->style;
|
|
}
|
|
|
|
};
|
|
#endif // JKQTFASTPLOTTER_H
|