Skip to content
Snippets Groups Projects
qwt_plot_item.h 8.15 KiB
Newer Older
  • Learn to ignore specific revisions
  • pixhawk's avatar
    pixhawk committed
    /* -*- mode: C++ ; c-file-style: "stroustrup" -*- *****************************
     * Qwt Widget Library
     * Copyright (C) 1997   Josef Wilgen
     * Copyright (C) 2002   Uwe Rathmann
    
    pixhawk's avatar
    pixhawk committed
     * This library is free software; you can redistribute it and/or
     * modify it under the terms of the Qwt License, Version 1.0
     *****************************************************************************/
    
    #ifndef QWT_PLOT_ITEM_H
    #define QWT_PLOT_ITEM_H
    
    #include "qwt_global.h"
    #include "qwt_text.h"
    
    Bryant's avatar
    Bryant committed
    #include "qwt_legend_data.h"
    #include "qwt_graphic.h"
    #include <qrect.h>
    #include <qlist.h>
    #include <qmetatype.h>
    
    pixhawk's avatar
    pixhawk committed
    
    class QPainter;
    class QwtScaleMap;
    class QwtScaleDiv;
    
    Bryant's avatar
    Bryant committed
    class QwtPlot;
    
    pixhawk's avatar
    pixhawk committed
    
    /*!
      \brief Base class for items on the plot canvas
    
    Bryant's avatar
    Bryant committed
    
      A plot item is "something", that can be painted on the plot canvas,
      or only affects the scales of the plot widget. They can be categorized as:
    
      - Representator\n
        A "Representator" is an item that represents some sort of data
        on the plot canvas. The different representator classes are organized
        according to the characteristics of the data:
        - QwtPlotMarker
          Represents a point or a horizontal/vertical coordinate
        - QwtPlotCurve
          Represents a series of points
        - QwtPlotSpectrogram ( QwtPlotRasterItem )
          Represents raster data
        - ...
    
      - Decorators\n
        A "Decorator" is an item, that displays additional information, that
        is not related to any data:
        - QwtPlotGrid
        - QwtPlotScaleItem
        - QwtPlotSvgItem
        - ...
    
      Depending on the QwtPlotItem::ItemAttribute flags, an item is included
      into autoscaling or has an entry on the legend.
    
      Before misusing the existing item classes it might be better to
      implement a new type of plot item
      ( don't implement a watermark as spectrogram ).
      Deriving a new type of QwtPlotItem primarily means to implement
      the YourPlotItem::draw() method.
    
      \sa The cpuplot example shows the implementation of additional plot items.
    
    pixhawk's avatar
    pixhawk committed
    */
    
    
    Bryant's avatar
    Bryant committed
    class QWT_EXPORT QwtPlotItem
    
    pixhawk's avatar
    pixhawk committed
    {
    public:
    
    Bryant's avatar
    Bryant committed
        /*!
            \brief Runtime type information
    
            RttiValues is used to cast plot items, without
            having to enable runtime type information of the compiler.
         */
        enum RttiValues
        {
            //! Unspecific value, that can be used, when it doesn't matter
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotItem = 0,
    
    
    Bryant's avatar
    Bryant committed
            //! For QwtPlotGrid
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotGrid,
    
    Bryant's avatar
    Bryant committed
    
            //! For QwtPlotScaleItem
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotScale,
    
    Bryant's avatar
    Bryant committed
    
            //! For QwtPlotLegendItem
            Rtti_PlotLegend,
    
            //! For QwtPlotMarker
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotMarker,
    
    Bryant's avatar
    Bryant committed
    
            //! For QwtPlotCurve
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotCurve,
    
    Bryant's avatar
    Bryant committed
    
            //! For QwtPlotSpectroCurve
            Rtti_PlotSpectroCurve,
    
            //! For QwtPlotIntervalCurve
            Rtti_PlotIntervalCurve,
    
            //! For QwtPlotHistogram
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotHistogram,
    
    Bryant's avatar
    Bryant committed
    
            //! For QwtPlotSpectrogram
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotSpectrogram,
    
    Bryant's avatar
    Bryant committed
    
            //! For QwtPlotSvgItem
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotSVG,
    
    
    Bryant's avatar
    Bryant committed
            //! For QwtPlotTradingCurve
            Rtti_PlotTradingCurve,
    
            //! For QwtPlotBarChart
            Rtti_PlotBarChart,
    
            //! For QwtPlotMultiBarChart
            Rtti_PlotMultiBarChart,
    
            //! For QwtPlotShapeItem
            Rtti_PlotShape,
    
            //! For QwtPlotTextLabel
            Rtti_PlotTextLabel,
    
            //! For QwtPlotZoneItem
            Rtti_PlotZone,
    
            /*! 
               Values >= Rtti_PlotUserItem are reserved for plot items
               not implemented in the Qwt library.
             */
    
    pixhawk's avatar
    pixhawk committed
            Rtti_PlotUserItem = 1000
        };
    
    
    Bryant's avatar
    Bryant committed
        /*!
           \brief Plot Item Attributes
    
           Various aspects of a plot widget depend on the attributes of
           the attached plot items. If and how a single plot item 
           participates in these updates depends on its attributes.
           
           \sa setItemAttribute(), testItemAttribute(), ItemInterest
         */
        enum ItemAttribute
        {
            //! The item is represented on the legend.
            Legend = 0x01,
    
            /*!
               The boundingRect() of the item is included in the
               autoscaling calculation as long as its width or height
               is >= 0.0.
             */
            AutoScale = 0x02,
    
            /*!
               The item needs extra space to display something outside
               its bounding rectangle. 
               \sa getCanvasMarginHint()
             */
            Margins = 0x04
    
    pixhawk's avatar
    pixhawk committed
        };
    
    
    Bryant's avatar
    Bryant committed
        //! Plot Item Attributes
        typedef QFlags<ItemAttribute> ItemAttributes;
    
        /*!
           \brief Plot Item Interests
    
           Plot items might depend on the situation of the corresponding
           plot widget. By enabling an interest the plot item will be
           notified, when the corresponding attribute of the plot widgets
           has changed.
    
           \sa setItemAttribute(), testItemAttribute(), ItemInterest
         */
        enum ItemInterest
        {
            /*! 
               The item is interested in updates of the scales
               \sa updateScaleDiv()
             */
            ScaleInterest = 0x01,
    
            /*! 
               The item is interested in updates of the legend ( of other items )
               This flag is intended for items, that want to implement a legend
               for displaying entries of other plot item.
    
               \note If the plot item wants to be represented on a legend
                     enable QwtPlotItem::Legend instead.
    
               \sa updateLegend()
             */
            LegendInterest = 0x02
    
    pixhawk's avatar
    pixhawk committed
        };
    
    
    Bryant's avatar
    Bryant committed
        //! Plot Item Interests
        typedef QFlags<ItemInterest> ItemInterests;
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        //! Render hints
        enum RenderHint
        {
            //! Enable antialiasing
            RenderAntialiased = 0x1
        };
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        //! Render hints
        typedef QFlags<RenderHint> RenderHints;
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        explicit QwtPlotItem( const QwtText &title = QwtText() );
        virtual ~QwtPlotItem();
    
        void attach( QwtPlot *plot );
        void detach();
    
    pixhawk's avatar
    pixhawk committed
    
        QwtPlot *plot() const;
    
    Bryant's avatar
    Bryant committed
        void setTitle( const QString &title );
        void setTitle( const QwtText &title );
    
    pixhawk's avatar
    pixhawk committed
        const QwtText &title() const;
    
        virtual int rtti() const;
    
    
    Bryant's avatar
    Bryant committed
        void setItemAttribute( ItemAttribute, bool on = true );
        bool testItemAttribute( ItemAttribute ) const;
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        void setItemInterest( ItemInterest, bool on = true );
        bool testItemInterest( ItemInterest ) const;
    
        void setRenderHint( RenderHint, bool on = true );
        bool testRenderHint( RenderHint ) const;
    
        void setRenderThreadCount( uint numThreads );
        uint renderThreadCount() const;
    
        void setLegendIconSize( const QSize & );
        QSize legendIconSize() const;
    
    pixhawk's avatar
    pixhawk committed
    
    
        double z() const;
    
    Bryant's avatar
    Bryant committed
        void setZ( double z );
    
    pixhawk's avatar
    pixhawk committed
    
        void show();
        void hide();
    
    Bryant's avatar
    Bryant committed
        virtual void setVisible( bool );
    
    pixhawk's avatar
    pixhawk committed
        bool isVisible () const;
    
    
    Bryant's avatar
    Bryant committed
        void setAxes( int xAxis, int yAxis );
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        void setXAxis( int axis );
    
    pixhawk's avatar
    pixhawk committed
        int xAxis() const;
    
    
    Bryant's avatar
    Bryant committed
        void setYAxis( int axis );
    
    pixhawk's avatar
    pixhawk committed
        int yAxis() const;
    
        virtual void itemChanged();
    
    Bryant's avatar
    Bryant committed
        virtual void legendChanged();
    
    pixhawk's avatar
    pixhawk committed
    
        /*!
          \brief Draw the item
    
          \param painter Painter
          \param xMap Maps x-values into pixel coordinates.
          \param yMap Maps y-values into pixel coordinates.
          \param canvasRect Contents rect of the canvas in painter coordinates
        */
    
    Bryant's avatar
    Bryant committed
        virtual void draw( QPainter *painter,
            const QwtScaleMap &xMap, const QwtScaleMap &yMap,
            const QRectF &canvasRect ) const = 0;
    
        virtual QRectF boundingRect() const;
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        virtual void getCanvasMarginHint( 
            const QwtScaleMap &xMap, const QwtScaleMap &yMap,
            const QRectF &canvasSize,
            double &left, double &top, double &right, double &bottom) const;
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        virtual void updateScaleDiv( 
            const QwtScaleDiv&, const QwtScaleDiv& );
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        virtual void updateLegend( const QwtPlotItem *,
            const QList<QwtLegendData> & );
    
    pixhawk's avatar
    pixhawk committed
    
    
    Bryant's avatar
    Bryant committed
        QRectF scaleRect( const QwtScaleMap &, const QwtScaleMap & ) const;
        QRectF paintRect( const QwtScaleMap &, const QwtScaleMap & ) const;
    
    Bryant's avatar
    Bryant committed
        virtual QList<QwtLegendData> legendData() const;
    
        virtual QwtGraphic legendIcon( int index, const QSizeF  & ) const;
    
    protected:
        QwtGraphic defaultIcon( const QBrush &, const QSizeF & ) const;
    
    pixhawk's avatar
    pixhawk committed
    
    private:
        // Disabled copy constructor and operator=
        QwtPlotItem( const QwtPlotItem & );
        QwtPlotItem &operator=( const QwtPlotItem & );
    
        class PrivateData;
        PrivateData *d_data;
    };
    
    Bryant's avatar
    Bryant committed
    Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotItem::ItemAttributes )
    Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotItem::ItemInterests )
    Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotItem::RenderHints )
    
    Q_DECLARE_METATYPE( QwtPlotItem * )
    
    
    pixhawk's avatar
    pixhawk committed
    #endif