Skip to content
qwt_plot_canvas.h 4.84 KiB
Newer Older
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_CANVAS_H
#define QWT_PLOT_CANVAS_H

#include "qwt_global.h"
Bryant's avatar
Bryant committed
#include <qframe.h>
#include <qpainterpath.h>
pixhawk's avatar
pixhawk committed

class QwtPlot;
class QPixmap;

/*!
Bryant's avatar
Bryant committed
  \brief Canvas of a QwtPlot.
  
   Canvas is the widget where all plot items are displayed

  \sa QwtPlot::setCanvas(), QwtPlotGLCanvas
pixhawk's avatar
pixhawk committed
*/
class QWT_EXPORT QwtPlotCanvas : public QFrame
{
    Q_OBJECT

Bryant's avatar
Bryant committed
    Q_PROPERTY( double borderRadius READ borderRadius WRITE setBorderRadius )

pixhawk's avatar
pixhawk committed
public:

    /*!
      \brief Paint attributes
Bryant's avatar
Bryant committed
      The default setting enables BackingStore and Opaque.
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
      \sa setPaintAttribute(), testPaintAttribute()
pixhawk's avatar
pixhawk committed
     */
Bryant's avatar
Bryant committed
    enum PaintAttribute
    {
        /*!
          \brief Paint double buffered reusing the content 
                 of the pixmap buffer when possible. 

          Using a backing store might improve the performance
          significantly, when working with widget overlays ( like rubber bands ).
          Disabling the cache might improve the performance for
          incremental paints (using QwtPlotDirectPainter ).

          \sa backingStore(), invalidateBackingStore()
         */
        BackingStore = 1,

        /*!
          \brief Try to fill the complete contents rectangle
                 of the plot canvas

          When using styled backgrounds Qt assumes, that the
          canvas doesn't fill its area completely 
          ( f.e because of rounded borders ) and fills the area
          below the canvas. When this is done with gradients it might
          result in a serious performance bottleneck - depending on the size.

          When the Opaque attribute is enabled the canvas tries to
          identify the gaps with some heuristics and to fill those only. 

          \warning Will not work for semitransparent backgrounds 
         */
        Opaque       = 2,

        /*!
          \brief Try to improve painting of styled backgrounds

          QwtPlotCanvas supports the box model attributes for
          customizing the layout with style sheets. Unfortunately
          the design of Qt style sheets has no concept how to
          handle backgrounds with rounded corners - beside of padding.

          When HackStyledBackground is enabled the plot canvas tries
          to separate the background from the background border
          by reverse engineering to paint the background before and
          the border after the plot items. In this order the border
          gets perfectly antialiased and you can avoid some pixel
          artifacts in the corners.
         */
        HackStyledBackground = 4,

        /*!
          When ImmediatePaint is set replot() calls repaint()
          instead of update().

          \sa replot(), QWidget::repaint(), QWidget::update()
         */
        ImmediatePaint = 8
pixhawk's avatar
pixhawk committed
    };

Bryant's avatar
Bryant committed
    //! Paint attributes
    typedef QFlags<PaintAttribute> PaintAttributes;

pixhawk's avatar
pixhawk committed
    /*!
      \brief Focus indicator
Bryant's avatar
Bryant committed
      The default setting is NoFocusIndicator
pixhawk's avatar
pixhawk committed
      \sa setFocusIndicator(), focusIndicator(), paintFocus()
    */

Bryant's avatar
Bryant committed
    enum FocusIndicator
    {
        //! Don't paint a focus indicator
pixhawk's avatar
pixhawk committed
        NoFocusIndicator,
Bryant's avatar
Bryant committed

        /*!
          The focus is related to the complete canvas.
          Paint the focus indicator using paintFocus()
         */
pixhawk's avatar
pixhawk committed
        CanvasFocusIndicator,
Bryant's avatar
Bryant committed

        /*!
          The focus is related to an item (curve, point, ...) on
          the canvas. It is up to the application to display a
          focus indication using f.e. highlighting.
         */
pixhawk's avatar
pixhawk committed
        ItemFocusIndicator
    };

Bryant's avatar
Bryant committed
    explicit QwtPlotCanvas( QwtPlot * = NULL );
pixhawk's avatar
pixhawk committed
    virtual ~QwtPlotCanvas();

    QwtPlot *plot();
    const QwtPlot *plot() const;

Bryant's avatar
Bryant committed
    void setFocusIndicator( FocusIndicator );
pixhawk's avatar
pixhawk committed
    FocusIndicator focusIndicator() const;

Bryant's avatar
Bryant committed
    void setBorderRadius( double );
    double borderRadius() const;
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
    void setPaintAttribute( PaintAttribute, bool on = true );
    bool testPaintAttribute( PaintAttribute ) const;
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
    const QPixmap *backingStore() const;
    void invalidateBackingStore();
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
    virtual bool event( QEvent * );
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
    Q_INVOKABLE QPainterPath borderPath( const QRect & ) const;
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
public Q_SLOTS:
    void replot();

protected:
    virtual void paintEvent( QPaintEvent * );
    virtual void resizeEvent( QResizeEvent * );

    virtual void drawFocusIndicator( QPainter * );
    virtual void drawBorder( QPainter * );

    void updateStyleSheetInfo();
pixhawk's avatar
pixhawk committed

Bryant's avatar
Bryant committed
    void drawCanvas( QPainter *, bool withBackground );
pixhawk's avatar
pixhawk committed

    class PrivateData;
    PrivateData *d_data;
};

Bryant's avatar
Bryant committed
Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotCanvas::PaintAttributes )

pixhawk's avatar
pixhawk committed
#endif