KPlotWidget Class
Generic data plotting widget. More...
Header: | #include <KPlotWidget> |
CMake: | find_package(KF6 REQUIRED COMPONENTS Plotting) target_link_libraries(mytarget PRIVATE KF6::Plotting) |
Inherits: | QFrame |
Public Types
enum | Axis { LeftAxis, BottomAxis, RightAxis, TopAxis } |
Properties
|
|
Public Functions
KPlotWidget(QWidget *parent = nullptr) | |
void | addPlotObject(KPlotObject *object) |
void | addPlotObjects(const QList<KPlotObject *> &objects) |
bool | antialiasing() const |
KPlotAxis * | axis(KPlotWidget::Axis type) |
const KPlotAxis * | axis(KPlotWidget::Axis type) const |
QColor | backgroundColor() const |
int | bottomPadding() const |
void | clearSecondaryLimits() |
QRectF | dataRect() const |
QColor | foregroundColor() const |
QColor | gridColor() const |
bool | isGridShown() const |
bool | isObjectToolTipShown() const |
int | leftPadding() const |
QPointF | mapToWidget(const QPointF &p) const |
void | maskAlongLine(const QPointF &p1, const QPointF &p2, float value = 1.0f) |
void | maskRect(const QRectF &r, float value = 1.0f) |
QRect | pixRect() const |
void | placeLabel(QPainter *painter, KPlotPoint *pp) |
QList<KPlotObject *> | plotObjects() const |
void | removeAllPlotObjects() |
void | replacePlotObject(int i, KPlotObject *o) |
void | resetPlot() |
void | resetPlotMask() |
int | rightPadding() const |
QRectF | secondaryDataRect() const |
void | setAntialiasing(bool b) |
(since 5.12) void | setAutoDeletePlotObjects(bool autoDelete) |
void | setBackgroundColor(const QColor &bg) |
void | setBottomPadding(int padding) |
void | setDefaultPaddings() |
void | setForegroundColor(const QColor &fg) |
void | setGridColor(const QColor &gc) |
void | setLeftPadding(int padding) |
void | setLimits(double x1, double x2, double y1, double y2) |
void | setRightPadding(int padding) |
void | setSecondaryLimits(double x1, double x2, double y1, double y2) |
void | setTopPadding(int padding) |
int | topPadding() const |
Reimplemented Public Functions
virtual QSize | minimumSizeHint() const override |
virtual QSize | sizeHint() const override |
Public Slots
void | setObjectToolTipShown(bool show) |
void | setShowGrid(bool show) |
Protected Functions
QList<KPlotPoint *> | pointsUnderPoint(const QPoint &p) const |
void | setPixRect() |
Detailed Description
Widget for drawing plots. The basic idea behind KPlotWidget is that you don't have to worry about any transformation from your data's natural units to screen pixel coordinates; this is handled internally by the widget.
Data to be plotted are represented by one or more instances of KPlotObject. KPlotObject contains a list of QPointFs to be plotted (again, in the data's natural units), as well as information about how the data are to be rendered in the plot (i.e., as separate points or connected by lines? With what color and point style? etc). See KPlotObject for more information.
KPlotWidget automatically adds axis labels with tickmarks and tick labels. These are encapsulated in the KPlotAxis class. All you have to do is set the limits of the plotting area in data units, and KPlotWidget will figure out the optimal positions and labels for the tickmarks on the axes.
Example of usage:
KPlotWidget *kpw = new KPlotWidget( parent ); // setting our limits for the plot kpw->setLimits( 1.0, 5.0, 1.0, 25.0 ); // creating a plot object whose points are connected by red lines ... KPlotObject *kpo = new KPlotObject( Qt::red, KPlotObject::Lines ); // ... adding some points to it ... for ( float x = 1.0; x <= 5.0; x += 0.1 ) kpo->addPoint( x, x*x ); // ... and adding the object to the plot widget kpw->addPlotObject( kpo );
Note: KPlotWidget will take ownership of the objects added to it, so when clearing the objects list (eg with removeAllPlotObjects()) any previous reference to a KPlotObject already added to a KPlotWidget will be invalid. You can disable this behavior by using setAutoDelete(false).
Member Type Documentation
enum KPlotWidget::Axis
The four types of plot axes.
Constant | Value | Description |
---|---|---|
KPlotWidget::LeftAxis | 0 | the left axis |
KPlotWidget::BottomAxis | 1 | the bottom axis |
KPlotWidget::RightAxis | 2 | the right axis |
KPlotWidget::TopAxis | 3 | the top axis |
Property Documentation
backgroundColor : QColor
Access functions:
QColor | backgroundColor() const |
void | setBackgroundColor(const QColor &bg) |
[read-only]
bottomPadding : const int
Access functions:
int | bottomPadding() const |
foregroundColor : QColor
Access functions:
QColor | foregroundColor() const |
void | setForegroundColor(const QColor &fg) |
grid : bool
Access functions:
bool | isGridShown() const |
void | setShowGrid(bool show) |
gridColor : QColor
Access functions:
QColor | gridColor() const |
void | setGridColor(const QColor &gc) |
[read-only]
leftPadding : const int
Access functions:
int | leftPadding() const |
objectToolTip : bool
Access functions:
bool | isObjectToolTipShown() const |
void | setObjectToolTipShown(bool show) |
[read-only]
rightPadding : const int
Access functions:
int | rightPadding() const |
[read-only]
topPadding : const int
Access functions:
int | topPadding() const |
Member Function Documentation
[explicit]
KPlotWidget::KPlotWidget(QWidget *parent = nullptr)
Constructor.
parent the parent widget
void KPlotWidget::addPlotObject(KPlotObject *object)
Add an item to the list of KPlotObjects to be plotted.
The widget takes ownership of the plot object, unless auto-delete was disabled.
object the KPlotObject to be added
void KPlotWidget::addPlotObjects(const QList<KPlotObject *> &objects)
Add more than one KPlotObject at one time.
The widget takes ownership of the plot object, unless auto-delete was disabled.
objects the list of KPlotObjects to be added
bool KPlotWidget::antialiasing() const
Returns whether the antialiasing is active
Antialiasing is not active by default.
See also setAntialiasing().
KPlotAxis *KPlotWidget::axis(KPlotWidget::Axis type)
Returns the axis of the specified type, or 0 if no axis has been set.
See also Axis.
const KPlotAxis *KPlotWidget::axis(KPlotWidget::Axis type) const
Returns the axis of the specified type, or 0 if no axis has been set.
See also Axis.
QColor KPlotWidget::backgroundColor() const
Returns the background color of the plot.
The default color is black.
Note: Getter function for property backgroundColor.
See also setBackgroundColor().
int KPlotWidget::bottomPadding() const
Returns the number of pixels below the plot area.
Padding values are set to -1 by default; if unchanged, this function will try to guess a good value, based on whether ticklabels and/or axis labels are to be drawn.
Note: Getter function for property bottomPadding.
See also setBottomPadding().
void KPlotWidget::clearSecondaryLimits()
Unset the secondary limits, so the top and right axes show the same tickmarks as the bottom and left axes (no tickmark labels will be drawn for the top and right axes in this case)
QRectF KPlotWidget::dataRect() const
Returns the rectangle representing the boundaries of the current plot, in natural data units.
See also setLimits().
QColor KPlotWidget::foregroundColor() const
Returns the foreground color, used for axes, tickmarks and associated labels.
The default color is white.
Note: Getter function for property foregroundColor.
See also setForegroundColor().
QColor KPlotWidget::gridColor() const
Returns the grid color.
The default color is gray.
Note: Getter function for property gridColor.
See also setGridColor().
bool KPlotWidget::isGridShown() const
Returns whether the grid lines are shown
Grid lines are not shown by default.
Note: Getter function for property grid.
bool KPlotWidget::isObjectToolTipShown() const
Returns whether the tooltip for the point objects is shown.
Tooltips are enabled by default.
Note: Getter function for property objectToolTip.
int KPlotWidget::leftPadding() const
Returns the number of pixels to the left of the plot area.
Padding values are set to -1 by default; if unchanged, this function will try to guess a good value, based on whether ticklabels and/or axis labels need to be drawn.
Note: Getter function for property leftPadding.
See also setLeftPadding().
QPointF KPlotWidget::mapToWidget(const QPointF &p) const
Map a coordinate p from the data rect to the physical pixel rect.
Used mainly when drawing.
p the point to be converted, in natural data units
Returns the coordinate in the pixel coordinate system
void KPlotWidget::maskAlongLine(const QPointF &p1, const QPointF &p2, float value = 1.0f)
Indicate that object labels should try to avoid the line joining the two given points (in pixel coordinates).
Note: You should not normally call this function directly. It is called by KPlotObject when lines are drawn in the plot.
p1 the starting point for the line
p2 the ending point for the line
value Allows you to determine how strongly the line should be avoided. Larger values are avoided more strongly.
void KPlotWidget::maskRect(const QRectF &r, float value = 1.0f)
Indicate that object labels should try to avoid the given rectangle in the plot. The rectangle is in pixel coordinates.
Note: You should not normally call this function directly. It is called by KPlotObject when points, bars and labels are drawn.
r the rectangle defining the region in the plot that text labels should avoid (in pixel coordinates)
value Allows you to determine how strongly the rectangle should be avoided. Larger values are avoided more strongly.
[override virtual]
QSize KPlotWidget::minimumSizeHint() const
Reimplements an access function for property: QWidget::minimumSizeHint.
Returns suggested minimum size for the plot widget
QRect KPlotWidget::pixRect() const
Returns the rectangle representing the boundaries of the current plot, in screen pixel units.
See also setPixRect().
void KPlotWidget::placeLabel(QPainter *painter, KPlotPoint *pp)
Place an object label optimally in the plot. This function will attempt to place the label as close as it can to the point to which the label belongs, while avoiding overlap with regions of the plot that have been masked.
Note: You should not normally call this function directly. It is called internally in KPlotObject::draw().
painter Pointer to the painter on which to draw the label
pp pointer to the KPlotPoint whose label is to be drawn.
QList<KPlotObject *> KPlotWidget::plotObjects() const
Returns the current list of plot objects
[protected]
QList<KPlotPoint *> KPlotWidget::pointsUnderPoint(const QPoint &p) const
Returns a list of points in the plot which are within 4 pixels of the screen position given as an argument.
p The screen position from which to check for plot points.
void KPlotWidget::removeAllPlotObjects()
Removes all plot objects that were added to the widget.
If auto-delete was not disabled, the plot objects are deleted.
void KPlotWidget::replacePlotObject(int i, KPlotObject *o)
Replace an item in the KPlotObject list.
i the index of the item to be replaced
o pointer to the replacement KPlotObject
Since 5.12, if auto-deletion is enabled, the previous plot object is deleted. Call setAutoDeletePlotObjects(false) if you want to swap between available plot objects and therefore you want to handle deletion externally.
void KPlotWidget::resetPlot()
Clear the object list, reset the data limits, and remove axis labels
If auto-delete was not disabled, the plot objects are deleted.
void KPlotWidget::resetPlotMask()
Reset the mask used for non-overlapping labels so that all regions of the plot area are considered empty.
int KPlotWidget::rightPadding() const
Returns the number of pixels to the right of the plot area.
Padding values are set to -1 by default; if unchanged, this function will try to guess a good value, based on whether ticklabels and/or axis labels are to be drawn.
Note: Getter function for property rightPadding.
See also setRightPadding().
QRectF KPlotWidget::secondaryDataRect() const
Returns the rectangle representing the boundaries of the secondary data limits, if they have been set. Otherwise, this function behaves the same as dataRect().
See also setSecondaryLimits().
void KPlotWidget::setAntialiasing(bool b)
Toggle antialiased drawing.
b if true, the plot graphics will be antialiased.
See also antialiasing().
[since 5.12]
void KPlotWidget::setAutoDeletePlotObjects(bool autoDelete)
Enables auto-deletion of plot objects if autoDelete is true; otherwise auto-deletion is disabled.
Auto-deletion is enabled by default.
This function was introduced in 5.12.
void KPlotWidget::setBackgroundColor(const QColor &bg)
Set the background color
bg the new background color
Note: Setter function for property backgroundColor.
See also backgroundColor().
void KPlotWidget::setBottomPadding(int padding)
Set the number of pixels below the plot area.
Set this to -1 to revert to automatic determination of padding values.
See also bottomPadding().
void KPlotWidget::setDefaultPaddings()
Revert all four padding values to -1, so that they will be automatically determined.
void KPlotWidget::setForegroundColor(const QColor &fg)
Set the foreground color
fg the new foreground color
Note: Setter function for property foregroundColor.
See also foregroundColor().
void KPlotWidget::setGridColor(const QColor &gc)
Set the grid color
gc the new grid color
Note: Setter function for property gridColor.
See also gridColor().
void KPlotWidget::setLeftPadding(int padding)
Set the number of pixels to the left of the plot area.
Set this to -1 to revert to automatic determination of padding values.
See also leftPadding().
void KPlotWidget::setLimits(double x1, double x2, double y1, double y2)
Set new data limits for the plot.
x1 the minimum X value in data units
x2 the maximum X value in data units
y1 the minimum Y value in data units
y2 the maximum Y value in data units
[slot]
void KPlotWidget::setObjectToolTipShown(bool show)
Toggle the display of a tooltip for point objects.
show whether show the tooltip.
Note: Setter function for property objectToolTip.
See also isObjectToolTipShown().
[protected]
void KPlotWidget::setPixRect()
Synchronize the PixRect with the current widget size and padding settings.
See also pixRect().
void KPlotWidget::setRightPadding(int padding)
Set the number of pixels to the right of the plot area.
Set this to -1 to revert to automatic determination of padding values.
See also rightPadding().
void KPlotWidget::setSecondaryLimits(double x1, double x2, double y1, double y2)
Reset the secondary data limits, which control the values displayed along the top and right axes.
All data points are *plotted* using the coordinates defined by setLimits(), so this function is only useful for showing alternate tickmark labels along the top and right edges. For example, if you were plotting temperature on the X-axis, you could use Centigrade units for the primary (bottom) axis, using setLimits( 0.0, 100.0, 0.0, 1.0 ). If you also wanted to show Fahrenheit units along the secondary (top) axis, you would additionally use setSecondaryLimits( 32.0, 212.0, 0.0, 1.0 ). The data added to the plot would have x-coordinates in Centigrade degrees.
x1 the minimum X value in secondary data units
x2 the maximum X value in secondary data units
y1 the minimum Y value in secondary data units
y2 the maximum Y value in secondary data units
See also setLimits().
[slot]
void KPlotWidget::setShowGrid(bool show)
Toggle whether grid lines are drawn at major tickmarks.
show if true, grid lines will be drawn.
Note: Setter function for property grid.
See also isGridShown().
void KPlotWidget::setTopPadding(int padding)
Set the number of pixels above the plot area.
Set this to -1 to revert to automatic determination of padding values.
See also topPadding().
[override virtual]
QSize KPlotWidget::sizeHint() const
Reimplements: QFrame::sizeHint() const.
Returns suggested size for the plot widget
int KPlotWidget::topPadding() const
Returns the number of pixels above the plot area.
Padding values are set to -1 by default; if unchanged, this function will try to guess a good value, based on whether ticklabels and/or axis labels are to be drawn.
Note: Getter function for property topPadding.
See also setTopPadding().