BREAKING/DEPRECATED: deprecated JKQTBasePlotter::zoom() and JKQTPlotter::zoom(), use JKQTBasePlotter::setXY() and JKQTPlotter::setXY() instead

NEW: improved documentation of class methods
This commit is contained in:
jkriege2 2023-12-22 20:21:01 +01:00
parent ae157d928b
commit 0595fef048
5 changed files with 77 additions and 36 deletions

View File

@ -88,7 +88,7 @@ TestWidgetContourPlots::TestWidgetContourPlots(QWidget *parent) :
densityplot->setTitle("density plot"); densityplot->setTitle("density plot");
plotContour->addGraph(densityplot); plotContour->addGraph(densityplot);
plotContour->setGrid(false); plotContour->setGrid(false);
plotDensity->zoom(-0.1,1.1,-0.1,1.1); plotDensity->setXY(-0.1,1.1,-0.1,1.1);
QVector<double> levels; QVector<double> levels;
// levels<<5<<10<<25; // levels<<5.1<<10.1; // levels<<5<<10<<25; // levels<<5.1<<10.1;
@ -105,7 +105,7 @@ TestWidgetContourPlots::TestWidgetContourPlots(QWidget *parent) :
cp->setContourLevels(levels); cp->setContourLevels(levels);
cp->setTitle("contour plot"); cp->setTitle("contour plot");
plotContour->addGraph(cp); plotContour->addGraph(cp);
plotContour->zoom(-0.1,1.1,-0.1,1.1); plotContour->setXY(-0.1,1.1,-0.1,1.1);
plotContour->setPlotUpdateEnabled(true); plotContour->setPlotUpdateEnabled(true);
plotContour->redrawPlot(); plotContour->redrawPlot();

View File

@ -488,18 +488,6 @@ void JKQTBasePlotter::setMaintainAxisAspectRatio(bool value) {
redrawPlot(); redrawPlot();
} }
void JKQTBasePlotter::zoom(double nxmin, double nxmax, double nymin, double nymax){
// only react on double clicks inside event
double xmin=nxmin;
double xmax=nxmax;
double ymin=nymin;
double ymax=nymax;
xAxis->setRange(xmin, xmax);
yAxis->setRange(ymin, ymax);
redrawPlot();
if (emitSignals) emit zoomChangedLocally(xAxis->getMin(), xAxis->getMax(), yAxis->getMin(), yAxis->getMax(), this);
}
void JKQTBasePlotter::setWidgetSize(int wid, int heigh) { void JKQTBasePlotter::setWidgetSize(int wid, int heigh) {
widgetWidth=wid; widgetWidth=wid;

View File

@ -1642,35 +1642,50 @@ class JKQTPLOTTER_LIB_EXPORT JKQTBasePlotter: public QObject {
* Uppon setting, this function emits the signal zoomChangedLocally(), if emitting signals * Uppon setting, this function emits the signal zoomChangedLocally(), if emitting signals
* is activated at the moment (e.g. using setEmittingSignalsEnabled() ). * is activated at the moment (e.g. using setEmittingSignalsEnabled() ).
* *
* \see setX(), setX(), zoomToFit(), setAbsoluteXY(), JKQTPlotter::setXY() * \see setX(), setX(), zoomToFit(), setAbsoluteXY()
*/ */
void setXY(double xminn, double xmaxx, double yminn, double ymaxx, bool affectsSecondaryAxes=false); void setXY(double xminn, double xmaxx, double yminn, double ymaxx, bool affectsSecondaryAxes=false);
/** \copydoc setXY()
* \deprecated The function JKQTBasePlotter::zoom() is deprecated and will be removed in future version, use JKQTBasePlotter::setXY() instead!
*/
inline void zoom(double xminn, double xmaxx, double yminn, double ymaxx, bool affectsSecondaryAxes=false) {
setXY(xminn, xmaxx, yminn, ymaxx, affectsSecondaryAxes);
}
/** \brief sets absolutely limiting x-range of the plot /** \brief sets absolutely limiting x-range of the plot
*
* The user (or programmer) cannot zoom to a viewport that is larger than the range given to this function.
* This is implemented by calling JKQTPCoordinateAxis::setAbsoluteRange() for the major x-axes!
* *
* \param xminn absolute minimum of x-axis * \param xminn absolute minimum of x-axis
* \param xmaxx absolute maximum of x-axis * \param xmaxx absolute maximum of x-axis
* *
* \note if the aspect ratio of this does not fit into the widget, it is possible that you don't see the complete contents! * \note if the aspect ratio of this does not fit into the widget, it is possible that you don't see the complete contents!
* *
* \see setAbsoluteXY(), setAbsoluteY(), JKQTPlotter::setAbsoluteX() * \see setAbsoluteXY(), setAbsoluteY(), JKQTPCoordinateAxis::setAbsoluteRange()
*/ */
void setAbsoluteX(double xminn, double xmaxx); void setAbsoluteX(double xminn, double xmaxx);
/** \brief sets absolute minimum and maximum y-value to plot /** \brief sets absolute minimum and maximum y-value to plot
*
* The user (or programmer) cannot zoom to a viewport that is larger than the range given to this function.
* This is implemented by calling JKQTPCoordinateAxis::setAbsoluteRange() for the major y-axes!
* *
* \param yminn absolute minimum of y-axis * \param yminn absolute minimum of y-axis
* \param ymaxx absolute maximum of y-axis * \param ymaxx absolute maximum of y-axis
* *
* \note if the aspect ratio of this does not fit into the widget, it is possible that you don't see the complete contents! * \note if the aspect ratio of this does not fit into the widget, it is possible that you don't see the complete contents!
* *
* \see setAbsoluteXY(), setAbsoluteX(), JKQTPlotter::setAbsoluteY() * \see setAbsoluteXY(), setAbsoluteX(), JKQTPCoordinateAxis::setAbsoluteRange()
*/ */
void setAbsoluteY(double yminn, double ymaxx); void setAbsoluteY(double yminn, double ymaxx);
/** \brief sets absolutely limiting x- and y-range of the plot /** \brief sets absolutely limiting x- and y-range of the plot
* *
* The user (or programmer) cannot zoom to a viewport that is larger than the range given to this function. * The user (or programmer) cannot zoom to a viewport that is larger than the range given to this function.
* This is implemented by calling JKQTPCoordinateAxis::setAbsoluteRange() for the major axes!
* *
* \param xminn absolute minimum of x-axis * \param xminn absolute minimum of x-axis
* \param xmaxx absolute maximum of x-axis * \param xmaxx absolute maximum of x-axis
@ -1679,55 +1694,71 @@ class JKQTPLOTTER_LIB_EXPORT JKQTBasePlotter: public QObject {
* *
* \note if the aspect ratio of this does not fit into the widget, it is possible that you don't see the complete contents! * \note if the aspect ratio of this does not fit into the widget, it is possible that you don't see the complete contents!
* *
* \see setAbsoluteX(), setAbsoluteY(), zoomToFit(), JKQTPlotter::setAbsoluteXY() * \see setAbsoluteX(), setAbsoluteY(), JKQTPCoordinateAxis::setAbsoluteRange()
*/ */
void setAbsoluteXY(double xminn, double xmaxx, double yminn, double ymaxx); void setAbsoluteXY(double xminn, double xmaxx, double yminn, double ymaxx);
/** \brief sets x/ymin and x/ymax to the supplied values and replots the graph (zoom operation!) */
void zoom(double nxmin, double nxmax, double nymin, double nymax);
/** \brief sets whether to plot grid lines or not /** \brief sets whether the major grid lines of the major axes are shown
* *
* \image html jkqtplotter_gridvisible.png "Grid visible" * \image html jkqtplotter_gridvisible.png "Grid visible"
* \image html jkqtplotter_gridinvisible.png "Grid invisible" * \image html jkqtplotter_gridinvisible.png "Grid invisible"
*
* \see JKQTPCoordinateAxis::setDrawGrid() and JKQTPGridStyle::enabled in JKQTPCoordinateAxisStyle::majorGridStyle
*/ */
void setGrid(bool val); void setGrid(bool val);
/** \brief sets the color of all Major grid lines /** \brief sets the color of all major grid lines (of the major x- and y-axis)
*
* \see JKQTPCoordinateAxis::setGridColor() and JKQTPGridStyle::lineColor in JKQTPCoordinateAxisStyle::majorGridStyle
* */ * */
void setGridColor(QColor color); void setGridColor(QColor color);
/** \brief sets the color of all minor grid lines /** \brief sets the color of all minor grid lines (of the major x- and y-axis)
*
* \see JKQTPCoordinateAxis::setMinorGridColor() and JKQTPGridStyle::lineColor in JKQTPCoordinateAxisStyle::minorGridStyle
* */ * */
void setMinorGridColor(QColor color); void setMinorGridColor(QColor color);
/** \brief sets the width of all Major grid lines /** \brief sets the width of all Major grid lines
*
* \see JKQTPCoordinateAxis::setGridWidth() and JKQTPGridStyle::lineWidth in JKQTPCoordinateAxisStyle::majorGridStyle
* */ * */
void setGridWidth(double __value); void setGridWidth(double __value);
/** \brief sets the width of all minor grid lines /** \brief sets the width of all minor grid lines
* */ *
* \see JKQTPCoordinateAxis::setMinorGridWidth() and JKQTPGridStyle::lineWidth in JKQTPCoordinateAxisStyle::minorGridStyle
*/
void setMinorGridWidth(double __value); void setMinorGridWidth(double __value);
/** \brief sets the style of all Major grid lines /** \brief sets the style of all Major grid lines
*
* \see JKQTPCoordinateAxis::setGridStyle() and JKQTPGridStyle::lineStyle in JKQTPCoordinateAxisStyle::majorGridStyle
* */ * */
void setGridStyle(Qt::PenStyle __value); void setGridStyle(Qt::PenStyle __value);
/** \brief sets the style of all minor grid lines /** \brief sets the style of all minor grid lines
*
* \see JKQTPCoordinateAxis::setMinorGridStyle() and JKQTPGridStyle::lineStyle in JKQTPCoordinateAxisStyle::minorGridStyle
* */ * */
void setMinorGridStyle(Qt::PenStyle __value); void setMinorGridStyle(Qt::PenStyle __value);
/** \brief switches the visibility of the zero-axes associated with the x- and y-axis /** \brief switches the visibility of the zero-axes associated with the major x- and y-axis
* *
* \param showX indicates whether to show the zero-axis associated with the x-axis (i.e. x==0 or the vertical zero-axis) * \param showX indicates whether to show the zero-axis associated with the x-axis (i.e. x==0 or the vertical zero-axis)
* \param showY indicates whether to show the zero-axis associated with the y-axis (i.e. y==0 or the horizontal zero-axis) * \param showY indicates whether to show the zero-axis associated with the y-axis (i.e. y==0 or the horizontal zero-axis)
*
* \see JKQTPCoordinateAxis::showZeroAxis() and JKQTPCoordinateAxisStyle::showZeroAxis
* */ * */
void setShowZeroAxes(bool showX, bool showY); void setShowZeroAxes(bool showX, bool showY);
/** \brief switches the visibility of the zero-axes associated with the x- and y-axis /** \brief switches the visibility of the zero-axes associated with the major x- and y-axis
* *
* \param showXY indicates whether to show the zero-axis associated with the x- and y-axis * \param showXY indicates whether to show the zero-axis associated with the x- <ul>and</ul> y-axis
*
* \see JKQTPCoordinateAxis::showZeroAxis() and JKQTPCoordinateAxisStyle::showZeroAxis
* */ * */
void setShowZeroAxes(bool showXY); void setShowZeroAxes(bool showXY);
@ -1738,10 +1769,18 @@ class JKQTPLOTTER_LIB_EXPORT JKQTBasePlotter: public QObject {
* \param outputFormmat specify the file format for the generated file * \param outputFormmat specify the file format for the generated file
* \param outputSizeIncrease if given, the size of the generated pixel image is increased by this number of pixels in addition to the required space * \param outputSizeIncrease if given, the size of the generated pixel image is increased by this number of pixels in addition to the required space
* \return returns \c true on success * \return returns \c true on success
*
* This function may generate any pixel-graphics format, supported by Qt and listed in <a href="https://doc.qt.io/qt-6/qimagewriter.html"><code>QImageWriter::supportedImageFormats()</code></a>.
* The parameters are comparable to the standard Qt functions like <a href="https://doc.qt.io/qt-6/qimage.html#save"><code>QImage::save()</code></a>, which is also used internally.
*
* \see grabPixelImage(), copyPixelImage()
*/ */
bool saveAsPixelImage(const QString& filename=QString(""), bool displayPreview=true, const QByteArray &outputFormat=QByteArray(), const QSize& outputSizeIncrease=QSize(0,0)); bool saveAsPixelImage(const QString& filename=QString(""), bool displayPreview=true, const QByteArray &outputFormat=QByteArray(), const QSize& outputSizeIncrease=QSize(0,0));
/** \brief save the current plot as a pixel image into a QImage with the given size */ /** \brief returns a rendering of the current plot as a QImage (pixel image) with the given size
*
* \see saveAsPixelImage(), copyPixelImage()
*/
QImage grabPixelImage(QSize size=QSize(), bool showPreview=false); QImage grabPixelImage(QSize size=QSize(), bool showPreview=false);
/** \brief copy the current plot as a pixel+svg image to the clipboard */ /** \brief copy the current plot as a pixel+svg image to the clipboard */
void copyPixelImage(bool showPreview=true); void copyPixelImage(bool showPreview=true);
@ -1774,6 +1813,11 @@ class JKQTPLOTTER_LIB_EXPORT JKQTBasePlotter: public QObject {
* \param filename the filename to save to, if empty a file save dialog is displayed * \param filename the filename to save to, if empty a file save dialog is displayed
* \param displayPreview if \C true, a save/print-preview dialog is displayed that allows to make some modifications to the generated image, otherwise the image is saved with default settings. * \param displayPreview if \C true, a save/print-preview dialog is displayed that allows to make some modifications to the generated image, otherwise the image is saved with default settings.
* \return Returns \c true if the file was save successfully * \return Returns \c true if the file was save successfully
*
* This function is comparable to saveAsPixelImage(), but it allows to save into any graphics format, including SVG and PF (if printer-support is compiled into the library).
* Also it may use the custom exporters implemented as JKQTPPaintDeviceAdapter and registered via JKQTBasePlotter::registerPaintDeviceAdapter().
*
* \see grabPixelImage(), copyPixelImage(), saveAsPixelImage(), JKQTBasePlotter::registerPaintDeviceAdapter(), JKQTPPaintDeviceAdapter
*/ */
bool saveImage(const QString& filename=QString(""), bool displayPreview=true); bool saveImage(const QString& filename=QString(""), bool displayPreview=true);

View File

@ -494,7 +494,17 @@ class JKQTPLOTTER_LIB_EXPORT JKQTPCoordinateAxis: public QObject {
public Q_SLOTS: public Q_SLOTS:
/** \brief set range of plot axis */ /** \brief set range of plot axis */
void setRange(double amin, double amax); void setRange(double amin, double amax);
/** \brief set absolute range of plot axis */ /** \brief sets absolutely limiting range of the plot
*
* The user (or programmer) cannot zoom to a viewport that is larger than the range given to this function.
*
* \param aamin absolute minimum of the axis
* \param aamax absolute maximum of the axis
*
* \note if the aspect ratio (set in the JKQTBasePlotter or JKQTPlotter) of this does not fit into the widget, it is possible that you don't see the complete contents!
*
* \see setAbsoluteX(), setAbsoluteY(), zoomToFit(), JKQTPCoordinateAxis::setAbsoluteRange()
*/
void setAbsoluteRange(double aamin, double aamax); void setAbsoluteRange(double aamin, double aamax);
/** \brief do not use an absolute range of plot axis */ /** \brief do not use an absolute range of plot axis */
void setNoAbsoluteRange(); void setNoAbsoluteRange();

View File

@ -919,9 +919,11 @@ class JKQTPLOTTER_LIB_EXPORT JKQTPlotter: public QWidget {
public Q_SLOTS: public Q_SLOTS:
/** \brief set the current plot magnification */ /** \brief set the current plot magnification */
void setMagnification(double m); void setMagnification(double m);
/** \copydoc JKQTBasePlotter::zoom() */ /** \copydoc JKQTBasePlotter::zoom()
inline void zoom(double nxmin, double nxmax, double nymin, double nymax) { * \deprecated The function JKQTPlotter::zoom() is deprecated and will be removed in future version, use JKQTPlotter::setXY() instead!
plotter->zoom(nxmin, nxmax, nymin, nymax); */
inline void zoom(double nxmin, double nxmax, double nymin, double nymax, bool affectsSecondaryAxes=false) {
plotter->zoom(nxmin, nxmax, nymin, nymax, affectsSecondaryAxes);
} }
/** \copydoc JKQTBasePlotter::setGrid() */ /** \copydoc JKQTBasePlotter::setGrid() */
@ -972,10 +974,7 @@ class JKQTPLOTTER_LIB_EXPORT JKQTPlotter: public QWidget {
inline void setShowZeroAxes(bool showX, bool showY) { inline void setShowZeroAxes(bool showX, bool showY) {
plotter->setShowZeroAxes(showX, showY); plotter->setShowZeroAxes(showX, showY);
} }
/** \brief switches the visibility of the zero-axes associated with the x- and y-axis /** \copydoc JKQTBasePlotter::setShowZeroAxes() */
*
* \param showXY indicates whether to show the zero-axis associated with the x- and y-axis
* */
inline void setShowZeroAxes(bool showXY) { inline void setShowZeroAxes(bool showXY) {
plotter->setShowZeroAxes(showXY); plotter->setShowZeroAxes(showXY);
} }