23 return map.
isInverting() ? ( radius > map.
s1() ) : ( radius < map.
s1() );
31 i1 = qBound( 0, i1, size - 1 );
32 i2 = qBound( 0, i2, size - 1 );
37 return ( i2 - i1 + 1 );
48 pen = QPen( Qt::black );
278 const QPointF &pole,
double radius,
279 const QRectF &canvasRect )
const 282 Q_UNUSED( canvasRect );
284 draw( painter, azimuthMap, radialMap, pole, 0, -1 );
301 const QPointF &pole,
int from,
int to )
const 315 azimuthMap, radialMap, pole, from, to );
323 azimuthMap, radialMap, pole, from, to );
343 const QPointF &pole,
int from,
int to )
const 348 drawLines( painter, azimuthMap, radialMap, pole, from, to );
369 const QPointF &pole,
int from,
int to )
const 371 int size = to - from + 1;
379 QPolygonF points( size );
380 for (
int j = from; j <= to; j++ )
383 points[j - from] = QPointF( point.
azimuth(), point.
radius() );
388 polyline.resize( points.size() );
390 QPointF *polylineData = polyline.data();
391 QPointF *pointsData = points.data();
393 for (
int i = 0; i < points.size(); i++ )
395 const QwtPointPolar point( pointsData[i].x(), pointsData[i].y() );
405 polyline.resize( size );
406 QPointF *polylineData = polyline.data();
408 for (
int i = from; i <= to; i++ )
419 polylineData[i - from] = pole;
425 if ( painter->hasClipping() )
427 clipRect = painter->clipRegion().boundingRect();
431 clipRect = painter->window();
432 if ( !clipRect.isEmpty() )
433 clipRect = painter->transform().inverted().mapRect( clipRect );
436 if ( !clipRect.isEmpty() )
438 double off = qCeil( qMax( qreal( 1.0 ), painter->pen().widthF() ) );
439 clipRect = clipRect.toRect().adjusted( -off, -off, off, off );
461 const QPointF &pole,
int from,
int to )
const 463 painter->setBrush( symbol.
brush() );
464 painter->setPen( symbol.
pen() );
466 const int chunkSize = 500;
468 for (
int i = from; i <= to; i += chunkSize )
470 const int n = qMin( chunkSize, to - i + 1 );
473 for (
int j = 0; j < n; j++ )
490 if ( points.size() > 0 )
514 const QSizeF &size )
const 518 if ( size.isEmpty() )
525 QPainter painter( &graphic );
526 painter.setRenderHint( QPainter::Antialiasing,
535 brush = QBrush(
pen().color() );
543 if ( brush.style() != Qt::NoBrush )
545 QRectF r( 0, 0, size.width(), size.height() );
546 painter.fillRect( r, brush );
552 if (
pen() != Qt::NoPen )
555 pn.setCapStyle( Qt::FlatCap );
557 painter.setPen( pn );
559 const double y = 0.5 * size.height();
568 QRectF r( 0, 0, size.width(), size.height() );
590 return QwtInterval( boundingRect.left(), boundingRect.right() );
593 return QwtInterval( boundingRect.top(), boundingRect.bottom() );
bool testLegendAttribute(LegendAttribute) const
Test if a lefend attribute is enables.
A point in polar coordinates.
void setData(QwtSeriesData< QwtPointPolar > *data)
LegendAttribute
Attributes how to represent the curve on the legend.
virtual QRectF boundingRect() const =0
static void drawLine(QPainter *, qreal x1, qreal y1, qreal x2, qreal y2)
Wrapper for QPainter::drawLine()
A class representing an interval.
QwtPolarCurve::CurveStyle style
QPoint qwtPolar2Pos(const QPoint &pole, double radius, double angle)
void setStyle(CurveStyle style)
double radius() const
Returns the radius.
QwtSeriesData< QwtPointPolar > * d_series
An item, that represents a series of points.
QwtPolarCurve::LegendAttributes legendAttributes
virtual QwtInterval boundingInterval(int scaleId) const QWT_OVERRIDE
virtual void draw(QPainter *p, const QwtScaleMap &azimuthMap, const QwtScaleMap &radialMap, const QPointF &pole, double radius, const QRectF &canvasRect) const QWT_OVERRIDE
void init()
Initialize data members.
A class for drawing symbols.
double azimuth() const
Returns the azimuth.
QFlags< LegendAttribute > LegendAttributes
Legend attributes.
virtual int rtti() const QWT_OVERRIDE
void setRenderHint(RenderHint, bool on=true)
void setDefaultSize(const QSizeF &)
Set a default size.
virtual ~QwtPolarCurve()
Destructor.
Base class for items on a polar plot.
QwtPointPolar sample(int i) const
const QwtSymbol * symbol() const
bool testRenderHint(RenderHint) const
void setItemAttribute(ItemAttribute, bool on=true)
void setZ(double z)
Set the z value.
static void clipPolygonF(const QRectF &, QPolygonF &, bool closePolygon=false)
A class representing a text.
void drawLines(QPainter *, const QwtScaleMap &azimuthMap, const QwtScaleMap &radialMap, const QPointF &pole, int from, int to) const
QwtCurveFitter * curveFitter() const
void setLegendAttribute(LegendAttribute, bool on=true)
A paint device for scalable graphics.
void drawSymbols(QPainter *, const QPolygonF &) const
Draw symbols at the specified points.
static bool qwtInsidePole(const QwtScaleMap &map, double radius)
If the curve has a valid symbol it is painted.
const QwtSeriesData< QwtPointPolar > * data() const
virtual void drawCurve(QPainter *, int style, const QwtScaleMap &azimuthMap, const QwtScaleMap &radialMap, const QPointF &pole, int from, int to) const
virtual void drawSymbols(QPainter *, const QwtSymbol &, const QwtScaleMap &azimuthMap, const QwtScaleMap &radialMap, const QPointF &pole, int from, int to) const
static void drawPolyline(QPainter *, const QPolygonF &)
Wrapper for QPainter::drawPolyline()
void setSymbol(QwtSymbol *)
Assign a symbol.
virtual size_t size() const =0
void setPen(const QPen &)
Assign a pen.
virtual QPolygonF fitCurve(const QPolygonF &polygon) const =0
The item is represented on the legend.
const QwtText & title() const
double transform(double s) const
QwtCurveFitter * curveFitter
static int qwtVerifyRange(int size, int &i1, int &i2)
Don't draw a curve. Note: This doesn't affect the symbols.
virtual void itemChanged()
QwtPolarCurve()
Constructor.
void drawSymbol(QPainter *, const QRectF &) const
Draw the symbol into a rectangle.
virtual QwtGraphic legendIcon(int index, const QSizeF &) const QWT_OVERRIDE
Abstract base class for a curve fitter.
const QBrush & brush() const
void setCurveFitter(QwtCurveFitter *)
Insert a curve fitter.
No Style. The symbol cannot be drawn.
void setRenderHint(RenderHint, bool on=true)