blob: 3df87b8fe8b69db55200fcb493a9dd13074f2195 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
/*
* KAsteroids - Copyright (c) Martin R. Jones 1997
*
* Part of the KDE project
*/
#include <qpainter.h>
#include "ledmeter.h"
#include "ledmeter.moc"
KALedMeter::KALedMeter( QWidget *parent ) : QFrame( parent )
{
mCRanges.setAutoDelete( true );
mRange = 100;
mCount = 20;
mCurrentCount = 0;
mValue = 0;
setMinimumWidth( mCount * 2 + frameWidth() );
}
void KALedMeter::setRange( int r )
{
mRange = r;
if ( mRange < 1 )
mRange = 1;
setValue( mValue );
update();
}
void KALedMeter::setCount( int c )
{
mCount = c;
if ( mCount < 1 )
mCount = 1;
setMinimumWidth( mCount * 2 + frameWidth() );
calcColorRanges();
setValue( mValue );
update();
}
void KALedMeter::setValue( int v )
{
mValue = v;
if ( mValue > mRange )
mValue = mRange;
else if ( mValue < 0 )
mValue = 0;
int c = ( mValue + mRange / mCount - 1 ) * mCount / mRange;
if ( c != mCurrentCount )
{
mCurrentCount = c;
update();
}
}
void KALedMeter::addColorRange( int pc, const QColor &c )
{
ColorRange *cr = new ColorRange;
cr->mPc = pc;
cr->mColor = c;
mCRanges.append( cr );
calcColorRanges();
}
void KALedMeter::resizeEvent( QResizeEvent *e )
{
QFrame::resizeEvent( e );
int w = ( width() - frameWidth() - 2 ) / mCount * mCount;
w += frameWidth() + 2;
setFrameRect( QRect( 0, 0, w, height() ) );
}
void KALedMeter::drawContents( QPainter *p )
{
QRect b = contentsRect();
unsigned cidx = 0;
int ncol = mCount;
QColor col = colorGroup().foreground();
if ( !mCRanges.isEmpty() )
{
col = mCRanges.at( cidx )->mColor;
ncol = mCRanges.at( cidx )->mValue;
}
p->setBrush( col );
p->setPen( col );
int lw = b.width() / mCount;
int lx = b.left() + 1;
for ( int i = 0; i < mCurrentCount; i++, lx += lw )
{
if ( i > ncol )
{
if ( ++cidx < mCRanges.count() )
{
col = mCRanges.at( cidx )->mColor;
ncol = mCRanges.at( cidx )->mValue;
p->setBrush( col );
p->setPen( col );
}
}
p->drawRect( lx, b.top() + 1, lw - 1, b.height() - 2 );
}
}
void KALedMeter::calcColorRanges()
{
int prev = 0;
ColorRange *cr;
for ( cr = mCRanges.first(); cr; cr = mCRanges.next() )
{
cr->mValue = prev + cr->mPc * mCount / 100;
prev = cr->mValue;
}
}
|