-rw-r--r-- | core/settings/light-and-power/calibration.cpp | 1 | ||||
-rw-r--r-- | core/settings/light-and-power/light.cpp | 2 | ||||
-rw-r--r-- | core/settings/light-and-power/main.cpp | 3 | ||||
-rw-r--r-- | core/settings/light-and-power/sensor.cpp | 1 |
4 files changed, 0 insertions, 7 deletions
diff --git a/core/settings/light-and-power/calibration.cpp b/core/settings/light-and-power/calibration.cpp index c5377d0..504520e 100644 --- a/core/settings/light-and-power/calibration.cpp +++ b/core/settings/light-and-power/calibration.cpp | |||
@@ -1,346 +1,345 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. Copyright (c) 2002 Maximilian Reiss <harlekin@handhelds.org> | 3 | =. Copyright (c) 2002 Maximilian Reiss <harlekin@handhelds.org> |
4 | .=l. Copyright (c) 2002 Robert Griebl <sandman@handhelds.org> | 4 | .=l. Copyright (c) 2002 Robert Griebl <sandman@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | #include "calibration.h" | 28 | #include "calibration.h" |
29 | 29 | ||
30 | #include <qpainter.h> | 30 | #include <qpainter.h> |
31 | #include <qpalette.h> | ||
32 | #include <qpixmap.h> | 31 | #include <qpixmap.h> |
33 | 32 | ||
34 | #define BRD 3 | 33 | #define BRD 3 |
35 | 34 | ||
36 | Calibration::Calibration ( QWidget *parent, const char *name, WFlags fl ) | 35 | Calibration::Calibration ( QWidget *parent, const char *name, WFlags fl ) |
37 | : QWidget ( parent, name, fl | WRepaintNoErase ) | 36 | : QWidget ( parent, name, fl | WRepaintNoErase ) |
38 | { | 37 | { |
39 | setBackgroundMode ( NoBackground ); | 38 | setBackgroundMode ( NoBackground ); |
40 | 39 | ||
41 | m_scale = QSize ( 256, 256 ); | 40 | m_scale = QSize ( 256, 256 ); |
42 | m_steps = 5; | 41 | m_steps = 5; |
43 | m_dragged = -1; | 42 | m_dragged = -1; |
44 | m_interval = 5; | 43 | m_interval = 5; |
45 | 44 | ||
46 | m_p [0] = QPoint ( 0, 0 ); | 45 | m_p [0] = QPoint ( 0, 0 ); |
47 | m_p [1] = QPoint ( 255, 255 ); | 46 | m_p [1] = QPoint ( 255, 255 ); |
48 | } | 47 | } |
49 | 48 | ||
50 | Calibration::~Calibration ( ) | 49 | Calibration::~Calibration ( ) |
51 | { | 50 | { |
52 | } | 51 | } |
53 | 52 | ||
54 | void Calibration::setScale ( const QSize &s ) | 53 | void Calibration::setScale ( const QSize &s ) |
55 | { | 54 | { |
56 | if ( s. width ( ) < 1 || s. height ( ) < 1 ) | 55 | if ( s. width ( ) < 1 || s. height ( ) < 1 ) |
57 | return; | 56 | return; |
58 | 57 | ||
59 | m_scale = s; | 58 | m_scale = s; |
60 | checkPoints ( ); | 59 | checkPoints ( ); |
61 | 60 | ||
62 | update ( ); | 61 | update ( ); |
63 | } | 62 | } |
64 | 63 | ||
65 | QSize Calibration::scale ( ) const | 64 | QSize Calibration::scale ( ) const |
66 | { | 65 | { |
67 | return m_scale; | 66 | return m_scale; |
68 | } | 67 | } |
69 | 68 | ||
70 | void Calibration::setLineSteps ( int steps ) | 69 | void Calibration::setLineSteps ( int steps ) |
71 | { | 70 | { |
72 | if ( m_steps < 2 ) | 71 | if ( m_steps < 2 ) |
73 | return; | 72 | return; |
74 | 73 | ||
75 | m_steps = steps; | 74 | m_steps = steps; |
76 | update ( ); | 75 | update ( ); |
77 | } | 76 | } |
78 | 77 | ||
79 | int Calibration::lineSteps ( ) const | 78 | int Calibration::lineSteps ( ) const |
80 | { | 79 | { |
81 | return m_steps; | 80 | return m_steps; |
82 | } | 81 | } |
83 | 82 | ||
84 | void Calibration::setInterval ( int iv ) | 83 | void Calibration::setInterval ( int iv ) |
85 | { | 84 | { |
86 | if ( iv < 1 ) | 85 | if ( iv < 1 ) |
87 | return; | 86 | return; |
88 | 87 | ||
89 | m_interval = iv; | 88 | m_interval = iv; |
90 | //update ( ); | 89 | //update ( ); |
91 | } | 90 | } |
92 | 91 | ||
93 | int Calibration::interval ( ) const | 92 | int Calibration::interval ( ) const |
94 | { | 93 | { |
95 | return m_interval; | 94 | return m_interval; |
96 | } | 95 | } |
97 | 96 | ||
98 | void Calibration::setStartPoint ( const QPoint &p ) | 97 | void Calibration::setStartPoint ( const QPoint &p ) |
99 | { | 98 | { |
100 | m_p [0] = QPoint ( p. x ( ), m_scale. height ( ) - p. y ( ) - 1 ); | 99 | m_p [0] = QPoint ( p. x ( ), m_scale. height ( ) - p. y ( ) - 1 ); |
101 | checkPoints ( ); | 100 | checkPoints ( ); |
102 | update ( ); | 101 | update ( ); |
103 | } | 102 | } |
104 | 103 | ||
105 | QPoint Calibration::startPoint ( ) const | 104 | QPoint Calibration::startPoint ( ) const |
106 | { | 105 | { |
107 | return QPoint ( m_p [0]. x ( ), m_scale. height ( ) - m_p [0]. y ( ) - 1 ); | 106 | return QPoint ( m_p [0]. x ( ), m_scale. height ( ) - m_p [0]. y ( ) - 1 ); |
108 | } | 107 | } |
109 | 108 | ||
110 | void Calibration::setEndPoint ( const QPoint &p ) | 109 | void Calibration::setEndPoint ( const QPoint &p ) |
111 | { | 110 | { |
112 | m_p [1] = QPoint ( p. x ( ), m_scale. height ( ) - p. y ( ) - 1 ); | 111 | m_p [1] = QPoint ( p. x ( ), m_scale. height ( ) - p. y ( ) - 1 ); |
113 | checkPoints ( ); | 112 | checkPoints ( ); |
114 | update ( ); | 113 | update ( ); |
115 | } | 114 | } |
116 | 115 | ||
117 | QPoint Calibration::endPoint ( ) const | 116 | QPoint Calibration::endPoint ( ) const |
118 | { | 117 | { |
119 | return QPoint ( m_p [1]. x ( ), m_scale. height ( ) - m_p [1]. y ( ) - 1 ); | 118 | return QPoint ( m_p [1]. x ( ), m_scale. height ( ) - m_p [1]. y ( ) - 1 ); |
120 | } | 119 | } |
121 | 120 | ||
122 | void Calibration::checkPoints ( ) | 121 | void Calibration::checkPoints ( ) |
123 | { | 122 | { |
124 | int dx = m_scale. width ( ); | 123 | int dx = m_scale. width ( ); |
125 | int dy = m_scale. height ( ); | 124 | int dy = m_scale. height ( ); |
126 | 125 | ||
127 | if ( m_p [1]. x ( ) < 0 ) | 126 | if ( m_p [1]. x ( ) < 0 ) |
128 | m_p [1]. setX ( 0 ); | 127 | m_p [1]. setX ( 0 ); |
129 | if ( m_p [1]. x ( ) >= dx ) | 128 | if ( m_p [1]. x ( ) >= dx ) |
130 | m_p [1]. setX ( dx - 1 ); | 129 | m_p [1]. setX ( dx - 1 ); |
131 | if ( m_p [0]. x ( ) < 0 ) | 130 | if ( m_p [0]. x ( ) < 0 ) |
132 | m_p [0]. setX ( 0 ); | 131 | m_p [0]. setX ( 0 ); |
133 | if ( m_p [0]. x ( ) > m_p [1]. x ( )) | 132 | if ( m_p [0]. x ( ) > m_p [1]. x ( )) |
134 | m_p [0]. setX ( m_p [1]. x ( )); | 133 | m_p [0]. setX ( m_p [1]. x ( )); |
135 | 134 | ||
136 | if ( m_p [1]. y ( ) < 0 ) | 135 | if ( m_p [1]. y ( ) < 0 ) |
137 | m_p [1]. setY ( 0 ); | 136 | m_p [1]. setY ( 0 ); |
138 | if ( m_p [1]. y ( ) >= dy ) | 137 | if ( m_p [1]. y ( ) >= dy ) |
139 | m_p [1]. setY ( dy - 1 ); | 138 | m_p [1]. setY ( dy - 1 ); |
140 | if ( m_p [0]. y ( ) < 0 ) | 139 | if ( m_p [0]. y ( ) < 0 ) |
141 | m_p [0]. setY ( 0 ); | 140 | m_p [0]. setY ( 0 ); |
142 | if ( m_p [0]. y ( ) >= dy ) | 141 | if ( m_p [0]. y ( ) >= dy ) |
143 | m_p [0]. setY ( dy - 1 ); | 142 | m_p [0]. setY ( dy - 1 ); |
144 | } | 143 | } |
145 | 144 | ||
146 | 145 | ||
147 | #define SCALEX(x) (BRD+(x)*(width()- 2*BRD)/m_scale.width()) | 146 | #define SCALEX(x) (BRD+(x)*(width()- 2*BRD)/m_scale.width()) |
148 | #define SCALEY(y) (BRD+(y)*(height()-2*BRD)/m_scale.height()) | 147 | #define SCALEY(y) (BRD+(y)*(height()-2*BRD)/m_scale.height()) |
149 | 148 | ||
150 | 149 | ||
151 | static QRect around ( int x, int y ) | 150 | static QRect around ( int x, int y ) |
152 | { | 151 | { |
153 | return QRect ( x - BRD, y - BRD, 2 * BRD + 1, 2 * BRD + 1 ); | 152 | return QRect ( x - BRD, y - BRD, 2 * BRD + 1, 2 * BRD + 1 ); |
154 | } | 153 | } |
155 | 154 | ||
156 | void Calibration::mousePressEvent ( QMouseEvent *e ) | 155 | void Calibration::mousePressEvent ( QMouseEvent *e ) |
157 | { | 156 | { |
158 | if ( e-> button ( ) != LeftButton ) | 157 | if ( e-> button ( ) != LeftButton ) |
159 | return QWidget::mousePressEvent ( e ); | 158 | return QWidget::mousePressEvent ( e ); |
160 | 159 | ||
161 | int olddragged = m_dragged; | 160 | int olddragged = m_dragged; |
162 | int x [2], y [2]; | 161 | int x [2], y [2]; |
163 | 162 | ||
164 | m_dragged = -1; | 163 | m_dragged = -1; |
165 | for ( int i = 0; i < 2; i++ ) { | 164 | for ( int i = 0; i < 2; i++ ) { |
166 | x [i] = SCALEX( m_p [i]. x ( )); | 165 | x [i] = SCALEX( m_p [i]. x ( )); |
167 | y [i] = SCALEY( m_p [i]. y ( )); | 166 | y [i] = SCALEY( m_p [i]. y ( )); |
168 | 167 | ||
169 | if (( QABS( e-> x ( ) - x [i] ) <= 2 * BRD ) && | 168 | if (( QABS( e-> x ( ) - x [i] ) <= 2 * BRD ) && |
170 | ( QABS( e-> y ( ) - y [i] ) <= 2 * BRD )) { | 169 | ( QABS( e-> y ( ) - y [i] ) <= 2 * BRD )) { |
171 | m_dragged = i; | 170 | m_dragged = i; |
172 | break; | 171 | break; |
173 | } | 172 | } |
174 | } | 173 | } |
175 | 174 | ||
176 | if ( m_dragged != olddragged ) { | 175 | if ( m_dragged != olddragged ) { |
177 | QRect r; | 176 | QRect r; |
178 | 177 | ||
179 | if ( olddragged >= 0 ) | 178 | if ( olddragged >= 0 ) |
180 | r |= around ( x [olddragged], y [olddragged] ); | 179 | r |= around ( x [olddragged], y [olddragged] ); |
181 | if ( m_dragged >= 0 ) | 180 | if ( m_dragged >= 0 ) |
182 | r |= around ( x [m_dragged], y [m_dragged] ); | 181 | r |= around ( x [m_dragged], y [m_dragged] ); |
183 | repaint ( r, false ); | 182 | repaint ( r, false ); |
184 | } | 183 | } |
185 | } | 184 | } |
186 | 185 | ||
187 | void Calibration::mouseMoveEvent ( QMouseEvent *e ) | 186 | void Calibration::mouseMoveEvent ( QMouseEvent *e ) |
188 | { | 187 | { |
189 | if ( m_dragged < 0 ) | 188 | if ( m_dragged < 0 ) |
190 | return; | 189 | return; |
191 | 190 | ||
192 | QPoint n [2]; | 191 | QPoint n [2]; |
193 | 192 | ||
194 | n [m_dragged]. setX (( e-> x ( ) - BRD ) * m_scale. width ( ) / ( width ( ) - 2 * BRD )); | 193 | n [m_dragged]. setX (( e-> x ( ) - BRD ) * m_scale. width ( ) / ( width ( ) - 2 * BRD )); |
195 | n [m_dragged]. setY (( e-> y ( ) - BRD ) * m_scale. height ( ) / ( height ( ) - 2 * BRD )); | 194 | n [m_dragged]. setY (( e-> y ( ) - BRD ) * m_scale. height ( ) / ( height ( ) - 2 * BRD )); |
196 | n [1 - m_dragged] = m_p [1 - m_dragged]; | 195 | n [1 - m_dragged] = m_p [1 - m_dragged]; |
197 | 196 | ||
198 | if ( n [m_dragged]. x ( ) < 0 ) | 197 | if ( n [m_dragged]. x ( ) < 0 ) |
199 | n [m_dragged]. setX ( 0 ); | 198 | n [m_dragged]. setX ( 0 ); |
200 | if ( n [m_dragged]. x ( ) >= m_scale. width ( )) | 199 | if ( n [m_dragged]. x ( ) >= m_scale. width ( )) |
201 | n [m_dragged]. setX ( m_scale. width ( ) - 1 ); | 200 | n [m_dragged]. setX ( m_scale. width ( ) - 1 ); |
202 | if ( n [0]. x ( ) > n [1]. x ( )) | 201 | if ( n [0]. x ( ) > n [1]. x ( )) |
203 | n [m_dragged]. setX ( n [1 - m_dragged]. x ( )); | 202 | n [m_dragged]. setX ( n [1 - m_dragged]. x ( )); |
204 | if ( n [m_dragged]. y ( ) < 0 ) | 203 | if ( n [m_dragged]. y ( ) < 0 ) |
205 | n [m_dragged]. setY ( 0 ); | 204 | n [m_dragged]. setY ( 0 ); |
206 | if ( n [m_dragged]. y ( ) >= m_scale. height ( )) | 205 | if ( n [m_dragged]. y ( ) >= m_scale. height ( )) |
207 | n [m_dragged]. setY ( m_scale. height ( ) - 1 ); | 206 | n [m_dragged]. setY ( m_scale. height ( ) - 1 ); |
208 | //if ( n [0]. y ( ) > n [1]. y ( )) | 207 | //if ( n [0]. y ( ) > n [1]. y ( )) |
209 | // n [m_dragged]. setY ( n [1 - m_dragged]. y ( )); | 208 | // n [m_dragged]. setY ( n [1 - m_dragged]. y ( )); |
210 | 209 | ||
211 | QRect r; | 210 | QRect r; |
212 | int ox [2], oy [2], nx [2], ny [2]; | 211 | int ox [2], oy [2], nx [2], ny [2]; |
213 | 212 | ||
214 | for ( int i = 0; i < 2; i++ ) { | 213 | for ( int i = 0; i < 2; i++ ) { |
215 | nx [i] = SCALEX( n [i]. x ( )); | 214 | nx [i] = SCALEX( n [i]. x ( )); |
216 | ny [i] = SCALEY( n [i]. y ( )); | 215 | ny [i] = SCALEY( n [i]. y ( )); |
217 | ox [i] = SCALEX( m_p [i]. x ( )); | 216 | ox [i] = SCALEX( m_p [i]. x ( )); |
218 | oy [i] = SCALEY( m_p [i]. y ( )); | 217 | oy [i] = SCALEY( m_p [i]. y ( )); |
219 | 218 | ||
220 | if ( n [i] != m_p [i] ){ | 219 | if ( n [i] != m_p [i] ){ |
221 | r |= around ( nx [i], ny [i] ); | 220 | r |= around ( nx [i], ny [i] ); |
222 | r |= around ( ox [i], oy [i] ); | 221 | r |= around ( ox [i], oy [i] ); |
223 | m_p [i] = n [i]; | 222 | m_p [i] = n [i]; |
224 | 223 | ||
225 | if ( i == 0 ) { | 224 | if ( i == 0 ) { |
226 | r |= QRect ( 0, ny [0], nx [0] - 0 + 1, 1 ); | 225 | r |= QRect ( 0, ny [0], nx [0] - 0 + 1, 1 ); |
227 | r |= QRect ( 0, oy [0], ox [0] - 0 + 1, 1 ); | 226 | r |= QRect ( 0, oy [0], ox [0] - 0 + 1, 1 ); |
228 | 227 | ||
229 | emit startPointChanged ( startPoint ( )); | 228 | emit startPointChanged ( startPoint ( )); |
230 | } | 229 | } |
231 | else if ( i == 1 ) { | 230 | else if ( i == 1 ) { |
232 | r |= QRect ( nx [1], ny [1], width ( ) - nx [1], 1 ); | 231 | r |= QRect ( nx [1], ny [1], width ( ) - nx [1], 1 ); |
233 | r |= QRect ( ox [1], oy [1], width ( ) - ox [1], 1 ); | 232 | r |= QRect ( ox [1], oy [1], width ( ) - ox [1], 1 ); |
234 | 233 | ||
235 | emit endPointChanged ( endPoint ( )); | 234 | emit endPointChanged ( endPoint ( )); |
236 | } | 235 | } |
237 | } | 236 | } |
238 | } | 237 | } |
239 | if ( r. isValid ( )) { | 238 | if ( r. isValid ( )) { |
240 | r |= QRect ( nx [0], ny [0], nx [1] - nx [0] + 1, ny [1] - ny [0] + 1 ). normalize ( ); | 239 | r |= QRect ( nx [0], ny [0], nx [1] - nx [0] + 1, ny [1] - ny [0] + 1 ). normalize ( ); |
241 | r |= QRect ( ox [0], oy [0], ox [1] - ox [0] + 1, oy [1] - oy [0] + 1 ). normalize ( ); | 240 | r |= QRect ( ox [0], oy [0], ox [1] - ox [0] + 1, oy [1] - oy [0] + 1 ). normalize ( ); |
242 | 241 | ||
243 | repaint ( r, false ); | 242 | repaint ( r, false ); |
244 | } | 243 | } |
245 | } | 244 | } |
246 | 245 | ||
247 | void Calibration::mouseReleaseEvent ( QMouseEvent *e ) | 246 | void Calibration::mouseReleaseEvent ( QMouseEvent *e ) |
248 | { | 247 | { |
249 | if ( e-> button ( ) != LeftButton ) | 248 | if ( e-> button ( ) != LeftButton ) |
250 | return QWidget::mouseReleaseEvent ( e ); | 249 | return QWidget::mouseReleaseEvent ( e ); |
251 | 250 | ||
252 | if ( m_dragged < 0 ) | 251 | if ( m_dragged < 0 ) |
253 | return; | 252 | return; |
254 | 253 | ||
255 | int x = SCALEX( m_p [m_dragged]. x ( )); | 254 | int x = SCALEX( m_p [m_dragged]. x ( )); |
256 | int y = SCALEY( m_p [m_dragged]. y ( )); | 255 | int y = SCALEY( m_p [m_dragged]. y ( )); |
257 | m_dragged = -1; | 256 | m_dragged = -1; |
258 | 257 | ||
259 | repaint ( around ( x, y ), false ); | 258 | repaint ( around ( x, y ), false ); |
260 | } | 259 | } |
261 | 260 | ||
262 | void Calibration::paintEvent ( QPaintEvent *pe ) | 261 | void Calibration::paintEvent ( QPaintEvent *pe ) |
263 | { | 262 | { |
264 | QPixmap pix ( size ( )); | 263 | QPixmap pix ( size ( )); |
265 | QPainter p ( &pix, this ); | 264 | QPainter p ( &pix, this ); |
266 | QRect cr = pe-> rect ( ); | 265 | QRect cr = pe-> rect ( ); |
267 | 266 | ||
268 | int x0 = SCALEX( m_p [0]. x ( )); | 267 | int x0 = SCALEX( m_p [0]. x ( )); |
269 | int y0 = SCALEY( m_p [0]. y ( )); | 268 | int y0 = SCALEY( m_p [0]. y ( )); |
270 | int x1 = SCALEX( m_p [1]. x ( )); | 269 | int x1 = SCALEX( m_p [1]. x ( )); |
271 | int y1 = SCALEY( m_p [1]. y ( )); | 270 | int y1 = SCALEY( m_p [1]. y ( )); |
272 | 271 | ||
273 | int dx = x1 - x0; | 272 | int dx = x1 - x0; |
274 | int dy = y1 - y0; | 273 | int dy = y1 - y0; |
275 | 274 | ||
276 | // restrict steps to real x and y resolution | 275 | // restrict steps to real x and y resolution |
277 | int st = QMIN( QMIN( m_steps, ( dx + 1 )), ( QABS( dy ) + 1 )); | 276 | int st = QMIN( QMIN( m_steps, ( dx + 1 )), ( QABS( dy ) + 1 )); |
278 | 277 | ||
279 | QString stepstr = tr( "%1 Steps" ). arg ( st ); | 278 | QString stepstr = tr( "%1 Steps" ). arg ( st ); |
280 | QRect tr = p. boundingRect ( BRD, BRD, width ( ) - 2*BRD, height() - 2*BRD, AlignTop | AlignRight, stepstr ); | 279 | QRect tr = p. boundingRect ( BRD, BRD, width ( ) - 2*BRD, height() - 2*BRD, AlignTop | AlignRight, stepstr ); |
281 | tr. setLeft ( tr. left ( ) - 20 ); | 280 | tr. setLeft ( tr. left ( ) - 20 ); |
282 | if ( p. hasClipping ( )) | 281 | if ( p. hasClipping ( )) |
283 | p. setClipRegion ( p. clipRegion ( ) | QRegion ( tr )); | 282 | p. setClipRegion ( p. clipRegion ( ) | QRegion ( tr )); |
284 | 283 | ||
285 | QColorGroup g = colorGroup ( ); | 284 | QColorGroup g = colorGroup ( ); |
286 | 285 | ||
287 | p. fillRect ( cr, g. base ( )); | 286 | p. fillRect ( cr, g. base ( )); |
288 | p. fillRect ( tr, g. base ( )); | 287 | p. fillRect ( tr, g. base ( )); |
289 | 288 | ||
290 | int ex = x0, ey = y0; | 289 | int ex = x0, ey = y0; |
291 | 290 | ||
292 | p. setPen ( g. mid ( )); | 291 | p. setPen ( g. mid ( )); |
293 | 292 | ||
294 | int gx0 = SCALEX( 0 ); | 293 | int gx0 = SCALEX( 0 ); |
295 | int gy0 = SCALEY( 0 ); | 294 | int gy0 = SCALEY( 0 ); |
296 | int gx1 = SCALEX( m_scale. width ( ) - 1 ); | 295 | int gx1 = SCALEX( m_scale. width ( ) - 1 ); |
297 | int gy1 = SCALEY( m_scale. height ( ) - 1 ); | 296 | int gy1 = SCALEY( m_scale. height ( ) - 1 ); |
298 | 297 | ||
299 | int xdiv = QMIN( 4, m_scale. width ( )); | 298 | int xdiv = QMIN( 4, m_scale. width ( )); |
300 | int ydiv = QMIN( 4, m_scale. height ( )); | 299 | int ydiv = QMIN( 4, m_scale. height ( )); |
301 | 300 | ||
302 | xdiv = ( gx1 - gx0 + 1 ) / xdiv; | 301 | xdiv = ( gx1 - gx0 + 1 ) / xdiv; |
303 | ydiv = ( gy1 - gy0 + 1 ) / ydiv; | 302 | ydiv = ( gy1 - gy0 + 1 ) / ydiv; |
304 | 303 | ||
305 | for ( int i = gx0 + xdiv; i <= ( gx1 - xdiv ); i += xdiv ) | 304 | for ( int i = gx0 + xdiv; i <= ( gx1 - xdiv ); i += xdiv ) |
306 | p. drawLine ( i, gy0, i, gy1 ); | 305 | p. drawLine ( i, gy0, i, gy1 ); |
307 | 306 | ||
308 | for ( int i = gy0 + ydiv; i <= ( gy1 - ydiv ); i += ydiv ) | 307 | for ( int i = gy0 + ydiv; i <= ( gy1 - ydiv ); i += ydiv ) |
309 | p. drawLine ( gx0, i, gx1, i ); | 308 | p. drawLine ( gx0, i, gx1, i ); |
310 | 309 | ||
311 | p. setPen ( g. highlight ( )); | 310 | p. setPen ( g. highlight ( )); |
312 | 311 | ||
313 | p. drawLine ( BRD, ey, ex, ey ); | 312 | p. drawLine ( BRD, ey, ex, ey ); |
314 | 313 | ||
315 | for ( int i = 1; i < st; i++ ) { | 314 | for ( int i = 1; i < st; i++ ) { |
316 | int fx = x0 + dx * i / st; | 315 | int fx = x0 + dx * i / st; |
317 | int fy = y0 + dy * i / ( st - 1 ); | 316 | int fy = y0 + dy * i / ( st - 1 ); |
318 | 317 | ||
319 | p. drawLine ( ex, ey, fx, ey ); | 318 | p. drawLine ( ex, ey, fx, ey ); |
320 | p. drawLine ( fx, ey, fx, fy ); | 319 | p. drawLine ( fx, ey, fx, fy ); |
321 | 320 | ||
322 | ex = fx; | 321 | ex = fx; |
323 | ey = fy; | 322 | ey = fy; |
324 | } | 323 | } |
325 | if ( st == 1 ) { | 324 | if ( st == 1 ) { |
326 | p. drawLine ( ex, ey, ex, y1 ); | 325 | p. drawLine ( ex, ey, ex, y1 ); |
327 | ey = y1; | 326 | ey = y1; |
328 | } | 327 | } |
329 | 328 | ||
330 | p. drawLine ( ex, ey, width ( ) - 1 - BRD, ey ); | 329 | p. drawLine ( ex, ey, width ( ) - 1 - BRD, ey ); |
331 | 330 | ||
332 | 331 | ||
333 | p. fillRect ( around ( x0, y0 ), m_dragged == 0 ? g. highlightedText ( ) : g. text ( )); | 332 | p. fillRect ( around ( x0, y0 ), m_dragged == 0 ? g. highlightedText ( ) : g. text ( )); |
334 | p. drawRect ( around ( x0, y0 )); | 333 | p. drawRect ( around ( x0, y0 )); |
335 | p. fillRect ( around ( x1, y1 ), m_dragged == 1 ? g. highlightedText ( ) : g. text ( )); | 334 | p. fillRect ( around ( x1, y1 ), m_dragged == 1 ? g. highlightedText ( ) : g. text ( )); |
336 | p. drawRect ( around ( x1, y1 )); | 335 | p. drawRect ( around ( x1, y1 )); |
337 | 336 | ||
338 | p. setPen ( g. text ( )); | 337 | p. setPen ( g. text ( )); |
339 | p. drawText ( tr, AlignTop | AlignRight, stepstr ); | 338 | p. drawText ( tr, AlignTop | AlignRight, stepstr ); |
340 | 339 | ||
341 | p. end ( ); | 340 | p. end ( ); |
342 | bitBlt ( this, cr. topLeft ( ), &pix, cr ); | 341 | bitBlt ( this, cr. topLeft ( ), &pix, cr ); |
343 | if ( !cr. contains ( tr )) | 342 | if ( !cr. contains ( tr )) |
344 | bitBlt ( this, tr. topLeft ( ), &pix, tr ); | 343 | bitBlt ( this, tr. topLeft ( ), &pix, tr ); |
345 | } | 344 | } |
346 | 345 | ||
diff --git a/core/settings/light-and-power/light.cpp b/core/settings/light-and-power/light.cpp index eda0c1f..6115178 100644 --- a/core/settings/light-and-power/light.cpp +++ b/core/settings/light-and-power/light.cpp | |||
@@ -1,283 +1,281 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. Copyright (c) 2002 Maximilian Reiss <harlekin@handhelds.org> | 3 | =. Copyright (c) 2002 Maximilian Reiss <harlekin@handhelds.org> |
4 | .=l. Copyright (c) 2002 Robert Griebl <sandman@handhelds.org> | 4 | .=l. Copyright (c) 2002 Robert Griebl <sandman@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include "light.h" | 29 | #include "light.h" |
30 | 30 | ||
31 | #include <qpe/config.h> | 31 | #include <qpe/config.h> |
32 | #include <qpe/qpeapplication.h> | ||
33 | #include <qpe/power.h> | 32 | #include <qpe/power.h> |
34 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 33 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
35 | #include <qpe/qcopenvelope_qws.h> | 34 | #include <qpe/qcopenvelope_qws.h> |
36 | #endif | 35 | #endif |
37 | 36 | ||
38 | #include <qcheckbox.h> | 37 | #include <qcheckbox.h> |
39 | #include <qtabwidget.h> | 38 | #include <qtabwidget.h> |
40 | #include <qslider.h> | 39 | #include <qslider.h> |
41 | #include <qtimer.h> | ||
42 | #include <qspinbox.h> | 40 | #include <qspinbox.h> |
43 | #include <qpushbutton.h> | 41 | #include <qpushbutton.h> |
44 | #include <qgroupbox.h> | 42 | #include <qgroupbox.h> |
45 | #include <qcombobox.h> | 43 | #include <qcombobox.h> |
46 | 44 | ||
47 | #include <opie/odevice.h> | 45 | #include <opie/odevice.h> |
48 | 46 | ||
49 | #include "sensor.h" | 47 | #include "sensor.h" |
50 | 48 | ||
51 | using namespace Opie; | 49 | using namespace Opie; |
52 | 50 | ||
53 | LightSettings::LightSettings( QWidget* parent, const char* name, WFlags ) | 51 | LightSettings::LightSettings( QWidget* parent, const char* name, WFlags ) |
54 | : LightSettingsBase( parent, name, false, WStyle_ContextHelp ) | 52 | : LightSettingsBase( parent, name, false, WStyle_ContextHelp ) |
55 | { | 53 | { |
56 | m_bres = ODevice::inst ( )-> displayBrightnessResolution ( ); | 54 | m_bres = ODevice::inst ( )-> displayBrightnessResolution ( ); |
57 | m_cres = ODevice::inst ( )-> displayContrastResolution ( ); | 55 | m_cres = ODevice::inst ( )-> displayContrastResolution ( ); |
58 | 56 | ||
59 | if ( !ODevice::inst ( )-> hasLightSensor ( )) { | 57 | if ( !ODevice::inst ( )-> hasLightSensor ( )) { |
60 | auto_brightness-> hide ( ); | 58 | auto_brightness-> hide ( ); |
61 | CalibrateLightSensor-> hide ( ); | 59 | CalibrateLightSensor-> hide ( ); |
62 | auto_brightness_ac-> hide ( ); | 60 | auto_brightness_ac-> hide ( ); |
63 | CalibrateLightSensor_ac-> hide ( ); | 61 | CalibrateLightSensor_ac-> hide ( ); |
64 | } | 62 | } |
65 | if (m_cres) { | 63 | if (m_cres) { |
66 | GroupLight->setTitle(tr("Backlight && Contrast")); | 64 | GroupLight->setTitle(tr("Backlight && Contrast")); |
67 | GroupLight_ac->setTitle(GroupLight->title()); | 65 | GroupLight_ac->setTitle(GroupLight->title()); |
68 | } else { | 66 | } else { |
69 | contrast->hide(); | 67 | contrast->hide(); |
70 | contrast_ac->hide(); | 68 | contrast_ac->hide(); |
71 | } | 69 | } |
72 | 70 | ||
73 | QStrList freq = ODevice::inst()->allowedCpuFrequencies(); | 71 | QStrList freq = ODevice::inst()->allowedCpuFrequencies(); |
74 | if ( freq.count() ) { | 72 | if ( freq.count() ) { |
75 | frequency->insertStrList( freq ); | 73 | frequency->insertStrList( freq ); |
76 | frequency_ac->insertStrList( freq ); | 74 | frequency_ac->insertStrList( freq ); |
77 | } else { | 75 | } else { |
78 | frequency->hide(); | 76 | frequency->hide(); |
79 | frequency_ac->hide(); | 77 | frequency_ac->hide(); |
80 | } | 78 | } |
81 | 79 | ||
82 | Config config ( "apm" ); | 80 | Config config ( "apm" ); |
83 | config. setGroup ( "Battery" ); | 81 | config. setGroup ( "Battery" ); |
84 | 82 | ||
85 | // battery spinboxes | 83 | // battery spinboxes |
86 | interval_dim-> setValue ( config. readNumEntry ( "Dim", 30 )); | 84 | interval_dim-> setValue ( config. readNumEntry ( "Dim", 30 )); |
87 | interval_lightoff-> setValue ( config. readNumEntry ( "LightOff", 20 )); | 85 | interval_lightoff-> setValue ( config. readNumEntry ( "LightOff", 20 )); |
88 | interval_suspend-> setValue ( config. readNumEntry ( "Suspend", 60 )); | 86 | interval_suspend-> setValue ( config. readNumEntry ( "Suspend", 60 )); |
89 | 87 | ||
90 | // battery check and slider | 88 | // battery check and slider |
91 | LcdOffOnly->setChecked ( config. readBoolEntry ( "LcdOffOnly", false )); | 89 | LcdOffOnly->setChecked ( config. readBoolEntry ( "LcdOffOnly", false )); |
92 | 90 | ||
93 | // CPU frequency | 91 | // CPU frequency |
94 | frequency->setCurrentItem( config.readNumEntry("Freq", 0) ); | 92 | frequency->setCurrentItem( config.readNumEntry("Freq", 0) ); |
95 | 93 | ||
96 | int bright = config. readNumEntry ( "Brightness", 127 ); | 94 | int bright = config. readNumEntry ( "Brightness", 127 ); |
97 | int contr = m_oldcontrast = config. readNumEntry ( "Contrast", 127 ); | 95 | int contr = m_oldcontrast = config. readNumEntry ( "Contrast", 127 ); |
98 | brightness-> setTickInterval ( QMAX( 16, 256 / m_bres )); | 96 | brightness-> setTickInterval ( QMAX( 16, 256 / m_bres )); |
99 | brightness-> setLineStep ( QMAX( 1, 256 / m_bres )); | 97 | brightness-> setLineStep ( QMAX( 1, 256 / m_bres )); |
100 | brightness-> setPageStep ( QMAX( 1, 256 / m_bres )); | 98 | brightness-> setPageStep ( QMAX( 1, 256 / m_bres )); |
101 | brightness-> setValue ( bright ); | 99 | brightness-> setValue ( bright ); |
102 | 100 | ||
103 | if (m_cres) { | 101 | if (m_cres) { |
104 | contrast-> setTickInterval ( QMAX( 16, 256 / m_cres )); | 102 | contrast-> setTickInterval ( QMAX( 16, 256 / m_cres )); |
105 | contrast-> setLineStep ( QMAX( 1, 256 / m_cres )); | 103 | contrast-> setLineStep ( QMAX( 1, 256 / m_cres )); |
106 | contrast-> setPageStep ( QMAX( 1, 256 / m_cres )); | 104 | contrast-> setPageStep ( QMAX( 1, 256 / m_cres )); |
107 | contrast-> setValue ( contr ); | 105 | contrast-> setValue ( contr ); |
108 | } | 106 | } |
109 | 107 | ||
110 | // light sensor | 108 | // light sensor |
111 | auto_brightness-> setChecked ( config. readBoolEntry ( "LightSensor", false )); | 109 | auto_brightness-> setChecked ( config. readBoolEntry ( "LightSensor", false )); |
112 | m_sensordata = config. readListEntry ( "LightSensorData", ';' ); | 110 | m_sensordata = config. readListEntry ( "LightSensorData", ';' ); |
113 | 111 | ||
114 | config. setGroup ( "AC" ); | 112 | config. setGroup ( "AC" ); |
115 | 113 | ||
116 | // ac spinboxes | 114 | // ac spinboxes |
117 | interval_dim_ac-> setValue ( config. readNumEntry ( "Dim", 60 )); | 115 | interval_dim_ac-> setValue ( config. readNumEntry ( "Dim", 60 )); |
118 | interval_lightoff_ac-> setValue ( config. readNumEntry ( "LightOff", 120 )); | 116 | interval_lightoff_ac-> setValue ( config. readNumEntry ( "LightOff", 120 )); |
119 | interval_suspend_ac-> setValue ( config. readNumEntry ( "Suspend", 0 )); | 117 | interval_suspend_ac-> setValue ( config. readNumEntry ( "Suspend", 0 )); |
120 | 118 | ||
121 | // ac check and slider | 119 | // ac check and slider |
122 | LcdOffOnly_ac-> setChecked ( config. readBoolEntry ( "LcdOffOnly", false )); | 120 | LcdOffOnly_ac-> setChecked ( config. readBoolEntry ( "LcdOffOnly", false )); |
123 | 121 | ||
124 | // CPU frequency | 122 | // CPU frequency |
125 | frequency_ac->setCurrentItem( config.readNumEntry("Freq", 0) ); | 123 | frequency_ac->setCurrentItem( config.readNumEntry("Freq", 0) ); |
126 | 124 | ||
127 | bright = config. readNumEntry ( "Brightness", 255 ); | 125 | bright = config. readNumEntry ( "Brightness", 255 ); |
128 | brightness_ac-> setTickInterval ( QMAX( 16, 256 / m_bres )); | 126 | brightness_ac-> setTickInterval ( QMAX( 16, 256 / m_bres )); |
129 | brightness_ac-> setLineStep ( QMAX( 1, 256 / m_bres )); | 127 | brightness_ac-> setLineStep ( QMAX( 1, 256 / m_bres )); |
130 | brightness_ac-> setPageStep ( QMAX( 1, 256 / m_bres )); | 128 | brightness_ac-> setPageStep ( QMAX( 1, 256 / m_bres )); |
131 | brightness_ac-> setValue ( bright ); | 129 | brightness_ac-> setValue ( bright ); |
132 | 130 | ||
133 | if (m_cres) { | 131 | if (m_cres) { |
134 | contr = config. readNumEntry ( "Contrast", 127); | 132 | contr = config. readNumEntry ( "Contrast", 127); |
135 | contrast_ac-> setTickInterval ( QMAX( 16, 256 / m_cres )); | 133 | contrast_ac-> setTickInterval ( QMAX( 16, 256 / m_cres )); |
136 | contrast_ac-> setLineStep ( QMAX( 1, 256 / m_cres )); | 134 | contrast_ac-> setLineStep ( QMAX( 1, 256 / m_cres )); |
137 | contrast_ac-> setPageStep ( QMAX( 1, 256 / m_cres )); | 135 | contrast_ac-> setPageStep ( QMAX( 1, 256 / m_cres )); |
138 | contrast_ac-> setValue ( contr ); | 136 | contrast_ac-> setValue ( contr ); |
139 | } | 137 | } |
140 | 138 | ||
141 | // light sensor | 139 | // light sensor |
142 | auto_brightness_ac-> setChecked ( config. readBoolEntry ( "LightSensor", false )); | 140 | auto_brightness_ac-> setChecked ( config. readBoolEntry ( "LightSensor", false )); |
143 | m_sensordata_ac = config. readListEntry ( "LightSensorData", ';' ); | 141 | m_sensordata_ac = config. readListEntry ( "LightSensorData", ';' ); |
144 | 142 | ||
145 | // advanced settings | 143 | // advanced settings |
146 | config. setGroup ( "Warnings" ); | 144 | config. setGroup ( "Warnings" ); |
147 | warnintervalBox-> setValue ( config. readNumEntry ( "checkinterval", 10000 ) / 1000 ); | 145 | warnintervalBox-> setValue ( config. readNumEntry ( "checkinterval", 10000 ) / 1000 ); |
148 | lowSpinBox-> setValue ( config. readNumEntry ( "powerverylow", 10 ) ); | 146 | lowSpinBox-> setValue ( config. readNumEntry ( "powerverylow", 10 ) ); |
149 | criticalSpinBox-> setValue ( config. readNumEntry ( "powercritical", 5 ) ); | 147 | criticalSpinBox-> setValue ( config. readNumEntry ( "powercritical", 5 ) ); |
150 | 148 | ||
151 | m_resettimer = new QTimer ( this ); | 149 | m_resettimer = new QTimer ( this ); |
152 | connect ( m_resettimer, SIGNAL( timeout ( )), this, SLOT( resetBacklight ( ))); | 150 | connect ( m_resettimer, SIGNAL( timeout ( )), this, SLOT( resetBacklight ( ))); |
153 | 151 | ||
154 | if ( PowerStatusManager::readStatus ( ). acStatus ( ) != PowerStatus::Online ) { | 152 | if ( PowerStatusManager::readStatus ( ). acStatus ( ) != PowerStatus::Online ) { |
155 | tabs-> setCurrentPage ( 0 ); | 153 | tabs-> setCurrentPage ( 0 ); |
156 | } | 154 | } |
157 | else { | 155 | else { |
158 | tabs-> setCurrentPage ( 1 ); | 156 | tabs-> setCurrentPage ( 1 ); |
159 | } | 157 | } |
160 | 158 | ||
161 | connect ( brightness, SIGNAL( valueChanged ( int )), this, SLOT( setBacklight ( int ))); | 159 | connect ( brightness, SIGNAL( valueChanged ( int )), this, SLOT( setBacklight ( int ))); |
162 | connect ( brightness_ac, SIGNAL( valueChanged ( int )), this, SLOT( setBacklight ( int ))); | 160 | connect ( brightness_ac, SIGNAL( valueChanged ( int )), this, SLOT( setBacklight ( int ))); |
163 | if (m_cres) { | 161 | if (m_cres) { |
164 | connect ( contrast, SIGNAL( valueChanged ( int )), this, SLOT( setContrast ( int ))); | 162 | connect ( contrast, SIGNAL( valueChanged ( int )), this, SLOT( setContrast ( int ))); |
165 | connect ( contrast_ac, SIGNAL( valueChanged ( int )), this, SLOT( setContrast ( int ))); | 163 | connect ( contrast_ac, SIGNAL( valueChanged ( int )), this, SLOT( setContrast ( int ))); |
166 | } | 164 | } |
167 | connect( frequency, SIGNAL( activated(int) ), this, SLOT( setFrequency(int) ) ); | 165 | connect( frequency, SIGNAL( activated(int) ), this, SLOT( setFrequency(int) ) ); |
168 | } | 166 | } |
169 | 167 | ||
170 | LightSettings::~LightSettings ( ) | 168 | LightSettings::~LightSettings ( ) |
171 | { | 169 | { |
172 | } | 170 | } |
173 | 171 | ||
174 | void LightSettings::calibrateSensor ( ) | 172 | void LightSettings::calibrateSensor ( ) |
175 | { | 173 | { |
176 | Sensor *s = new Sensor ( m_sensordata, this ); | 174 | Sensor *s = new Sensor ( m_sensordata, this ); |
177 | connect ( s, SIGNAL( viewBacklight ( int )), this, SLOT( setBacklight ( int ))); | 175 | connect ( s, SIGNAL( viewBacklight ( int )), this, SLOT( setBacklight ( int ))); |
178 | s-> showMaximized ( ); | 176 | s-> showMaximized ( ); |
179 | s-> exec ( ); | 177 | s-> exec ( ); |
180 | delete s; | 178 | delete s; |
181 | } | 179 | } |
182 | 180 | ||
183 | void LightSettings::calibrateSensorAC ( ) | 181 | void LightSettings::calibrateSensorAC ( ) |
184 | { | 182 | { |
185 | Sensor *s = new Sensor ( m_sensordata_ac, this ); | 183 | Sensor *s = new Sensor ( m_sensordata_ac, this ); |
186 | connect ( s, SIGNAL( viewBacklight ( int )), this, SLOT( setBacklight ( int ))); | 184 | connect ( s, SIGNAL( viewBacklight ( int )), this, SLOT( setBacklight ( int ))); |
187 | s-> showMaximized ( ); | 185 | s-> showMaximized ( ); |
188 | s-> exec ( ); | 186 | s-> exec ( ); |
189 | delete s; | 187 | delete s; |
190 | } | 188 | } |
191 | 189 | ||
192 | void LightSettings::setBacklight ( int bright ) | 190 | void LightSettings::setBacklight ( int bright ) |
193 | { | 191 | { |
194 | QCopEnvelope e ( "QPE/System", "setBacklight(int)" ); | 192 | QCopEnvelope e ( "QPE/System", "setBacklight(int)" ); |
195 | e << bright; | 193 | e << bright; |
196 | 194 | ||
197 | if ( bright != -1 ) { | 195 | if ( bright != -1 ) { |
198 | m_resettimer-> stop ( ); | 196 | m_resettimer-> stop ( ); |
199 | m_resettimer-> start ( 4000, true ); | 197 | m_resettimer-> start ( 4000, true ); |
200 | } | 198 | } |
201 | } | 199 | } |
202 | 200 | ||
203 | void LightSettings::setContrast ( int contr ) | 201 | void LightSettings::setContrast ( int contr ) |
204 | { | 202 | { |
205 | if (contr == -1) contr = m_oldcontrast; | 203 | if (contr == -1) contr = m_oldcontrast; |
206 | 204 | ||
207 | ODevice::inst ( )-> setDisplayContrast(contr); | 205 | ODevice::inst ( )-> setDisplayContrast(contr); |
208 | } | 206 | } |
209 | 207 | ||
210 | void LightSettings::setFrequency ( int index ) | 208 | void LightSettings::setFrequency ( int index ) |
211 | { | 209 | { |
212 | qWarning("LightSettings::setFrequency(%d)", index); | 210 | qWarning("LightSettings::setFrequency(%d)", index); |
213 | ODevice::inst ( )-> setCurrentCpuFrequency(index); | 211 | ODevice::inst ( )-> setCurrentCpuFrequency(index); |
214 | } | 212 | } |
215 | 213 | ||
216 | void LightSettings::resetBacklight ( ) | 214 | void LightSettings::resetBacklight ( ) |
217 | { | 215 | { |
218 | setBacklight ( -1 ); | 216 | setBacklight ( -1 ); |
219 | setContrast ( -1 ); | 217 | setContrast ( -1 ); |
220 | } | 218 | } |
221 | 219 | ||
222 | void LightSettings::accept ( ) | 220 | void LightSettings::accept ( ) |
223 | { | 221 | { |
224 | Config config ( "apm" ); | 222 | Config config ( "apm" ); |
225 | 223 | ||
226 | // bat | 224 | // bat |
227 | config. setGroup ( "Battery" ); | 225 | config. setGroup ( "Battery" ); |
228 | config. writeEntry ( "LcdOffOnly", LcdOffOnly-> isChecked ( )); | 226 | config. writeEntry ( "LcdOffOnly", LcdOffOnly-> isChecked ( )); |
229 | config. writeEntry ( "Dim", interval_dim-> value ( )); | 227 | config. writeEntry ( "Dim", interval_dim-> value ( )); |
230 | config. writeEntry ( "LightOff", interval_lightoff-> value ( )); | 228 | config. writeEntry ( "LightOff", interval_lightoff-> value ( )); |
231 | config. writeEntry ( "Suspend", interval_suspend-> value ( )); | 229 | config. writeEntry ( "Suspend", interval_suspend-> value ( )); |
232 | config. writeEntry ( "Brightness", brightness-> value () ); | 230 | config. writeEntry ( "Brightness", brightness-> value () ); |
233 | if (m_cres) | 231 | if (m_cres) |
234 | config. writeEntry ( "Contrast", contrast-> value () ); | 232 | config. writeEntry ( "Contrast", contrast-> value () ); |
235 | config. writeEntry ( "Freq", frequency->currentItem() ); | 233 | config. writeEntry ( "Freq", frequency->currentItem() ); |
236 | 234 | ||
237 | // ac | 235 | // ac |
238 | config. setGroup ( "AC" ); | 236 | config. setGroup ( "AC" ); |
239 | config. writeEntry ( "LcdOffOnly", LcdOffOnly_ac-> isChecked ( )); | 237 | config. writeEntry ( "LcdOffOnly", LcdOffOnly_ac-> isChecked ( )); |
240 | config. writeEntry ( "Dim", interval_dim_ac-> value ( )); | 238 | config. writeEntry ( "Dim", interval_dim_ac-> value ( )); |
241 | config. writeEntry ( "LightOff", interval_lightoff_ac-> value ( )); | 239 | config. writeEntry ( "LightOff", interval_lightoff_ac-> value ( )); |
242 | config. writeEntry ( "Suspend", interval_suspend_ac-> value ( )); | 240 | config. writeEntry ( "Suspend", interval_suspend_ac-> value ( )); |
243 | config. writeEntry ( "Brightness", brightness_ac-> value () ); | 241 | config. writeEntry ( "Brightness", brightness_ac-> value () ); |
244 | if (m_cres) | 242 | if (m_cres) |
245 | config. writeEntry ( "Contrast", contrast_ac-> value () ); | 243 | config. writeEntry ( "Contrast", contrast_ac-> value () ); |
246 | config. writeEntry ( "Freq", frequency_ac->currentItem() ); | 244 | config. writeEntry ( "Freq", frequency_ac->currentItem() ); |
247 | 245 | ||
248 | // only make light sensor stuff appear if the unit has a sensor | 246 | // only make light sensor stuff appear if the unit has a sensor |
249 | if ( ODevice::inst ( )-> hasLightSensor ( )) { | 247 | if ( ODevice::inst ( )-> hasLightSensor ( )) { |
250 | config. setGroup ( "Battery" ); | 248 | config. setGroup ( "Battery" ); |
251 | config. writeEntry ( "LightSensor", auto_brightness->isChecked() ); | 249 | config. writeEntry ( "LightSensor", auto_brightness->isChecked() ); |
252 | config. writeEntry ( "LightSensorData", m_sensordata, ';' ); | 250 | config. writeEntry ( "LightSensorData", m_sensordata, ';' ); |
253 | config. setGroup ( "AC" ); | 251 | config. setGroup ( "AC" ); |
254 | config. writeEntry ( "LightSensor", auto_brightness_ac->isChecked() ); | 252 | config. writeEntry ( "LightSensor", auto_brightness_ac->isChecked() ); |
255 | config. writeEntry ( "LightSensorData", m_sensordata_ac, ';' ); | 253 | config. writeEntry ( "LightSensorData", m_sensordata_ac, ';' ); |
256 | } | 254 | } |
257 | 255 | ||
258 | // advanced | 256 | // advanced |
259 | config. setGroup ( "Warnings" ); | 257 | config. setGroup ( "Warnings" ); |
260 | config. writeEntry ( "check_interval", warnintervalBox-> value ( ) * 1000 ); | 258 | config. writeEntry ( "check_interval", warnintervalBox-> value ( ) * 1000 ); |
261 | config. writeEntry ( "power_verylow", lowSpinBox-> value ( )); | 259 | config. writeEntry ( "power_verylow", lowSpinBox-> value ( )); |
262 | config. writeEntry ( "power_critical", criticalSpinBox-> value ( )); | 260 | config. writeEntry ( "power_critical", criticalSpinBox-> value ( )); |
263 | config. write ( ); | 261 | config. write ( ); |
264 | 262 | ||
265 | // notify the launcher | 263 | // notify the launcher |
266 | { | 264 | { |
267 | QCopEnvelope e ( "QPE/System", "reloadPowerWarnSettings()" ); | 265 | QCopEnvelope e ( "QPE/System", "reloadPowerWarnSettings()" ); |
268 | } | 266 | } |
269 | { | 267 | { |
270 | QCopEnvelope e ( "QPE/System", "setScreenSaverInterval(int)" ); | 268 | QCopEnvelope e ( "QPE/System", "setScreenSaverInterval(int)" ); |
271 | e << -1; | 269 | e << -1; |
272 | } | 270 | } |
273 | LightSettingsBase::accept ( ); | 271 | LightSettingsBase::accept ( ); |
274 | } | 272 | } |
275 | 273 | ||
276 | void LightSettings::done ( int r ) | 274 | void LightSettings::done ( int r ) |
277 | { | 275 | { |
278 | m_resettimer-> stop ( ); | 276 | m_resettimer-> stop ( ); |
279 | resetBacklight ( ); | 277 | resetBacklight ( ); |
280 | 278 | ||
281 | LightSettingsBase::done ( r ); | 279 | LightSettingsBase::done ( r ); |
282 | close ( ); | 280 | close ( ); |
283 | } | 281 | } |
diff --git a/core/settings/light-and-power/main.cpp b/core/settings/light-and-power/main.cpp index 68d433b..cb43ce0 100644 --- a/core/settings/light-and-power/main.cpp +++ b/core/settings/light-and-power/main.cpp | |||
@@ -1,29 +1,26 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include "light.h" | 21 | #include "light.h" |
22 | 22 | ||
23 | #include <qpe/qpeapplication.h> | ||
24 | #include <qpe/qcopenvelope_qws.h> | ||
25 | #include <qpe/global.h> | ||
26 | #include <opie/oapplicationfactory.h> | 23 | #include <opie/oapplicationfactory.h> |
27 | 24 | ||
28 | 25 | ||
29 | OPIE_EXPORT_APP( OApplicationFactory<LightSettings> ) | 26 | OPIE_EXPORT_APP( OApplicationFactory<LightSettings> ) |
diff --git a/core/settings/light-and-power/sensor.cpp b/core/settings/light-and-power/sensor.cpp index 5ca54d4..41de851 100644 --- a/core/settings/light-and-power/sensor.cpp +++ b/core/settings/light-and-power/sensor.cpp | |||
@@ -1,103 +1,102 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. Copyright (c) 2002 Maximilian Reiss <harlekin@handhelds.org> | 3 | =. Copyright (c) 2002 Maximilian Reiss <harlekin@handhelds.org> |
4 | .=l. Copyright (c) 2002 Robert Griebl <sandman@handhelds.org> | 4 | .=l. Copyright (c) 2002 Robert Griebl <sandman@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | #include <qframe.h> | ||
29 | #include <qlayout.h> | 28 | #include <qlayout.h> |
30 | #include <qslider.h> | 29 | #include <qslider.h> |
31 | #include <qspinbox.h> | 30 | #include <qspinbox.h> |
32 | 31 | ||
33 | #include <opie/odevice.h> | 32 | #include <opie/odevice.h> |
34 | 33 | ||
35 | using namespace Opie; | 34 | using namespace Opie; |
36 | 35 | ||
37 | #include "calibration.h" | 36 | #include "calibration.h" |
38 | #include "sensor.h" | 37 | #include "sensor.h" |
39 | 38 | ||
40 | Sensor::Sensor ( QStringList ¶ms, QWidget *parent, const char *name ) | 39 | Sensor::Sensor ( QStringList ¶ms, QWidget *parent, const char *name ) |
41 | : SensorBase ( parent, name, true, WStyle_ContextHelp ), m_params ( params ) | 40 | : SensorBase ( parent, name, true, WStyle_ContextHelp ), m_params ( params ) |
42 | { | 41 | { |
43 | int steps = 12; | 42 | int steps = 12; |
44 | int inter = 2; | 43 | int inter = 2; |
45 | 44 | ||
46 | int smin = 40; | 45 | int smin = 40; |
47 | int smax = 215; | 46 | int smax = 215; |
48 | int lmin = 1; | 47 | int lmin = 1; |
49 | int lmax = 255; | 48 | int lmax = 255; |
50 | 49 | ||
51 | switch ( params. count ( )) { | 50 | switch ( params. count ( )) { |
52 | case 6: lmax = params [5]. toInt ( ); | 51 | case 6: lmax = params [5]. toInt ( ); |
53 | case 5: lmin = params [4]. toInt ( ); | 52 | case 5: lmin = params [4]. toInt ( ); |
54 | case 4: smax = params [3]. toInt ( ); | 53 | case 4: smax = params [3]. toInt ( ); |
55 | case 3: smin = params [2]. toInt ( ); | 54 | case 3: smin = params [2]. toInt ( ); |
56 | case 2: steps = params [1]. toInt ( ); | 55 | case 2: steps = params [1]. toInt ( ); |
57 | case 1: inter = params [0]. toInt ( ) / 1000; | 56 | case 1: inter = params [0]. toInt ( ) / 1000; |
58 | } | 57 | } |
59 | 58 | ||
60 | int xscale = ODevice::inst ( )-> lightSensorResolution ( ); | 59 | int xscale = ODevice::inst ( )-> lightSensorResolution ( ); |
61 | int yscale = ODevice::inst ( )-> displayBrightnessResolution ( ); | 60 | int yscale = ODevice::inst ( )-> displayBrightnessResolution ( ); |
62 | 61 | ||
63 | QVBoxLayout *lay = new QVBoxLayout ( frame ); | 62 | QVBoxLayout *lay = new QVBoxLayout ( frame ); |
64 | lay-> setMargin ( 2 ); | 63 | lay-> setMargin ( 2 ); |
65 | m_calib = new Calibration ( frame ); | 64 | m_calib = new Calibration ( frame ); |
66 | lay-> add ( m_calib ); | 65 | lay-> add ( m_calib ); |
67 | 66 | ||
68 | m_calib-> setScale ( QSize ( xscale, yscale )); | 67 | m_calib-> setScale ( QSize ( xscale, yscale )); |
69 | m_calib-> setLineSteps ( steps ); | 68 | m_calib-> setLineSteps ( steps ); |
70 | m_calib-> setInterval ( inter ); | 69 | m_calib-> setInterval ( inter ); |
71 | m_calib-> setStartPoint ( QPoint ( smin * xscale / 256, lmax * yscale / 256 )); | 70 | m_calib-> setStartPoint ( QPoint ( smin * xscale / 256, lmax * yscale / 256 )); |
72 | m_calib-> setEndPoint ( QPoint ( smax * xscale / 256, lmin * yscale / 256 )); | 71 | m_calib-> setEndPoint ( QPoint ( smax * xscale / 256, lmin * yscale / 256 )); |
73 | 72 | ||
74 | interval-> setValue ( inter ); | 73 | interval-> setValue ( inter ); |
75 | linesteps-> setValue ( steps ); | 74 | linesteps-> setValue ( steps ); |
76 | 75 | ||
77 | connect ( interval, SIGNAL( valueChanged ( int )), m_calib, SLOT( setInterval ( int ))); | 76 | connect ( interval, SIGNAL( valueChanged ( int )), m_calib, SLOT( setInterval ( int ))); |
78 | connect ( linesteps, SIGNAL( valueChanged ( int )), m_calib, SLOT( setLineSteps ( int ))); | 77 | connect ( linesteps, SIGNAL( valueChanged ( int )), m_calib, SLOT( setLineSteps ( int ))); |
79 | 78 | ||
80 | connect ( m_calib, SIGNAL( startPointChanged ( const QPoint & )), this, SLOT( pointDrag ( const QPoint & ))); | 79 | connect ( m_calib, SIGNAL( startPointChanged ( const QPoint & )), this, SLOT( pointDrag ( const QPoint & ))); |
81 | connect ( m_calib, SIGNAL( endPointChanged ( const QPoint & )), this, SLOT( pointDrag ( const QPoint & ))); | 80 | connect ( m_calib, SIGNAL( endPointChanged ( const QPoint & )), this, SLOT( pointDrag ( const QPoint & ))); |
82 | } | 81 | } |
83 | 82 | ||
84 | void Sensor::accept ( ) | 83 | void Sensor::accept ( ) |
85 | { | 84 | { |
86 | int xscale = ODevice::inst ( )-> lightSensorResolution ( ); | 85 | int xscale = ODevice::inst ( )-> lightSensorResolution ( ); |
87 | int yscale = ODevice::inst ( )-> displayBrightnessResolution ( ); | 86 | int yscale = ODevice::inst ( )-> displayBrightnessResolution ( ); |
88 | 87 | ||
89 | m_params. clear ( ); | 88 | m_params. clear ( ); |
90 | m_params << QString::number ( m_calib-> interval ( ) * 1000 ) | 89 | m_params << QString::number ( m_calib-> interval ( ) * 1000 ) |
91 | << QString::number ( m_calib-> lineSteps ( )) | 90 | << QString::number ( m_calib-> lineSteps ( )) |
92 | << QString::number ( m_calib-> startPoint ( ). x ( ) * 256 / xscale ) | 91 | << QString::number ( m_calib-> startPoint ( ). x ( ) * 256 / xscale ) |
93 | << QString::number ( m_calib-> endPoint ( ). x ( ) * 256 / xscale ) | 92 | << QString::number ( m_calib-> endPoint ( ). x ( ) * 256 / xscale ) |
94 | << QString::number ( m_calib-> endPoint ( ). y ( ) * 256 / yscale ) | 93 | << QString::number ( m_calib-> endPoint ( ). y ( ) * 256 / yscale ) |
95 | << QString::number ( m_calib-> startPoint ( ). y ( ) * 256 / yscale ); | 94 | << QString::number ( m_calib-> startPoint ( ). y ( ) * 256 / yscale ); |
96 | 95 | ||
97 | QDialog::accept ( ); | 96 | QDialog::accept ( ); |
98 | } | 97 | } |
99 | 98 | ||
100 | void Sensor::pointDrag ( const QPoint &p ) | 99 | void Sensor::pointDrag ( const QPoint &p ) |
101 | { | 100 | { |
102 | emit viewBacklight ( p. y ( )); | 101 | emit viewBacklight ( p. y ( )); |
103 | } | 102 | } |