QGIS/external/qwt-6.3.0/qwt_series_store.h
Juergen E. Fischer 33fc476d89 * replace external qwtpolar with qwt 6.3
* require qwt >=6.2 (and fallback to internal 6.3 if system's qwt doesn't suffice)
* debian doesn't have qwt for Qt6 and won't have it for trixie
2025-07-23 07:11:51 +10:00

209 lines
5.2 KiB
C++

/******************************************************************************
* Qwt Widget Library
* Copyright (C) 1997 Josef Wilgen
* Copyright (C) 2002 Uwe Rathmann
*
* 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_SERIES_STORE_H
#define QWT_SERIES_STORE_H
#include "qwt_global.h"
#include "qwt_series_data.h"
/*!
\brief Bridge between QwtSeriesStore and QwtPlotSeriesItem
QwtAbstractSeriesStore is an abstract interface only
to make it possible to isolate the template based methods ( QwtSeriesStore )
from the regular methods ( QwtPlotSeriesItem ) to make it possible
to derive from QwtPlotSeriesItem without any hassle with templates.
*/
class QwtAbstractSeriesStore
{
public:
//! Destructor
virtual ~QwtAbstractSeriesStore() {}
protected:
#ifndef QWT_PYTHON_WRAPPER
//! dataChanged() indicates, that the series has been changed.
virtual void dataChanged() = 0;
/*!
Set a the "rectangle of interest" for the stored series
\sa QwtSeriesData<T>::setRectOfInterest()
*/
virtual void setRectOfInterest( const QRectF& ) = 0;
//! \return Bounding rectangle of the stored series
virtual QRectF dataRect() const = 0;
//! \return Number of samples
virtual size_t dataSize() const = 0;
#else
// Needed for generating the python bindings, but not for using them !
virtual void dataChanged() {}
virtual void setRectOfInterest( const QRectF& ) {}
virtual QRectF dataRect() const { return QRectF( 0.0, 0.0, -1.0, -1.0 ); }
virtual size_t dataSize() const { return 0; }
#endif
};
/*!
\brief Class storing a QwtSeriesData object
QwtSeriesStore and QwtPlotSeriesItem are intended as base classes for all
plot items iterating over a series of samples. Both classes share
a virtual base class ( QwtAbstractSeriesStore ) to bridge between them.
QwtSeriesStore offers the template based part for the plot item API, so
that QwtPlotSeriesItem can be derived without any hassle with templates.
*/
template< typename T >
class QwtSeriesStore : public virtual QwtAbstractSeriesStore
{
public:
/*!
\brief Constructor
The store contains no series
*/
explicit QwtSeriesStore();
//! Destructor
~QwtSeriesStore();
/*!
Assign a series of samples
\param series Data
\warning The item takes ownership of the data object, deleting
it when its not used anymore.
*/
void setData( QwtSeriesData< T >* series );
//! \return the the series data
QwtSeriesData< T >* data();
//! \return the the series data
const QwtSeriesData< T >* data() const;
/*!
\param index Index
\return Sample at position index
*/
T sample( int index ) const;
/*!
\return Number of samples of the series
\sa setData(), QwtSeriesData<T>::size()
*/
virtual size_t dataSize() const QWT_OVERRIDE;
/*!
\return Bounding rectangle of the series
or an invalid rectangle, when no series is stored
\sa QwtSeriesData<T>::boundingRect()
*/
virtual QRectF dataRect() const QWT_OVERRIDE;
/*!
Set a the "rect of interest" for the series
\param rect Rectangle of interest
\sa QwtSeriesData<T>::setRectOfInterest()
*/
virtual void setRectOfInterest( const QRectF& rect ) QWT_OVERRIDE;
/*!
Replace a series without deleting the previous one
\param series New series
\return Previously assigned series
*/
QwtSeriesData< T >* swapData( QwtSeriesData< T >* series );
private:
QwtSeriesData< T >* m_series;
};
template< typename T >
QwtSeriesStore< T >::QwtSeriesStore()
: m_series( NULL )
{
}
template< typename T >
QwtSeriesStore< T >::~QwtSeriesStore()
{
delete m_series;
}
template< typename T >
inline QwtSeriesData< T >* QwtSeriesStore< T >::data()
{
return m_series;
}
template< typename T >
inline const QwtSeriesData< T >* QwtSeriesStore< T >::data() const
{
return m_series;
}
template< typename T >
inline T QwtSeriesStore< T >::sample( int index ) const
{
return m_series ? m_series->sample( index ) : T();
}
template< typename T >
void QwtSeriesStore< T >::setData( QwtSeriesData< T >* series )
{
if ( m_series != series )
{
delete m_series;
m_series = series;
dataChanged();
}
}
template< typename T >
size_t QwtSeriesStore< T >::dataSize() const
{
if ( m_series == NULL )
return 0;
return m_series->size();
}
template< typename T >
QRectF QwtSeriesStore< T >::dataRect() const
{
if ( m_series == NULL )
return QRectF( 1.0, 1.0, -2.0, -2.0 ); // invalid
return m_series->boundingRect();
}
template< typename T >
void QwtSeriesStore< T >::setRectOfInterest( const QRectF& rect )
{
if ( m_series )
m_series->setRectOfInterest( rect );
}
template< typename T >
QwtSeriesData< T >* QwtSeriesStore< T >::swapData( QwtSeriesData< T >* series )
{
QwtSeriesData< T >* swappedSeries = m_series;
m_series = series;
return swappedSeries;
}
#endif