Vespucci
1.0.0
|
Manages a legend inside a QCustomPlot. More...
#include <qcustomplot.h>
Public Types | |
enum | SelectablePart { spNone = 0x000, spLegendBox = 0x001, spItems = 0x002 } |
Public Types inherited from QCPLayoutElement | |
enum | UpdatePhase { upPreparation, upMargins, upLayout } |
Signals | |
void | selectionChanged (QCPLegend::SelectableParts parts) |
void | selectableChanged (QCPLegend::SelectableParts parts) |
Signals inherited from QCPLayerable | |
void | layerChanged (QCPLayer *newLayer) |
Public Member Functions | |
QCPLegend () | |
virtual | ~QCPLegend () |
QPen | borderPen () const |
QBrush | brush () const |
QFont | font () const |
QColor | textColor () const |
QSize | iconSize () const |
int | iconTextPadding () const |
QPen | iconBorderPen () const |
SelectableParts | selectableParts () const |
SelectableParts | selectedParts () const |
QPen | selectedBorderPen () const |
QPen | selectedIconBorderPen () const |
QBrush | selectedBrush () const |
QFont | selectedFont () const |
QColor | selectedTextColor () const |
void | setBorderPen (const QPen &pen) |
void | setBrush (const QBrush &brush) |
void | setFont (const QFont &font) |
void | setTextColor (const QColor &color) |
void | setIconSize (const QSize &size) |
void | setIconSize (int width, int height) |
void | setIconTextPadding (int padding) |
void | setIconBorderPen (const QPen &pen) |
Q_SLOT void | setSelectableParts (const SelectableParts &selectableParts) |
Q_SLOT void | setSelectedParts (const SelectableParts &selectedParts) |
void | setSelectedBorderPen (const QPen &pen) |
void | setSelectedIconBorderPen (const QPen &pen) |
void | setSelectedBrush (const QBrush &brush) |
void | setSelectedFont (const QFont &font) |
void | setSelectedTextColor (const QColor &color) |
virtual double | selectTest (const QPointF &pos, bool onlySelectable, QVariant *details=0) const |
QCPAbstractLegendItem * | item (int index) const |
QCPPlottableLegendItem * | itemWithPlottable (const QCPAbstractPlottable *plottable) const |
int | itemCount () const |
bool | hasItem (QCPAbstractLegendItem *item) const |
bool | hasItemWithPlottable (const QCPAbstractPlottable *plottable) const |
bool | addItem (QCPAbstractLegendItem *item) |
bool | removeItem (int index) |
bool | removeItem (QCPAbstractLegendItem *item) |
void | clearItems () |
QList< QCPAbstractLegendItem * > | selectedItems () const |
Public Member Functions inherited from QCPLayoutGrid | |
QCPLayoutGrid () | |
virtual | ~QCPLayoutGrid () |
int | rowCount () const |
int | columnCount () const |
QList< double > | columnStretchFactors () const |
QList< double > | rowStretchFactors () const |
int | columnSpacing () const |
int | rowSpacing () const |
void | setColumnStretchFactor (int column, double factor) |
void | setColumnStretchFactors (const QList< double > &factors) |
void | setRowStretchFactor (int row, double factor) |
void | setRowStretchFactors (const QList< double > &factors) |
void | setColumnSpacing (int pixels) |
void | setRowSpacing (int pixels) |
virtual void | updateLayout () |
virtual int | elementCount () const |
virtual QCPLayoutElement * | elementAt (int index) const |
virtual QCPLayoutElement * | takeAt (int index) |
virtual bool | take (QCPLayoutElement *element) |
virtual QList< QCPLayoutElement * > | elements (bool recursive) const |
virtual void | simplify () |
virtual QSize | minimumSizeHint () const |
virtual QSize | maximumSizeHint () const |
QCPLayoutElement * | element (int row, int column) const |
bool | addElement (int row, int column, QCPLayoutElement *element) |
bool | hasElement (int row, int column) |
void | expandTo (int newRowCount, int newColumnCount) |
void | insertRow (int newIndex) |
void | insertColumn (int newIndex) |
Public Member Functions inherited from QCPLayout | |
QCPLayout () | |
virtual void | update (UpdatePhase phase) |
bool | removeAt (int index) |
bool | remove (QCPLayoutElement *element) |
void | clear () |
Public Member Functions inherited from QCPLayoutElement | |
QCPLayoutElement (QCustomPlot *parentPlot=0) | |
virtual | ~QCPLayoutElement () |
QCPLayout * | layout () const |
QRect | rect () const |
QRect | outerRect () const |
QMargins | margins () const |
QMargins | minimumMargins () const |
QCP::MarginSides | autoMargins () const |
QSize | minimumSize () const |
QSize | maximumSize () const |
QCPMarginGroup * | marginGroup (QCP::MarginSide side) const |
QHash< QCP::MarginSide, QCPMarginGroup * > | marginGroups () const |
void | setOuterRect (const QRect &rect) |
void | setMargins (const QMargins &margins) |
void | setMinimumMargins (const QMargins &margins) |
void | setAutoMargins (QCP::MarginSides sides) |
void | setMinimumSize (const QSize &size) |
void | setMinimumSize (int width, int height) |
void | setMaximumSize (const QSize &size) |
void | setMaximumSize (int width, int height) |
void | setMarginGroup (QCP::MarginSides sides, QCPMarginGroup *group) |
Public Member Functions inherited from QCPLayerable | |
QCPLayerable (QCustomPlot *plot, QString targetLayer=QString(), QCPLayerable *parentLayerable=0) | |
~QCPLayerable () | |
bool | visible () const |
QCustomPlot * | parentPlot () const |
QCPLayerable * | parentLayerable () const |
QCPLayer * | layer () const |
bool | antialiased () const |
void | setVisible (bool on) |
Q_SLOT bool | setLayer (QCPLayer *layer) |
bool | setLayer (const QString &layerName) |
void | setAntialiased (bool enabled) |
bool | realVisibility () const |
Protected Member Functions | |
virtual void | parentPlotInitialized (QCustomPlot *parentPlot) |
virtual QCP::Interaction | selectionCategory () const |
virtual void | applyDefaultAntialiasingHint (QCPPainter *painter) const |
virtual void | draw (QCPPainter *painter) |
virtual void | selectEvent (QMouseEvent *event, bool additive, const QVariant &details, bool *selectionStateChanged) |
virtual void | deselectEvent (bool *selectionStateChanged) |
QPen | getBorderPen () const |
QBrush | getBrush () const |
Protected Member Functions inherited from QCPLayoutGrid | |
void | getMinimumRowColSizes (QVector< int > *minColWidths, QVector< int > *minRowHeights) const |
void | getMaximumRowColSizes (QVector< int > *maxColWidths, QVector< int > *maxRowHeights) const |
Protected Member Functions inherited from QCPLayout | |
void | sizeConstraintsChanged () const |
void | adoptElement (QCPLayoutElement *el) |
void | releaseElement (QCPLayoutElement *el) |
QVector< int > | getSectionSizes (QVector< int > maxSizes, QVector< int > minSizes, QVector< double > stretchFactors, int totalSize) const |
Protected Member Functions inherited from QCPLayoutElement | |
virtual int | calculateAutoMargin (QCP::MarginSide side) |
virtual void | mousePressEvent (QMouseEvent *event) |
virtual void | mouseMoveEvent (QMouseEvent *event) |
virtual void | mouseReleaseEvent (QMouseEvent *event) |
virtual void | mouseDoubleClickEvent (QMouseEvent *event) |
virtual void | wheelEvent (QWheelEvent *event) |
Protected Member Functions inherited from QCPLayerable | |
virtual QRect | clipRect () const |
void | initializeParentPlot (QCustomPlot *parentPlot) |
void | setParentLayerable (QCPLayerable *parentLayerable) |
bool | moveToLayer (QCPLayer *layer, bool prepend) |
void | applyAntialiasingHint (QCPPainter *painter, bool localAntialiased, QCP::AntialiasedElement overrideElement) const |
Protected Attributes | |
QPen | mBorderPen |
QPen | mIconBorderPen |
QBrush | mBrush |
QFont | mFont |
QColor | mTextColor |
QSize | mIconSize |
int | mIconTextPadding |
SelectableParts | mSelectedParts |
SelectableParts | mSelectableParts |
QPen | mSelectedBorderPen |
QPen | mSelectedIconBorderPen |
QBrush | mSelectedBrush |
QFont | mSelectedFont |
QColor | mSelectedTextColor |
Protected Attributes inherited from QCPLayoutGrid | |
QList< QList< QCPLayoutElement * > > | mElements |
QList< double > | mColumnStretchFactors |
QList< double > | mRowStretchFactors |
int | mColumnSpacing |
int | mRowSpacing |
Protected Attributes inherited from QCPLayoutElement | |
QCPLayout * | mParentLayout |
QSize | mMinimumSize |
QSize | mMaximumSize |
QRect | mRect |
QRect | mOuterRect |
QMargins | mMargins |
QMargins | mMinimumMargins |
QCP::MarginSides | mAutoMargins |
QHash< QCP::MarginSide, QCPMarginGroup * > | mMarginGroups |
Protected Attributes inherited from QCPLayerable | |
bool | mVisible |
QCustomPlot * | mParentPlot |
QPointer< QCPLayerable > | mParentLayerable |
QCPLayer * | mLayer |
bool | mAntialiased |
Friends | |
class | QCustomPlot |
class | QCPAbstractLegendItem |
Manages a legend inside a QCustomPlot.
A legend is a small box somewhere in the plot which lists plottables with their name and icon.
Normally, the legend is populated by calling QCPAbstractPlottable::addToLegend. The respective legend item can be removed with QCPAbstractPlottable::removeFromLegend. However, QCPLegend also offers an interface to add and manipulate legend items directly: item, itemWithPlottable, itemCount, addItem, removeItem, etc.
The QCPLegend derives from QCPLayoutGrid and as such can be placed in any position a QCPLayoutElement may be positioned. The legend items are themselves QCPLayoutElements which are placed in the grid layout of the legend. QCPLegend only adds an interface specialized for handling child elements of type QCPAbstractLegendItem, as mentioned above. In principle, any other layout elements may also be added to a legend via the normal QCPLayoutGrid interface. However, the QCPAbstractLegendItem-Interface will ignore those elements (e.g. itemCount will only return the number of items with QCPAbstractLegendItems type).
By default, every QCustomPlot has one legend (QCustomPlot::legend) which is placed in the inset layout of the main axis rect (QCPAxisRect::insetLayout). To move the legend to another position inside the axis rect, use the methods of the QCPLayoutInset. To move the legend outside of the axis rect, place it anywhere else with the QCPLayout/QCPLayoutElement interface.
Definition at line 2219 of file qcustomplot.h.
Defines the selectable parts of a legend
Enumerator | |
---|---|
spNone |
|
spLegendBox |
|
spItems |
|
Definition at line 2244 of file qcustomplot.h.
|
explicit |
Constructs a new QCPLegend instance with parentPlot as the containing plot and default values.
Note that by default, QCustomPlot already contains a legend ready to be used as QCustomPlot::legend
Definition at line 13458 of file qcustomplot.cpp.
|
virtual |
Definition at line 13481 of file qcustomplot.cpp.
bool QCPLegend::addItem | ( | QCPAbstractLegendItem * | item | ) |
Adds item to the legend, if it's not present already.
Returns true on sucess, i.e. if the item wasn't in the list already and has been successfuly added.
The legend takes ownership of the item.
Definition at line 13799 of file qcustomplot.cpp.
|
protectedvirtual |
Reimplemented from QCPLayoutElement.
Definition at line 13883 of file qcustomplot.cpp.
|
inline |
Definition at line 2255 of file qcustomplot.h.
|
inline |
Definition at line 2256 of file qcustomplot.h.
void QCPLegend::clearItems | ( | ) |
Removes all items from the legend.
Definition at line 13844 of file qcustomplot.cpp.
|
protectedvirtual |
Reimplemented from QCPLayerable.
Definition at line 13951 of file qcustomplot.cpp.
|
protectedvirtual |
Reimplemented from QCPLayoutElement.
Definition at line 13913 of file qcustomplot.cpp.
|
inline |
Definition at line 2257 of file qcustomplot.h.
|
protected |
Definition at line 13893 of file qcustomplot.cpp.
|
protected |
Definition at line 13903 of file qcustomplot.cpp.
bool QCPLegend::hasItem | ( | QCPAbstractLegendItem * | item | ) | const |
Returns whether the legend contains itm.
Definition at line 13771 of file qcustomplot.cpp.
bool QCPLegend::hasItemWithPlottable | ( | const QCPAbstractPlottable * | plottable | ) | const |
Returns whether the legend contains a QCPPlottableLegendItem which is associated with plottable (e.g. a QCPGraph*). If such an item isn't in the legend, returns false.
Definition at line 13787 of file qcustomplot.cpp.
|
inline |
Definition at line 2261 of file qcustomplot.h.
|
inline |
Definition at line 2259 of file qcustomplot.h.
|
inline |
Definition at line 2260 of file qcustomplot.h.
QCPAbstractLegendItem * QCPLegend::item | ( | int | index | ) | const |
int QCPLegend::itemCount | ( | ) | const |
Returns the number of items currently in the legend.
Definition at line 13763 of file qcustomplot.cpp.
QCPPlottableLegendItem * QCPLegend::itemWithPlottable | ( | const QCPAbstractPlottable * | plottable | ) | const |
Returns the QCPPlottableLegendItem which is associated with plottable (e.g. a QCPGraph*). If such an item isn't in the legend, returns 0.
Definition at line 13746 of file qcustomplot.cpp.
|
protectedvirtual |
Reimplemented from QCPLayoutElement.
Definition at line 13976 of file qcustomplot.cpp.
bool QCPLegend::removeItem | ( | int | index | ) |
Removes the item with index index from the legend.
Returns true, if successful.
Definition at line 13815 of file qcustomplot.cpp.
bool QCPLegend::removeItem | ( | QCPAbstractLegendItem * | item | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Removes item from the legend.
Returns true, if successful.
Definition at line 13834 of file qcustomplot.cpp.
|
signal |
|
inline |
Definition at line 2262 of file qcustomplot.h.
|
inline |
Definition at line 2264 of file qcustomplot.h.
|
inline |
Definition at line 2266 of file qcustomplot.h.
|
inline |
Definition at line 2267 of file qcustomplot.h.
|
inline |
Definition at line 2265 of file qcustomplot.h.
QList< QCPAbstractLegendItem * > QCPLegend::selectedItems | ( | ) | const |
Returns the legend items that are currently selected. If no items are selected, the list is empty.
Definition at line 13856 of file qcustomplot.cpp.
QCPLegend::SelectableParts QCPLegend::selectedParts | ( | ) | const |
Definition at line 13489 of file qcustomplot.cpp.
|
inline |
Definition at line 2268 of file qcustomplot.h.
|
protectedvirtual |
Reimplemented from QCPLayerable.
Definition at line 13937 of file qcustomplot.cpp.
|
protectedvirtual |
Reimplemented from QCPLayerable.
Definition at line 13964 of file qcustomplot.cpp.
|
signal |
This signal is emitted when the selection state of this legend has changed.
|
virtual |
Layout elements are sensitive to events inside their outer rect. If pos is within the outer rect, this method returns a value corresponding to 0.99 times the parent plot's selection tolerance. However, layout elements are not selectable by default. So if onlySelectable is true, -1.0 is returned.
See QCPLayerable::selectTest for a general explanation of this virtual method.
QCPLayoutElement subclasses may reimplement this method to provide more specific selection test behaviour.
Reimplemented from QCPLayoutElement.
Definition at line 13922 of file qcustomplot.cpp.
void QCPLegend::setBorderPen | ( | const QPen & | pen | ) |
Sets the pen, the border of the entire legend is drawn with.
Definition at line 13510 of file qcustomplot.cpp.
void QCPLegend::setBrush | ( | const QBrush & | brush | ) |
Sets the brush of the legend background.
Definition at line 13518 of file qcustomplot.cpp.
void QCPLegend::setFont | ( | const QFont & | font | ) |
Sets the default font of legend text. Legend items that draw text (e.g. the name of a graph) will use this font by default. However, a different font can be specified on a per-item-basis by accessing the specific legend item.
This function will also set font on all already existing legend items.
Definition at line 13532 of file qcustomplot.cpp.
void QCPLegend::setIconBorderPen | ( | const QPen & | pen | ) |
Sets the pen used to draw a border around each legend icon. Legend items that draw an icon (e.g. a visual representation of the graph) will use this pen by default.
If no border is wanted, set this to Qt::NoPen.
Definition at line 13594 of file qcustomplot.cpp.
void QCPLegend::setIconSize | ( | const QSize & | size | ) |
Sets the size of legend icons. Legend items that draw an icon (e.g. a visual representation of the graph) will use this size by default.
Definition at line 13565 of file qcustomplot.cpp.
void QCPLegend::setIconSize | ( | int | width, |
int | height | ||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Definition at line 13572 of file qcustomplot.cpp.
void QCPLegend::setIconTextPadding | ( | int | padding | ) |
Sets the horizontal space in pixels between the legend icon and the text next to it. Legend items that draw an icon (e.g. a visual representation of the graph) and text (e.g. the name of the graph) will use this space by default.
Definition at line 13583 of file qcustomplot.cpp.
void QCPLegend::setSelectableParts | ( | const SelectableParts & | selectable | ) |
Sets whether the user can (de-)select the parts in selectable by clicking on the QCustomPlot surface. (When QCustomPlot::setInteractions contains QCP::iSelectLegend.)
However, even when selectable is set to a value not allowing the selection of a specific part, it is still possible to set the selection of this part manually, by calling setSelectedParts directly.
Definition at line 13609 of file qcustomplot.cpp.
void QCPLegend::setSelectedBorderPen | ( | const QPen & | pen | ) |
When the legend box is selected, this pen is used to draw the border instead of the normal pen set via setBorderPen.
Definition at line 13670 of file qcustomplot.cpp.
void QCPLegend::setSelectedBrush | ( | const QBrush & | brush | ) |
When the legend box is selected, this brush is used to draw the legend background instead of the normal brush set via setBrush.
Definition at line 13691 of file qcustomplot.cpp.
void QCPLegend::setSelectedFont | ( | const QFont & | font | ) |
Sets the default font that is used by legend items when they are selected.
This function will also set font on all already existing legend items.
Definition at line 13703 of file qcustomplot.cpp.
void QCPLegend::setSelectedIconBorderPen | ( | const QPen & | pen | ) |
Sets the pen legend items will use to draw their icon borders, when they are selected.
Definition at line 13680 of file qcustomplot.cpp.
void QCPLegend::setSelectedParts | ( | const SelectableParts & | selected | ) |
Sets the selected state of the respective legend parts described by SelectablePart. When a part is selected, it uses a different pen/font and brush. If some legend items are selected and selected doesn't contain spItems, those items become deselected.
The entire selection mechanism is handled automatically when QCustomPlot::setInteractions contains iSelectLegend. You only need to call this function when you wish to change the selection state manually.
This function can change the selection state of a part even when setSelectableParts was set to a value that actually excludes the part.
emits the selectionChanged signal when selected is different from the previous selection state.
Note that it doesn't make sense to set the selected state spItems here when it wasn't set before, because there's no way to specify which exact items to newly select. Do this by calling QCPAbstractLegendItem::setSelected directly on the legend item you wish to select.
Definition at line 13639 of file qcustomplot.cpp.
void QCPLegend::setSelectedTextColor | ( | const QColor & | color | ) |
Sets the default text color that is used by legend items when they are selected.
This function will also set color on all already existing legend items.
Definition at line 13720 of file qcustomplot.cpp.
void QCPLegend::setTextColor | ( | const QColor & | color | ) |
Sets the default color of legend text. Legend items that draw text (e.g. the name of a graph) will use this color by default. However, a different colors can be specified on a per-item-basis by accessing the specific legend item.
This function will also set color on all already existing legend items.
Definition at line 13551 of file qcustomplot.cpp.
|
inline |
Definition at line 2258 of file qcustomplot.h.
|
friend |
Definition at line 2337 of file qcustomplot.h.
|
friend |
Definition at line 2336 of file qcustomplot.h.
|
protected |
Definition at line 2308 of file qcustomplot.h.
|
protected |
Definition at line 2309 of file qcustomplot.h.
|
protected |
Definition at line 2310 of file qcustomplot.h.
|
protected |
Definition at line 2308 of file qcustomplot.h.
|
protected |
Definition at line 2312 of file qcustomplot.h.
|
protected |
Definition at line 2313 of file qcustomplot.h.
|
protected |
Definition at line 2314 of file qcustomplot.h.
|
protected |
Definition at line 2315 of file qcustomplot.h.
|
protected |
Definition at line 2316 of file qcustomplot.h.
|
protected |
Definition at line 2317 of file qcustomplot.h.
|
protected |
Definition at line 2315 of file qcustomplot.h.
|
protected |
Definition at line 2314 of file qcustomplot.h.
|
protected |
Definition at line 2318 of file qcustomplot.h.
|
protected |
Definition at line 2311 of file qcustomplot.h.