📄 qwt_analog_clock.cpp
字号:
#include "qwt_analog_clock.h"/*! Constructor \param parent Parent widget \param name Widget name*/QwtAnalogClock::QwtAnalogClock(QWidget *parent, const char* name): QwtDial(parent, name){ setWrapping(TRUE); setReadOnly(TRUE); setOrigin(270.0); setRange(0.0, 60.0 * 60.0 * 12.0); // seconds setScale(-1, 5, 60.0 * 60.0); setScaleOptions(ScaleTicks | ScaleLabel); setScaleTicks(1, 0, 8); const QColor knobColor = palette().color(QPalette::Active, QColorGroup::Text).dark(120); QColor handColor; int width; for ( int i = 0; i < NHands; i++ ) { if ( i == SecondHand ) { width = 2; handColor = knobColor.dark(120); } else { width = 8; handColor = knobColor; } QwtDialSimpleNeedle *hand = new QwtDialSimpleNeedle( QwtDialSimpleNeedle::Arrow, TRUE, handColor, knobColor); hand->setWidth(width); d_hand[i] = NULL; setHand((Hand)i, hand); }}//! DestructorQwtAnalogClock::~QwtAnalogClock(){ for ( int i = 0; i < NHands; i++ ) delete d_hand[i];}/*! Nop method, use setHand instead \sa QwtAnalogClock::setHand*/void QwtAnalogClock::setNeedle(QwtDialNeedle *){ // no op return;}/*! Set a clockhand \param hand Specifies the type of hand \param needle Hand \sa QwtAnalogClock::hand()*/void QwtAnalogClock::setHand(Hand hand, QwtDialNeedle *needle){ if ( hand >= 0 || hand < NHands ) { delete d_hand[hand]; d_hand[hand] = needle; }}/*! \return Clock hand \param hd Specifies the type of hand \sa QwtAnalogClock::setHand*/QwtDialNeedle *QwtAnalogClock::hand(Hand hd){ if ( hd < 0 || hd >= NHands ) return NULL; return d_hand[hd];}/*! \return Clock hand \param hd Specifies the type of hand \sa QwtAnalogClock::setHand*/const QwtDialNeedle *QwtAnalogClock::hand(Hand hd) const{ return ((QwtAnalogClock *)this)->hand(hd);}/*! \brief Set the current time This is the same as QwtAnalogClock::setTime(), but Qt < 3.0 can磘 handle default parameters for slots.*/void QwtAnalogClock::setCurrentTime(){ setTime(QTime::currentTime()); }/*! Set a time \param time Time to display*/void QwtAnalogClock::setTime(const QTime &time){ if ( time.isValid() ) { setValue((time.hour() % 12) * 60.0 * 60.0 + time.minute() * 60.0 + time.second()); } else setValid(FALSE);}/*! Find the scale label for a given value \param value Value \return Label*/QString QwtAnalogClock::scaleLabel(double value) const{ if ( value == 0.0 ) value = 60.0 * 60.0 * 12.0; QString label; label.sprintf("%d", int(value / (60.0 * 60.0))); return label;}/*! \brief Draw the needle A clock has no single needle but three hands instead. drawNeedle translates value() into directions for the hands and calls drawHand(). \param painter Painter \param center Center of the clock \param radius Maximum length for the hands \param direction Dummy, not used. \param cg ColorGroup \sa QwtAnalogClock::drawHand()*/void QwtAnalogClock::drawNeedle(QPainter *painter, const QPoint ¢er, int radius, double, QPalette::ColorGroup cg) const{ if ( isValid() ) { const double hours = value() / (60.0 * 60.0); const double minutes = (value() - (int)hours * 60.0 * 60.0) / 60.0; const double seconds = value() - (int)hours * 60.0 * 60.0 - (int)minutes * 60.0; drawHand(painter, HourHand, center, radius, 360.0 - (origin() + 360.0 * hours / 12.0), cg); drawHand(painter, MinuteHand, center, radius, 360.0 - (origin() + 360.0 * minutes / 60.0), cg); drawHand(painter, SecondHand, center, radius, 360.0 - (origin() + 360.0 * seconds / 60.0), cg); }}/*! Draw a clock hand \param painter Painter \param hd Specify the type of hand \param center Center of the clock \param radius Maximum length for the hands \param direction Direction of the hand in degrees, counter clockwise \param cg ColorGroup*/void QwtAnalogClock::drawHand(QPainter *painter, Hand hd, const QPoint ¢er, int radius, double direction, QPalette::ColorGroup cg) const{ const QwtDialNeedle *needle = hand(hd); if ( needle ) { if ( hd == HourHand ) radius = qRound(0.8 * radius); needle->draw(painter, center, radius, direction, cg); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -