-rw-r--r-- | noncore/settings/appearance2/appearance.cpp | 105 | ||||
-rw-r--r-- | noncore/settings/appearance2/colorlistitem.h | 95 | ||||
-rw-r--r-- | noncore/settings/appearance2/editScheme.cpp | 10 | ||||
-rw-r--r-- | noncore/settings/appearance2/editScheme.h | 8 | ||||
-rw-r--r-- | noncore/settings/appearance2/sample.cpp | 11 |
5 files changed, 152 insertions, 77 deletions
diff --git a/noncore/settings/appearance2/appearance.cpp b/noncore/settings/appearance2/appearance.cpp index 52c7125..cf3069e 100644 --- a/noncore/settings/appearance2/appearance.cpp +++ b/noncore/settings/appearance2/appearance.cpp | |||
@@ -66,212 +66,174 @@ | |||
66 | #include <qvgroupbox.h> | 66 | #include <qvgroupbox.h> |
67 | #include <qwidget.h> | 67 | #include <qwidget.h> |
68 | 68 | ||
69 | #include "stylelistitem.h" | 69 | #include "stylelistitem.h" |
70 | #include "decolistitem.h" | 70 | #include "decolistitem.h" |
71 | #include "fontlistitem.h" | 71 | #include "fontlistitem.h" |
72 | #include "colorlistitem.h" | 72 | #include "colorlistitem.h" |
73 | 73 | ||
74 | #include "sample.h" | 74 | #include "sample.h" |
75 | 75 | ||
76 | 76 | ||
77 | static int findItemCB ( QComboBox *box, const QString &str ) | 77 | static int findItemCB ( QComboBox *box, const QString &str ) |
78 | { | 78 | { |
79 | for ( int i = 0; i < box-> count ( ); i++ ) { | 79 | for ( int i = 0; i < box-> count ( ); i++ ) { |
80 | if ( box-> text ( i ) == str ) | 80 | if ( box-> text ( i ) == str ) |
81 | return i; | 81 | return i; |
82 | } | 82 | } |
83 | return -1; | 83 | return -1; |
84 | } | 84 | } |
85 | 85 | ||
86 | class DefaultWindowDecoration : public WindowDecorationInterface | 86 | class DefaultWindowDecoration : public WindowDecorationInterface |
87 | { | 87 | { |
88 | public: | 88 | public: |
89 | DefaultWindowDecoration() : ref(0) {} | 89 | DefaultWindowDecoration() : ref(0) {} |
90 | QString name() const { | 90 | QString name() const { |
91 | return "Default"; | 91 | return "Default"; |
92 | } | 92 | } |
93 | QPixmap icon() const { | 93 | QPixmap icon() const { |
94 | return QPixmap(); | 94 | return QPixmap(); |
95 | } | 95 | } |
96 | QRESULT queryInterface( const QUuid &uuid, QUnknownInterface **iface ) { | 96 | QRESULT queryInterface( const QUuid &uuid, QUnknownInterface **iface ) { |
97 | *iface = 0; | 97 | *iface = 0; |
98 | if ( uuid == IID_QUnknown ) | 98 | if ( uuid == IID_QUnknown ) |
99 | *iface = this; | 99 | *iface = this; |
100 | else if ( uuid == IID_WindowDecoration ) | 100 | else if ( uuid == IID_WindowDecoration ) |
101 | *iface = this; | 101 | *iface = this; |
102 | 102 | ||
103 | if ( *iface ) | 103 | if ( *iface ) |
104 | (*iface)->addRef(); | 104 | (*iface)->addRef(); |
105 | return QS_OK; | 105 | return QS_OK; |
106 | } | 106 | } |
107 | Q_REFCOUNT | 107 | Q_REFCOUNT |
108 | 108 | ||
109 | private: | 109 | private: |
110 | ulong ref; | 110 | ulong ref; |
111 | }; | 111 | }; |
112 | 112 | ||
113 | 113 | ||
114 | struct { | ||
115 | QColorGroup::ColorRole role; | ||
116 | const char *key; | ||
117 | const char *def; | ||
118 | } colorLUT [] = { | ||
119 | { QColorGroup::Base, "Base", "#FFFFFF" }, | ||
120 | { QColorGroup::Background, "Background", "#E5E1D5" }, | ||
121 | { QColorGroup::Button, "Button", "#D6CDBB" }, | ||
122 | { QColorGroup::ButtonText, "ButtonText", "#000000" }, | ||
123 | { QColorGroup::Highlight, "Highlight", "#800000" }, | ||
124 | { QColorGroup::HighlightedText, "HighlightedText", "#FFFFFF" }, | ||
125 | { QColorGroup::Text, "Text", "#000000" }, | ||
126 | |||
127 | { QColorGroup::NColorRoles, 0, 0 } | ||
128 | }; | ||
129 | |||
130 | 114 | ||
131 | void Appearance::loadStyles ( QListBox *list ) | 115 | void Appearance::loadStyles ( QListBox *list ) |
132 | { | 116 | { |
133 | #if QT_VERSION >= 300 | 117 | #if QT_VERSION >= 300 |
134 | list->insertStringList(QStyleFactory::styles()); | 118 | list->insertStringList(QStyleFactory::styles()); |
135 | #else | 119 | #else |
136 | list->insertItem( new StyleListItem ( "Windows", new QWindowsStyle ( ))); | 120 | list->insertItem( new StyleListItem ( "Windows", new QWindowsStyle ( ))); |
137 | list->insertItem( new StyleListItem ( "Light", new LightStyle ( ))); | 121 | list->insertItem( new StyleListItem ( "Light", new LightStyle ( ))); |
138 | #ifndef QT_NO_STYLE_MOTIF | 122 | #ifndef QT_NO_STYLE_MOTIF |
139 | list->insertItem( new StyleListItem ( "Motif", new QMotifStyle ( ))); | 123 | list->insertItem( new StyleListItem ( "Motif", new QMotifStyle ( ))); |
140 | #endif | 124 | #endif |
141 | #ifndef QT_NO_STYLE_MOTIFPLUS | 125 | #ifndef QT_NO_STYLE_MOTIFPLUS |
142 | list->insertItem( new StyleListItem ( "MotifPlus", new QMotifPlusStyle ( ))); | 126 | list->insertItem( new StyleListItem ( "MotifPlus", new QMotifPlusStyle ( ))); |
143 | #endif | 127 | #endif |
144 | #ifndef QT_NO_STYLE_PLATINUM | 128 | #ifndef QT_NO_STYLE_PLATINUM |
145 | list->insertItem( new StyleListItem ( "Platinum", new QPlatinumStyle ( ))); | 129 | list->insertItem( new StyleListItem ( "Platinum", new QPlatinumStyle ( ))); |
146 | #endif | 130 | #endif |
147 | #endif | 131 | #endif |
148 | list->insertItem( new StyleListItem ( "QPE", new QPEStyle ( ))); | 132 | list->insertItem( new StyleListItem ( "QPE", new QPEStyle ( ))); |
149 | 133 | ||
150 | #if QT_VERSION < 300 | 134 | #if QT_VERSION < 300 |
151 | { | 135 | { |
152 | QString path = QPEApplication::qpeDir() + "/plugins/styles/"; | 136 | QString path = QPEApplication::qpeDir() + "/plugins/styles/"; |
153 | QStringList sl = QDir ( path, "lib*.so" ). entryList ( ); | 137 | QStringList sl = QDir ( path, "lib*.so" ). entryList ( ); |
154 | 138 | ||
155 | for ( QStringList::Iterator it = sl. begin ( ); it != sl. end ( ); ++it ) { | 139 | for ( QStringList::Iterator it = sl. begin ( ); it != sl. end ( ); ++it ) { |
156 | QLibrary *lib = new QLibrary ( path + "/" + *it ); | 140 | QLibrary *lib = new QLibrary ( path + "/" + *it ); |
157 | StyleInterface *iface; | 141 | StyleInterface *iface; |
158 | 142 | ||
159 | if ( lib-> queryInterface ( IID_Style, (QUnknownInterface **) &iface ) == QS_OK ) | 143 | if ( lib-> queryInterface ( IID_Style, (QUnknownInterface **) &iface ) == QS_OK ) |
160 | list-> insertItem ( new StyleListItem ( lib, iface )); | 144 | list-> insertItem ( new StyleListItem ( lib, iface )); |
161 | else | 145 | else |
162 | delete lib; | 146 | delete lib; |
163 | } | 147 | } |
164 | } | 148 | } |
165 | 149 | ||
166 | #endif | 150 | #endif |
167 | } | 151 | } |
168 | 152 | ||
169 | void Appearance::loadDecos ( QListBox *list ) | 153 | void Appearance::loadDecos ( QListBox *list ) |
170 | { | 154 | { |
171 | list-> insertItem ( new DecoListItem ( tr( "Default" ))); | 155 | list-> insertItem ( new DecoListItem ( tr( "Default" ))); |
172 | 156 | ||
173 | { | 157 | { |
174 | QString path = QPEApplication::qpeDir() + "/plugins/decorations/"; | 158 | QString path = QPEApplication::qpeDir() + "/plugins/decorations/"; |
175 | QStringList sl = QDir ( path, "lib*.so" ). entryList ( ); | 159 | QStringList sl = QDir ( path, "lib*.so" ). entryList ( ); |
176 | 160 | ||
177 | for ( QStringList::Iterator it = sl. begin ( ); it != sl. end ( ); ++it ) { | 161 | for ( QStringList::Iterator it = sl. begin ( ); it != sl. end ( ); ++it ) { |
178 | QLibrary *lib = new QLibrary ( path + "/" + *it ); | 162 | QLibrary *lib = new QLibrary ( path + "/" + *it ); |
179 | WindowDecorationInterface *iface; | 163 | WindowDecorationInterface *iface; |
180 | 164 | ||
181 | if ( lib-> queryInterface ( IID_WindowDecoration, (QUnknownInterface **) &iface ) == QS_OK ) | 165 | if ( lib-> queryInterface ( IID_WindowDecoration, (QUnknownInterface **) &iface ) == QS_OK ) |
182 | list-> insertItem ( new DecoListItem ( lib, iface )); | 166 | list-> insertItem ( new DecoListItem ( lib, iface )); |
183 | else | 167 | else |
184 | delete lib; | 168 | delete lib; |
185 | } | 169 | } |
186 | } | 170 | } |
187 | } | 171 | } |
188 | 172 | ||
189 | static QPalette readColorPalette ( Config &config ) | ||
190 | { | ||
191 | QColor bgcolor( config. readEntry( "Background", "#E5E1D5" ) ); | ||
192 | QColor btncolor( config. readEntry( "Button", "#D6CDBB" ) ); | ||
193 | QPalette pal( btncolor, bgcolor ); | ||
194 | |||
195 | QString color = config. readEntry( "Highlight", "#800000" ); | ||
196 | pal.setColor( QColorGroup::Highlight, QColor(color) ); | ||
197 | color = config. readEntry( "HighlightedText", "#FFFFFF" ); | ||
198 | pal.setColor( QColorGroup::HighlightedText, QColor(color) ); | ||
199 | color = config. readEntry( "Text", "#000000" ); | ||
200 | pal.setColor( QColorGroup::Text, QColor(color) ); | ||
201 | color = config. readEntry( "ButtonText", "#000000" ); | ||
202 | pal.setColor( QPalette::Active, QColorGroup::ButtonText, QColor(color) ); | ||
203 | color = config. readEntry( "Base", "#FFFFFF" ); | ||
204 | pal.setColor( QColorGroup::Base, QColor(color) ); | ||
205 | |||
206 | pal.setColor( QPalette::Disabled, QColorGroup::Text, pal.color(QPalette::Active, QColorGroup::Background).dark() ); | ||
207 | |||
208 | return pal; | ||
209 | } | ||
210 | |||
211 | void Appearance::loadColors ( QListBox *list ) | 173 | void Appearance::loadColors ( QListBox *list ) |
212 | { | 174 | { |
213 | list-> clear ( ); | 175 | list-> clear ( ); |
214 | { | 176 | { |
215 | Config config ( "qpe" ); | 177 | Config config ( "qpe" ); |
216 | config. setGroup ( "Appearance" ); | 178 | config. setGroup ( "Appearance" ); |
217 | 179 | ||
218 | list-> insertItem ( new ColorListItem ( tr( "Current scheme" ), readColorPalette ( config ))); | 180 | list-> insertItem ( new ColorListItem ( tr( "Current scheme" ), config )); |
219 | } | 181 | } |
220 | 182 | ||
221 | QString path = QPEApplication::qpeDir ( ) + "/etc/colors/"; | 183 | QString path = QPEApplication::qpeDir ( ) + "/etc/colors/"; |
222 | QStringList sl = QDir ( path ). entryList ( "*.scheme" ); | 184 | QStringList sl = QDir ( path ). entryList ( "*.scheme" ); |
223 | 185 | ||
224 | for ( QStringList::Iterator it = sl. begin ( ); it != sl. end ( ); ++it ) { | 186 | for ( QStringList::Iterator it = sl. begin ( ); it != sl. end ( ); ++it ) { |
225 | QString name = (*it). left ((*it). find ( ".scheme" )); | 187 | QString name = (*it). left ((*it). find ( ".scheme" )); |
226 | Config config ( path + *it, Config::File ); | 188 | Config config ( path + *it, Config::File ); |
227 | config. setGroup ( "Colors" ); | 189 | config. setGroup ( "Colors" ); |
228 | 190 | ||
229 | list-> insertItem ( new ColorListItem ( name, readColorPalette ( config ))); | 191 | list-> insertItem ( new ColorListItem ( name, config )); |
230 | } | 192 | } |
231 | } | 193 | } |
232 | 194 | ||
233 | void Appearance::loadFonts ( QListBox *list ) | 195 | void Appearance::loadFonts ( QListBox *list ) |
234 | { | 196 | { |
235 | FontDatabase fd; | 197 | FontDatabase fd; |
236 | QStringList f = fd. families ( ); | 198 | QStringList f = fd. families ( ); |
237 | 199 | ||
238 | for ( QStringList::ConstIterator it = f. begin ( ); it != f. end ( ); ++it ) | 200 | for ( QStringList::ConstIterator it = f. begin ( ); it != f. end ( ); ++it ) |
239 | list-> insertItem ( new FontListItem ( *it, fd. styles ( *it ), fd. pointSizes ( *it ))); | 201 | list-> insertItem ( new FontListItem ( *it, fd. styles ( *it ), fd. pointSizes ( *it ))); |
240 | } | 202 | } |
241 | 203 | ||
242 | 204 | ||
243 | QWidget *Appearance::createStyleTab ( QWidget *parent ) | 205 | QWidget *Appearance::createStyleTab ( QWidget *parent ) |
244 | { | 206 | { |
245 | Config config ( "qpe" ); | 207 | Config config ( "qpe" ); |
246 | config. setGroup ( "Appearance" ); | 208 | config. setGroup ( "Appearance" ); |
247 | 209 | ||
248 | QWidget* tab = new QWidget( parent, "StyleTab" ); | 210 | QWidget* tab = new QWidget( parent, "StyleTab" ); |
249 | QVBoxLayout* vertLayout = new QVBoxLayout( tab, 4, 4 ); | 211 | QVBoxLayout* vertLayout = new QVBoxLayout( tab, 4, 4 ); |
250 | 212 | ||
251 | m_style_list = new QListBox( tab, "m_style_list" ); | 213 | m_style_list = new QListBox( tab, "m_style_list" ); |
252 | vertLayout->addWidget( m_style_list ); | 214 | vertLayout->addWidget( m_style_list ); |
253 | 215 | ||
254 | m_style_settings = new QPushButton ( tr( "Settings..." ), tab ); | 216 | m_style_settings = new QPushButton ( tr( "Settings..." ), tab ); |
255 | connect ( m_style_settings, SIGNAL( clicked ( )), this, SLOT( styleSettingsClicked ( ))); | 217 | connect ( m_style_settings, SIGNAL( clicked ( )), this, SLOT( styleSettingsClicked ( ))); |
256 | vertLayout-> addWidget ( m_style_settings ); | 218 | vertLayout-> addWidget ( m_style_settings ); |
257 | 219 | ||
258 | loadStyles ( m_style_list ); | 220 | loadStyles ( m_style_list ); |
259 | 221 | ||
260 | QString s = config. readEntry ( "Style", "Light" ); | 222 | QString s = config. readEntry ( "Style", "Light" ); |
261 | m_style_list-> setCurrentItem ( m_style_list-> findItem ( s )); | 223 | m_style_list-> setCurrentItem ( m_style_list-> findItem ( s )); |
262 | m_original_style = m_style_list-> currentItem ( ); | 224 | m_original_style = m_style_list-> currentItem ( ); |
263 | styleClicked ( m_original_style ); | 225 | styleClicked ( m_original_style ); |
264 | 226 | ||
265 | connect( m_style_list, SIGNAL( highlighted( int ) ), this, SLOT( styleClicked( int ) ) ); | 227 | connect( m_style_list, SIGNAL( highlighted( int ) ), this, SLOT( styleClicked( int ) ) ); |
266 | 228 | ||
267 | return tab; | 229 | return tab; |
268 | } | 230 | } |
269 | 231 | ||
270 | QWidget *Appearance::createDecoTab ( QWidget *parent ) | 232 | QWidget *Appearance::createDecoTab ( QWidget *parent ) |
271 | { | 233 | { |
272 | Config config ( "qpe" ); | 234 | Config config ( "qpe" ); |
273 | config. setGroup ( "Appearance" ); | 235 | config. setGroup ( "Appearance" ); |
274 | 236 | ||
275 | QWidget* tab = new QWidget( parent, "DecoTab" ); | 237 | QWidget* tab = new QWidget( parent, "DecoTab" ); |
276 | QVBoxLayout* vertLayout = new QVBoxLayout( tab, 4, 4 ); | 238 | QVBoxLayout* vertLayout = new QVBoxLayout( tab, 4, 4 ); |
277 | 239 | ||
@@ -439,106 +401,105 @@ Appearance::Appearance( QWidget* parent, const char* name, WFlags ) | |||
439 | 401 | ||
440 | OTabWidget* tw = new OTabWidget ( this, "tabwidget", OTabWidget::Global, OTabWidget::Bottom ); | 402 | OTabWidget* tw = new OTabWidget ( this, "tabwidget", OTabWidget::Global, OTabWidget::Bottom ); |
441 | QWidget *styletab; | 403 | QWidget *styletab; |
442 | 404 | ||
443 | tw-> addTab ( styletab = createStyleTab ( tw ), "appearance/styletabicon.png", tr( "Style" )); | 405 | tw-> addTab ( styletab = createStyleTab ( tw ), "appearance/styletabicon.png", tr( "Style" )); |
444 | tw-> addTab ( createFontTab ( tw ), "appearance/fonttabicon.png", tr( "Font" )); | 406 | tw-> addTab ( createFontTab ( tw ), "appearance/fonttabicon.png", tr( "Font" )); |
445 | tw-> addTab ( createColorTab ( tw ), "appearance/colorstabicon.png", tr( "Colors" ) ); | 407 | tw-> addTab ( createColorTab ( tw ), "appearance/colorstabicon.png", tr( "Colors" ) ); |
446 | tw-> addTab ( createDecoTab ( tw ), "appearance/styletabicon.png", tr( "Windows" ) ); | 408 | tw-> addTab ( createDecoTab ( tw ), "appearance/styletabicon.png", tr( "Windows" ) ); |
447 | tw-> addTab ( createGuiTab ( tw ), "appearance/backgroundtabicon.png", tr( "Gui" ) ); | 409 | tw-> addTab ( createGuiTab ( tw ), "appearance/backgroundtabicon.png", tr( "Gui" ) ); |
448 | 410 | ||
449 | top-> addWidget ( tw, 10 ); | 411 | top-> addWidget ( tw, 10 ); |
450 | top-> addWidget ( m_sample, 1 ); | 412 | top-> addWidget ( m_sample, 1 ); |
451 | 413 | ||
452 | tw-> setCurrentTab ( styletab ); | 414 | tw-> setCurrentTab ( styletab ); |
453 | } | 415 | } |
454 | 416 | ||
455 | Appearance::~Appearance() | 417 | Appearance::~Appearance() |
456 | { | 418 | { |
457 | } | 419 | } |
458 | 420 | ||
459 | void Appearance::accept ( ) | 421 | void Appearance::accept ( ) |
460 | { | 422 | { |
461 | Config config("qpe"); | 423 | Config config("qpe"); |
462 | config.setGroup( "Appearance" ); | 424 | config.setGroup( "Appearance" ); |
463 | 425 | ||
464 | int newstyle = m_style_list-> currentItem ( ); | 426 | int newstyle = m_style_list-> currentItem ( ); |
465 | int newtabstyle = ( m_tabstyle_list-> currentItem ( ) & 0xff ) | \ | 427 | int newtabstyle = ( m_tabstyle_list-> currentItem ( ) & 0xff ) | \ |
466 | ( m_tabstyle_top-> isChecked ( ) ? 0x000 : 0x100 ); | 428 | ( m_tabstyle_top-> isChecked ( ) ? 0x000 : 0x100 ); |
467 | int newfontfamily = m_font_family_list-> currentItem ( ); | 429 | int newfontfamily = m_font_family_list-> currentItem ( ); |
468 | int newfontstyle = m_font_style_list-> currentItem ( ); | 430 | int newfontstyle = m_font_style_list-> currentItem ( ); |
469 | int newfontsize = m_font_size_list-> currentItem ( ); | 431 | int newfontsize = m_font_size_list-> currentItem ( ); |
470 | 432 | ||
471 | 433 | ||
472 | if ( m_style_changed ) { | 434 | if ( m_style_changed ) { |
473 | StyleListItem *item = (StyleListItem *) m_style_list-> item ( newstyle ); | 435 | StyleListItem *item = (StyleListItem *) m_style_list-> item ( newstyle ); |
474 | if ( item ) | 436 | if ( item ) |
475 | config.writeEntry( "Style", item-> key ( )); | 437 | config.writeEntry( "Style", item-> key ( )); |
476 | } | 438 | } |
477 | if ( newtabstyle != m_original_tabstyle ) { | 439 | if ( newtabstyle != m_original_tabstyle ) { |
478 | config. writeEntry ( "TabStyle", newtabstyle ); | 440 | config. writeEntry ( "TabStyle", newtabstyle ); |
479 | } | 441 | } |
480 | 442 | ||
481 | if ( m_font_changed ) { | 443 | if ( m_font_changed ) { |
482 | config.writeEntry( "FontFamily", m_font_family_list-> text ( newfontfamily )); | 444 | config.writeEntry( "FontFamily", m_font_family_list-> text ( newfontfamily )); |
483 | config.writeEntry( "FontStyle", m_font_style_list-> text ( newfontstyle )); | 445 | config.writeEntry( "FontStyle", m_font_style_list-> text ( newfontstyle )); |
484 | config.writeEntry( "FontSize", m_font_size_list-> text ( newfontsize )); | 446 | config.writeEntry( "FontSize", m_font_size_list-> text ( newfontsize )); |
485 | } | 447 | } |
486 | 448 | ||
487 | /* | 449 | |
488 | if ( schemeChanged ) | 450 | if ( m_color_changed ) |
489 | { | 451 | { |
490 | int i; | 452 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); |
491 | for ( i = 0; i < MAX_CONTROL; i++ ) | 453 | |
492 | { | 454 | if ( item ) |
493 | config.writeEntry( controlList[i], controlColor[i] ); | 455 | item-> save ( config ); |
494 | } | ||
495 | } | 456 | } |
496 | */ | 457 | |
497 | config. write ( ); // need to flush the config info first | 458 | config. write ( ); // need to flush the config info first |
498 | Global::applyStyle ( ); | 459 | Global::applyStyle ( ); |
499 | 460 | ||
500 | if ( QMessageBox::warning ( this, tr( "Restart" ), tr( "Do you want to restart Opie now?" ), tr( "Yes" ), tr( "No" ), 0, 0, 1 ) == 0 ) { | 461 | if ( QMessageBox::warning ( this, tr( "Restart" ), tr( "Do you want to restart Opie now?" ), tr( "Yes" ), tr( "No" ), 0, 0, 1 ) == 0 ) { |
501 | QCopEnvelope e( "QPE/System", "restart()" ); | 462 | QCopEnvelope e( "QPE/System", "restart()" ); |
502 | } | 463 | } |
503 | 464 | ||
504 | QDialog::accept ( ); | 465 | QDialog::accept ( ); |
505 | } | 466 | } |
506 | 467 | ||
507 | void Appearance::done ( int r ) | 468 | void Appearance::done ( int r ) |
508 | { | 469 | { |
509 | QDialog::done ( r ); | 470 | QDialog::done ( r ); |
510 | close ( ); | 471 | close ( ); |
511 | } | 472 | } |
512 | 473 | ||
513 | 474 | ||
514 | void Appearance::styleClicked ( int index ) | 475 | void Appearance::styleClicked ( int index ) |
515 | { | 476 | { |
516 | StyleListItem *sli = (StyleListItem *) m_style_list-> item ( index ); | 477 | StyleListItem *sli = (StyleListItem *) m_style_list-> item ( index ); |
517 | m_style_settings-> setEnabled ( sli ? sli-> hasSettings ( ) : false ); | 478 | m_style_settings-> setEnabled ( sli ? sli-> hasSettings ( ) : false ); |
518 | 479 | ||
519 | if ( m_sample && sli && sli-> style ( )) | 480 | if ( m_sample && sli && sli-> style ( )) |
520 | m_sample-> setStyle2 ( sli-> style ( )); | 481 | m_sample-> setStyle2 ( sli-> style ( )); |
521 | 482 | ||
522 | m_style_changed |= ( index != m_original_style ); | 483 | m_style_changed |= ( index != m_original_style ); |
523 | } | 484 | } |
524 | 485 | ||
525 | void Appearance::styleSettingsClicked ( ) | 486 | void Appearance::styleSettingsClicked ( ) |
526 | { | 487 | { |
527 | StyleListItem *item = (StyleListItem *) m_style_list-> item ( m_style_list-> currentItem ( )); | 488 | StyleListItem *item = (StyleListItem *) m_style_list-> item ( m_style_list-> currentItem ( )); |
528 | 489 | ||
529 | if ( item && item-> hasSettings ( )) { | 490 | if ( item && item-> hasSettings ( )) { |
530 | QDialog *d = new QDialog ( this, "SETTINGS-DLG", true ); | 491 | QDialog *d = new QDialog ( this, "SETTINGS-DLG", true ); |
531 | QVBoxLayout *vbox = new QVBoxLayout ( d, 4, 0 ); | 492 | QVBoxLayout *vbox = new QVBoxLayout ( d, 4, 0 ); |
532 | 493 | ||
533 | QWidget *w = item-> settings ( d ); | 494 | QWidget *w = item-> settings ( d ); |
534 | 495 | ||
535 | if ( w ) { | 496 | if ( w ) { |
536 | vbox-> addWidget ( w ); | 497 | vbox-> addWidget ( w ); |
537 | 498 | ||
538 | d-> setCaption ( w-> caption ( )); | 499 | d-> setCaption ( w-> caption ( )); |
539 | 500 | ||
540 | d-> showMaximized ( ); | 501 | d-> showMaximized ( ); |
541 | bool accepted = ( d-> exec ( ) == QDialog::Accepted ); | 502 | bool accepted = ( d-> exec ( ) == QDialog::Accepted ); |
542 | 503 | ||
543 | if ( item-> setSettings ( accepted )) | 504 | if ( item-> setSettings ( accepted )) |
544 | m_style_changed = true; | 505 | m_style_changed = true; |
@@ -607,123 +568,141 @@ void Appearance::fontFamilyClicked ( int index ) | |||
607 | 568 | ||
608 | void Appearance::fontStyleClicked ( int index ) | 569 | void Appearance::fontStyleClicked ( int index ) |
609 | { | 570 | { |
610 | changeText ( ); | 571 | changeText ( ); |
611 | 572 | ||
612 | m_font_changed |= ( index != m_original_fontstyle ); | 573 | m_font_changed |= ( index != m_original_fontstyle ); |
613 | } | 574 | } |
614 | 575 | ||
615 | void Appearance::fontSizeClicked ( int index ) | 576 | void Appearance::fontSizeClicked ( int index ) |
616 | { | 577 | { |
617 | changeText ( ); | 578 | changeText ( ); |
618 | 579 | ||
619 | m_font_changed |= ( index != m_original_fontsize ); | 580 | m_font_changed |= ( index != m_original_fontsize ); |
620 | } | 581 | } |
621 | 582 | ||
622 | void Appearance::changeText ( ) | 583 | void Appearance::changeText ( ) |
623 | { | 584 | { |
624 | int ffa = m_font_family_list-> currentItem ( ); | 585 | int ffa = m_font_family_list-> currentItem ( ); |
625 | int fst = m_font_style_list-> currentItem ( ); | 586 | int fst = m_font_style_list-> currentItem ( ); |
626 | int fsi = m_font_size_list-> currentItem ( ); | 587 | int fsi = m_font_size_list-> currentItem ( ); |
627 | 588 | ||
628 | FontListItem *fli = (FontListItem *) m_font_family_list-> item ( ffa ); | 589 | FontListItem *fli = (FontListItem *) m_font_family_list-> item ( ffa ); |
629 | 590 | ||
630 | if ( fli ) { | 591 | if ( fli ) { |
631 | FontDatabase fdb; | 592 | FontDatabase fdb; |
632 | 593 | ||
633 | m_sample-> setFont ( fdb. font ( fli-> family ( ), \ | 594 | m_sample-> setFont ( fdb. font ( fli-> family ( ), \ |
634 | fst >= 0 ? fli-> styles ( ) [fst] : QString::null, \ | 595 | fst >= 0 ? fli-> styles ( ) [fst] : QString::null, \ |
635 | fsi >= 0 ? fli-> sizes ( ) [fsi] : 10, \ | 596 | fsi >= 0 ? fli-> sizes ( ) [fsi] : 10, \ |
636 | fdb. charSets ( fli-> family ( )) [0] )); | 597 | fdb. charSets ( fli-> family ( )) [0] )); |
637 | } | 598 | } |
638 | } | 599 | } |
639 | 600 | ||
640 | void Appearance::colorClicked ( int index ) | 601 | void Appearance::colorClicked ( int index ) |
641 | { | 602 | { |
642 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( index ); | 603 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( index ); |
643 | 604 | ||
644 | if ( item ) | 605 | if ( item ) |
645 | m_sample-> setPalette ( item-> palette ( )); | 606 | m_sample-> setPalette ( item-> palette ( )); |
646 | 607 | ||
647 | m_color_changed |= ( item-> palette ( ) != qApp-> palette ( )); | 608 | m_color_changed |= ( item-> palette ( ) != qApp-> palette ( )); |
648 | } | 609 | } |
649 | 610 | ||
650 | 611 | ||
651 | void Appearance::editSchemeClicked ( ) | 612 | void Appearance::editSchemeClicked ( ) |
652 | { | 613 | { |
653 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); | 614 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); |
654 | 615 | ||
655 | /* | 616 | int cnt = 0; |
656 | EditScheme* editdlg = new EditScheme( this, "editScheme", TRUE, 0, | 617 | QString controlLabel [QColorGroup::NColorRoles]; |
657 | 9, controlLabel, controlColor ); | 618 | QString controlColor [QColorGroup::NColorRoles]; |
658 | editdlg->showMaximized(); | 619 | |
659 | if ( editdlg->exec() == QDialog::Accepted ) | 620 | for ( QColorGroup::ColorRole role = (QColorGroup::ColorRole) 0; role != QColorGroup::NColorRoles; ((int) role )++ ) { |
660 | { | 621 | QColor col = item-> color ( role ); |
661 | int i; | 622 | |
662 | for ( i = 0; i < MAX_CONTROL; i++ ) | 623 | if ( col. isValid ( )) { |
663 | { | 624 | controlLabel [cnt] = item-> label ( role ); |
664 | controlColor[i] = editdlg->colorList[i]; | 625 | controlColor [cnt] = col. name ( ); |
626 | |||
627 | cnt++; | ||
628 | } | ||
629 | } | ||
630 | |||
631 | EditScheme* editdlg = new EditScheme( this, "editScheme", true, 0, cnt, controlLabel, controlColor ); | ||
632 | editdlg-> showMaximized ( ); | ||
633 | if ( editdlg-> exec ( ) == QDialog::Accepted ) { | ||
634 | ColorListItem *citem = (ColorListItem *) m_color_list-> item ( 0 ); | ||
635 | cnt = 0; | ||
636 | |||
637 | for ( QColorGroup::ColorRole role = (QColorGroup::ColorRole) 0; role != QColorGroup::NColorRoles; ((int) role )++ ) { | ||
638 | if ( item-> color ( role ). isValid ( )) { | ||
639 | citem-> setColor ( role, QColor ( controlColor [cnt] )); | ||
640 | cnt++; | ||
641 | } | ||
665 | } | 642 | } |
643 | |||
644 | m_color_list-> setCurrentItem ( 0 ); | ||
645 | colorClicked ( 0 ); | ||
646 | |||
666 | m_color_changed = true; | 647 | m_color_changed = true; |
667 | } | 648 | } |
668 | delete editdlg; | 649 | delete editdlg; |
669 | */ | ||
670 | } | 650 | } |
671 | 651 | ||
672 | 652 | ||
673 | void Appearance::saveSchemeClicked() | 653 | void Appearance::saveSchemeClicked() |
674 | { | 654 | { |
675 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); | 655 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); |
676 | 656 | ||
677 | if ( !item ) | 657 | if ( !item ) |
678 | return; | 658 | return; |
679 | 659 | ||
680 | QDialog *d = new QDialog ( this, 0, true ); | 660 | QDialog *d = new QDialog ( this, 0, true ); |
681 | d-> setCaption ( tr( "Save Scheme" )); | 661 | d-> setCaption ( tr( "Save Scheme" )); |
682 | QLineEdit *ed = new QLineEdit ( this ); | 662 | QLineEdit *ed = new QLineEdit ( this ); |
683 | ( new QVBoxLayout ( d, 4, 4 ))-> addWidget ( ed ); | 663 | ( new QVBoxLayout ( d, 4, 4 ))-> addWidget ( ed ); |
684 | 664 | ||
685 | if ( d-> exec ( ) == QDialog::Accepted ) { | 665 | if ( d-> exec ( ) == QDialog::Accepted ) { |
686 | QString schemename = ed-> text ( ); | 666 | QString schemename = ed-> text ( ); |
687 | QFile file ( QPEApplication::qpeDir() + "/etc/colors/" + schemename + ".scheme" ); | 667 | QFile file ( QPEApplication::qpeDir() + "/etc/colors/" + schemename + ".scheme" ); |
688 | if ( !file. exists ( )) | 668 | if ( !file. exists ( )) |
689 | { | 669 | { |
690 | QPalette p = item-> palette ( ); | 670 | QPalette p = item-> palette ( ); |
691 | 671 | ||
692 | Config config ( file.name(), Config::File ); | 672 | Config config ( file.name(), Config::File ); |
693 | config.setGroup( "Colors" ); | 673 | config. setGroup( "Colors" ); |
694 | 674 | ||
695 | for ( int i = 0; colorLUT [i]. role != QColorGroup::NColorRoles; i++ ) | 675 | item-> save ( config ); |
696 | config.writeEntry ( colorLUT [i]. key, p. color ( QPalette::Active, colorLUT [i]. role ). name ( )); | 676 | |
697 | |||
698 | config. write ( ); // need to flush the config info first | 677 | config. write ( ); // need to flush the config info first |
699 | loadColors ( m_color_list ); | 678 | loadColors ( m_color_list ); |
700 | } | 679 | } |
701 | else | 680 | else |
702 | { | 681 | { |
703 | QMessageBox::information ( this, tr( "Save scheme" ), tr( "Scheme does already exist." )); | 682 | QMessageBox::information ( this, tr( "Save scheme" ), tr( "Scheme does already exist." )); |
704 | } | 683 | } |
705 | } | 684 | } |
706 | delete d; | 685 | delete d; |
707 | } | 686 | } |
708 | 687 | ||
709 | void Appearance::deleteSchemeClicked() | 688 | void Appearance::deleteSchemeClicked() |
710 | { | 689 | { |
711 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); | 690 | ColorListItem *item = (ColorListItem *) m_color_list-> item ( m_color_list-> currentItem ( )); |
712 | 691 | ||
713 | if ( !item ) | 692 | if ( !item ) |
714 | return; | 693 | return; |
715 | 694 | ||
716 | if ( m_color_list-> currentItem ( ) > 0 ) | 695 | if ( m_color_list-> currentItem ( ) > 0 ) |
717 | { | 696 | { |
718 | if ( QMessageBox::warning ( this, tr( "Delete scheme" ), tr( "Do you really want to delete\n" ) + item-> text ( ) + "?", | 697 | if ( QMessageBox::warning ( this, tr( "Delete scheme" ), tr( "Do you really want to delete\n" ) + item-> text ( ) + "?", |
719 | tr( "Yes" ), tr( "No" ), 0, 0, 1 ) == 0 ) { | 698 | tr( "Yes" ), tr( "No" ), 0, 0, 1 ) == 0 ) { |
720 | QFile::remove ( QPEApplication::qpeDir ( ) + "/etc/colors/" + item-> text ( ) + ".scheme" ); | 699 | QFile::remove ( QPEApplication::qpeDir ( ) + "/etc/colors/" + item-> text ( ) + ".scheme" ); |
721 | loadColors ( m_color_list ); | 700 | loadColors ( m_color_list ); |
722 | } | 701 | } |
723 | } | 702 | } |
724 | else | 703 | else |
725 | { | 704 | { |
726 | QMessageBox::information( this, tr( "Delete scheme" ), tr( "Unable to delete current scheme." )); | 705 | QMessageBox::information( this, tr( "Delete scheme" ), tr( "Unable to delete current scheme." )); |
727 | } | 706 | } |
728 | } | 707 | } |
729 | 708 | ||
diff --git a/noncore/settings/appearance2/colorlistitem.h b/noncore/settings/appearance2/colorlistitem.h index c7318a6..1ff6ecc 100644 --- a/noncore/settings/appearance2/colorlistitem.h +++ b/noncore/settings/appearance2/colorlistitem.h | |||
@@ -1,28 +1,113 @@ | |||
1 | #ifndef COLORLISTITEM_H | 1 | #ifndef COLORLISTITEM_H |
2 | #define COLORLISTITEM_H | 2 | #define COLORLISTITEM_H |
3 | 3 | ||
4 | #include <qlistbox.h> | 4 | #include <qlistbox.h> |
5 | #include <qpalette.h> | 5 | #include <qpalette.h> |
6 | #include <qapplication.h> | ||
7 | |||
8 | #include <qpe/config.h> | ||
9 | |||
10 | class Appearance; | ||
6 | 11 | ||
7 | class ColorListItem : public QListBoxText { | 12 | class ColorListItem : public QListBoxText { |
8 | public: | 13 | public: |
9 | ColorListItem ( const QString &t, const QPalette &pal ) : QListBoxText ( t ) | 14 | ColorListItem ( const QString &t, Config &cfg ) : QListBoxText ( t ) |
10 | { | 15 | { |
11 | m_pal = pal; | 16 | m_colors = new QColor [s_colorcount]; |
17 | load ( cfg ); | ||
12 | } | 18 | } |
13 | 19 | ||
14 | virtual ~ColorListItem ( ) | 20 | virtual ~ColorListItem ( ) |
15 | { | 21 | { |
22 | delete [] m_colors; | ||
16 | } | 23 | } |
17 | 24 | ||
18 | QPalette palette ( ) | 25 | QPalette palette ( ) |
19 | { | 26 | { |
20 | return m_pal; | 27 | return m_palette; |
28 | } | ||
29 | |||
30 | bool load ( Config &cfg ) | ||
31 | { | ||
32 | for ( int i = 0; i < s_colorcount; i++ ) | ||
33 | m_colors [i] = QColor ( cfg. readEntry ( s_colorlut [i]. m_key, s_colorlut [i]. m_def )); | ||
34 | |||
35 | buildPalette ( ); | ||
36 | return true; | ||
37 | } | ||
38 | |||
39 | void buildPalette ( ) | ||
40 | { | ||
41 | m_palette = QPalette ( m_colors [r2i(QColorGroup::Button)], m_colors [r2i(QColorGroup::Background)] ); | ||
42 | m_palette. setColor ( QColorGroup::Highlight, m_colors [r2i(QColorGroup::Highlight)] ); | ||
43 | m_palette. setColor ( QColorGroup::HighlightedText, m_colors [r2i(QColorGroup::HighlightedText)] ); | ||
44 | m_palette. setColor ( QColorGroup::Text, m_colors [r2i(QColorGroup::Text)] ); | ||
45 | m_palette. setColor ( QPalette::Active, QColorGroup::ButtonText, m_colors [r2i(QColorGroup::ButtonText)] ); | ||
46 | m_palette. setColor ( QColorGroup::Base, m_colors [r2i(QColorGroup::Base)] ); | ||
47 | m_palette. setColor ( QPalette::Disabled, QColorGroup::Text, m_palette. color ( QPalette::Active, QColorGroup::Background ). dark ( )); | ||
21 | } | 48 | } |
22 | 49 | ||
50 | bool save ( Config &cfg ) | ||
51 | { | ||
52 | for ( int i = 0; i < s_colorcount; i++ ) | ||
53 | cfg. writeEntry ( s_colorlut [i]. m_key, m_colors [i]. name ( )); | ||
54 | return true; | ||
55 | } | ||
56 | |||
57 | QColor color ( QColorGroup::ColorRole role ) | ||
58 | { | ||
59 | int i = r2i ( role ); | ||
60 | return i >= 0 ? m_colors [i] : QColor ( ); | ||
61 | } | ||
62 | |||
63 | void setColor ( QColorGroup::ColorRole role, QColor c ) | ||
64 | { | ||
65 | int i = r2i ( role ); | ||
66 | if ( i >= 0 ) { | ||
67 | m_colors [i] = c; | ||
68 | buildPalette ( ); | ||
69 | } | ||
70 | } | ||
71 | |||
72 | QString label ( QColorGroup::ColorRole role ) | ||
73 | { | ||
74 | int i = r2i ( role ); | ||
75 | return i >= 0 ? qApp-> translate ( "Appearance", s_colorlut [i]. m_label ) : QString::null; | ||
76 | } | ||
77 | |||
23 | private: | 78 | private: |
24 | QPalette m_pal; | 79 | QPalette m_palette; |
80 | QColor *m_colors; | ||
81 | |||
82 | static struct colorlut { | ||
83 | QColorGroup::ColorRole m_role; | ||
84 | const char * m_key; | ||
85 | const char * m_def; | ||
86 | const char * m_label; | ||
87 | } const s_colorlut []; | ||
88 | static const int s_colorcount; | ||
89 | |||
90 | static int r2i ( QColorGroup::ColorRole role ) | ||
91 | { | ||
92 | for ( int i = 0; i < s_colorcount; i++ ) { | ||
93 | if ( s_colorlut [i]. m_role == role ) | ||
94 | return i; | ||
95 | } | ||
96 | return -1; | ||
97 | } | ||
25 | }; | 98 | }; |
26 | 99 | ||
100 | const ColorListItem::colorlut ColorListItem::s_colorlut [] = { | ||
101 | { QColorGroup::Base, "Base", "#FFFFFF", QT_TRANSLATE_NOOP( "Appearance", "Base" ) }, | ||
102 | { QColorGroup::Background, "Background", "#E5E1D5", QT_TRANSLATE_NOOP( "Appearance", "Background" ) }, | ||
103 | { QColorGroup::Button, "Button", "#D6CDBB", QT_TRANSLATE_NOOP( "Appearance", "Button" ) }, | ||
104 | { QColorGroup::ButtonText, "ButtonText", "#000000", QT_TRANSLATE_NOOP( "Appearance", "Button Text" ) }, | ||
105 | { QColorGroup::Highlight, "Highlight", "#800000", QT_TRANSLATE_NOOP( "Appearance", "Highlight" ) }, | ||
106 | { QColorGroup::HighlightedText, "HighlightedText", "#FFFFFF", QT_TRANSLATE_NOOP( "Appearance", "Highlighted Text" ) }, | ||
107 | { QColorGroup::Text, "Text", "#000000", QT_TRANSLATE_NOOP( "Appearance", "Text" ) } | ||
108 | }; | ||
109 | |||
110 | const int ColorListItem::s_colorcount = sizeof( s_colorlut ) / sizeof ( s_colorlut [0] ); | ||
111 | |||
27 | 112 | ||
28 | #endif | 113 | #endif |
diff --git a/noncore/settings/appearance2/editScheme.cpp b/noncore/settings/appearance2/editScheme.cpp index 2453c7b..4f2ac2c 100644 --- a/noncore/settings/appearance2/editScheme.cpp +++ b/noncore/settings/appearance2/editScheme.cpp | |||
@@ -1,83 +1,87 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** EditScheme | 2 | ** EditScheme |
3 | ** | 3 | ** |
4 | ** Dialog for editing color scheme | 4 | ** Dialog for editing color scheme |
5 | ** | 5 | ** |
6 | ** Copyright (C) 2002, Dan Williams | 6 | ** Copyright (C) 2002, Dan Williams |
7 | ** williamsdr@acm.org | 7 | ** williamsdr@acm.org |
8 | ** http://draknor.net | 8 | ** http://draknor.net |
9 | ** | 9 | ** |
10 | ** This file may be distributed and/or modified under the terms of the | 10 | ** This file may be distributed and/or modified under the terms of the |
11 | ** GNU General Public License version 2 as published by the Free Software | 11 | ** GNU General Public License version 2 as published by the Free Software |
12 | ** Foundation and appearing in the file LICENSE.GPL included in the | 12 | ** Foundation and appearing in the file LICENSE.GPL included in the |
13 | ** packaging of this file. | 13 | ** packaging of this file. |
14 | ** | 14 | ** |
15 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 15 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
16 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 16 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
17 | ** | 17 | ** |
18 | **********************************************************************/ | 18 | **********************************************************************/ |
19 | 19 | ||
20 | #include "editScheme.h" | 20 | #include "editScheme.h" |
21 | 21 | ||
22 | #include "opie/colorpopupmenu.h" | 22 | #include "opie/colorpopupmenu.h" |
23 | 23 | ||
24 | #include <qaction.h> | 24 | #include <qaction.h> |
25 | #include <qlabel.h> | 25 | #include <qlabel.h> |
26 | #include <qlayout.h> | 26 | #include <qlayout.h> |
27 | #include <qpopupmenu.h> | 27 | #include <qpopupmenu.h> |
28 | #include <qscrollview.h> | 28 | #include <qscrollview.h> |
29 | #include <qtoolbutton.h> | 29 | #include <qtoolbutton.h> |
30 | 30 | ||
31 | EditScheme::EditScheme( QWidget* parent, const char* name, bool modal, WFlags fl, | 31 | EditScheme::EditScheme( QWidget* parent, const char* name, bool modal, WFlags fl, |
32 | int max, QString list[], QString colors[] ) | 32 | int max, QString *list, QString *colors ) |
33 | : QDialog( parent, name, modal, fl ) | 33 | : QDialog( parent, name, modal, fl ) |
34 | { | 34 | { |
35 | setCaption( tr( "Edit scheme" ) ); | 35 | setCaption( tr( "Edit scheme" ) ); |
36 | QGridLayout* layout = new QGridLayout( this ); | 36 | QGridLayout* layout = new QGridLayout( this ); |
37 | layout->setSpacing( 4 ); | 37 | layout->setSpacing( 4 ); |
38 | layout->setMargin( 4 ); | 38 | layout->setMargin( 4 ); |
39 | 39 | ||
40 | 40 | ||
41 | maxCount = max; | 41 | maxCount = max; |
42 | colorList = colors; | ||
43 | surfaceList = list; | ||
44 | colorButtons = new QToolButton * [max]; | ||
42 | int i; | 45 | int i; |
43 | QLabel* label; | 46 | QLabel* label; |
44 | ColorPopupMenu* colorPopupMenu; | 47 | ColorPopupMenu* colorPopupMenu; |
45 | for ( i = 0; i < max; i++ ) | 48 | for ( i = 0; i < max; i++ ) |
46 | { | 49 | { |
47 | colorList[i] = colors[i]; | 50 | // colorList[i] = colors[i]; |
48 | surfaceList[i] = list[i]; | 51 | // surfaceList[i] = list[i]; |
49 | label = new QLabel( tr( surfaceList[i] ), this ); | 52 | label = new QLabel( tr( surfaceList[i] ), this ); |
50 | layout->addWidget( label, i, 0 ); | 53 | layout->addWidget( label, i, 0 ); |
51 | colorButtons[i] = new QToolButton( this, list[i] ); | 54 | colorButtons[i] = new QToolButton( this, list[i] ); |
52 | colorButtons[i]->setPalette( QPalette( QColor( colors[i] ) ) ); | 55 | colorButtons[i]->setPalette( QPalette( QColor( colors[i] ) ) ); |
53 | layout->addWidget( colorButtons[i], i, 1 ); | 56 | layout->addWidget( colorButtons[i], i, 1 ); |
54 | 57 | ||
55 | colorPopupMenu = new ColorPopupMenu( colors[i], 0, list[i] ); | 58 | colorPopupMenu = new ColorPopupMenu( colors[i], 0, list[i] ); |
56 | colorButtons[i]->setPopup( colorPopupMenu ); | 59 | colorButtons[i]->setPopup( colorPopupMenu ); |
57 | colorButtons[i]->setPopupDelay( 0 ); | 60 | colorButtons[i]->setPopupDelay( 0 ); |
58 | connect( colorPopupMenu, SIGNAL( colorSelected( const QColor& ) ), this, SLOT( changeColor( const QColor& ) ) ); | 61 | connect( colorPopupMenu, SIGNAL( colorSelected( const QColor& ) ), this, SLOT( changeColor( const QColor& ) ) ); |
59 | } | 62 | } |
60 | } | 63 | } |
61 | 64 | ||
62 | EditScheme::~EditScheme() | 65 | EditScheme::~EditScheme() |
63 | { | 66 | { |
67 | delete [] colorButtons; | ||
64 | } | 68 | } |
65 | 69 | ||
66 | void EditScheme::changeColor( const QColor& color ) | 70 | void EditScheme::changeColor( const QColor& color ) |
67 | { | 71 | { |
68 | QString name( sender()->name() ); | 72 | QString name( sender()->name() ); |
69 | int i; | 73 | int i; |
70 | 74 | ||
71 | for ( i = 0; i < maxCount; i++ ) | 75 | for ( i = 0; i < maxCount; i++ ) |
72 | { | 76 | { |
73 | if ( name == colorButtons[i]->name() ) | 77 | if ( name == colorButtons[i]->name() ) |
74 | { | 78 | { |
75 | break; | 79 | break; |
76 | } | 80 | } |
77 | } | 81 | } |
78 | if ( i < maxCount && name == colorButtons[i]->name() ) | 82 | if ( i < maxCount && name == colorButtons[i]->name() ) |
79 | { | 83 | { |
80 | colorList[i] = color.name(); | 84 | colorList[i] = color.name(); |
81 | colorButtons[i]->setPalette( QPalette( QColor( colorList[i] ) ) ); | 85 | colorButtons[i]->setPalette( QPalette( QColor( colorList[i] ) ) ); |
82 | } | 86 | } |
83 | } | 87 | } |
diff --git a/noncore/settings/appearance2/editScheme.h b/noncore/settings/appearance2/editScheme.h index cf238c6..583050f 100644 --- a/noncore/settings/appearance2/editScheme.h +++ b/noncore/settings/appearance2/editScheme.h | |||
@@ -1,48 +1,48 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** EditScheme | 2 | ** EditScheme |
3 | ** | 3 | ** |
4 | ** Dialog for editing color scheme | 4 | ** Dialog for editing color scheme |
5 | ** | 5 | ** |
6 | ** Copyright (C) 2002, Dan Williams | 6 | ** Copyright (C) 2002, Dan Williams |
7 | ** williamsdr@acm.org | 7 | ** williamsdr@acm.org |
8 | ** http://draknor.net | 8 | ** http://draknor.net |
9 | ** | 9 | ** |
10 | ** This file may be distributed and/or modified under the terms of the | 10 | ** This file may be distributed and/or modified under the terms of the |
11 | ** GNU General Public License version 2 as published by the Free Software | 11 | ** GNU General Public License version 2 as published by the Free Software |
12 | ** Foundation and appearing in the file LICENSE.GPL included in the | 12 | ** Foundation and appearing in the file LICENSE.GPL included in the |
13 | ** packaging of this file. | 13 | ** packaging of this file. |
14 | ** | 14 | ** |
15 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 15 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
16 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 16 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
17 | ** | 17 | ** |
18 | **********************************************************************/ | 18 | **********************************************************************/ |
19 | 19 | ||
20 | #ifndef EDITSCHEME_H | 20 | #ifndef EDITSCHEME_H |
21 | #define EDITSCHEME_H | 21 | #define EDITSCHEME_H |
22 | 22 | ||
23 | #include <qdialog.h> | 23 | #include <qdialog.h> |
24 | #include <qtoolbutton.h> | 24 | #include <qtoolbutton.h> |
25 | 25 | ||
26 | class QColor; | 26 | class QColor; |
27 | 27 | ||
28 | class EditScheme : public QDialog | 28 | class EditScheme : public QDialog |
29 | { | 29 | { |
30 | Q_OBJECT | 30 | Q_OBJECT |
31 | 31 | ||
32 | public: | 32 | public: |
33 | EditScheme( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0, | 33 | EditScheme( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0, |
34 | int = 0, QString[] = 0, QString[] = 0 ); | 34 | int = 0, QString * = 0, QString * = 0 ); |
35 | ~EditScheme(); | 35 | ~EditScheme(); |
36 | 36 | ||
37 | int maxCount; | 37 | int maxCount; |
38 | QString surfaceList[9]; | 38 | QString * surfaceList; |
39 | QString colorList[9]; | 39 | QString * colorList; |
40 | 40 | ||
41 | 41 | ||
42 | QToolButton* colorButtons[9]; | 42 | QToolButton** colorButtons; |
43 | 43 | ||
44 | protected slots: | 44 | protected slots: |
45 | void changeColor( const QColor& ); | 45 | void changeColor( const QColor& ); |
46 | }; | 46 | }; |
47 | 47 | ||
48 | #endif // EDITSCHEME_H | 48 | #endif // EDITSCHEME_H |
diff --git a/noncore/settings/appearance2/sample.cpp b/noncore/settings/appearance2/sample.cpp index ee27d60..e447002 100644 --- a/noncore/settings/appearance2/sample.cpp +++ b/noncore/settings/appearance2/sample.cpp | |||
@@ -1,136 +1,143 @@ | |||
1 | #include <qvbox.h> | 1 | #include <qvbox.h> |
2 | #include <qpopupmenu.h> | 2 | #include <qpopupmenu.h> |
3 | #include <qpainter.h> | 3 | #include <qpainter.h> |
4 | #include <qmenubar.h> | 4 | #include <qmenubar.h> |
5 | #include <qcheckbox.h> | 5 | #include <qcheckbox.h> |
6 | #include <qpushbutton.h> | 6 | #include <qpushbutton.h> |
7 | #include <qscrollbar.h> | 7 | #include <qscrollbar.h> |
8 | #include <qlayout.h> | 8 | #include <qlayout.h> |
9 | #include <qwhatsthis.h> | 9 | #include <qwhatsthis.h> |
10 | #include <qpixmapcache.h> | 10 | #include <qpixmapcache.h> |
11 | #include <qtimer.h> | 11 | #include <qtimer.h> |
12 | #include <qobjectlist.h> | 12 | #include <qobjectlist.h> |
13 | #include <qcommonstyle.h> | ||
13 | 14 | ||
14 | #include "sample.h" | 15 | #include "sample.h" |
15 | 16 | ||
16 | 17 | ||
17 | class SampleText : public QWidget | 18 | class SampleText : public QWidget |
18 | { | 19 | { |
19 | public: | 20 | public: |
20 | SampleText( const QString &t, bool h, QWidget *parent ) | 21 | SampleText( const QString &t, bool h, QWidget *parent ) |
21 | : QWidget( parent ), hl(h), text(t) | 22 | : QWidget( parent ), hl(h), text(t) |
22 | { | 23 | { |
23 | if ( hl ) | 24 | if ( hl ) |
24 | setBackgroundMode( PaletteHighlight ); | 25 | setBackgroundMode( PaletteHighlight ); |
25 | else | 26 | else |
26 | setBackgroundMode( PaletteBase ); | 27 | setBackgroundMode( PaletteBase ); |
27 | } | 28 | } |
28 | 29 | ||
29 | QSize sizeHint() const | 30 | QSize sizeHint() const |
30 | { | 31 | { |
31 | QFontMetrics fm(font()); | 32 | QFontMetrics fm(font()); |
32 | return QSize( fm.width(text)+10, fm.height()+4 ); | 33 | return QSize( fm.width(text)+10, fm.height()+4 ); |
33 | } | 34 | } |
34 | 35 | ||
35 | void paintEvent( QPaintEvent * ) | 36 | void paintEvent( QPaintEvent * ) |
36 | { | 37 | { |
37 | QPainter p(this); | 38 | QPainter p(this); |
38 | if ( hl ) | 39 | if ( hl ) |
39 | p.setPen( colorGroup().highlightedText() ); | 40 | p.setPen( colorGroup().highlightedText() ); |
40 | else | 41 | else |
41 | p.setPen( colorGroup().text() ); | 42 | p.setPen( colorGroup().text() ); |
42 | p.drawText( rect(), AlignCenter, text ); | 43 | p.drawText( rect(), AlignCenter, text ); |
43 | } | 44 | } |
44 | 45 | ||
45 | private: | 46 | private: |
46 | bool hl; | 47 | bool hl; |
47 | QString text; | 48 | QString text; |
48 | }; | 49 | }; |
49 | 50 | ||
50 | 51 | ||
51 | SampleWindow::SampleWindow( QWidget *parent ) : QWidget(parent), iface(0) | 52 | SampleWindow::SampleWindow( QWidget *parent ) : QWidget(parent), iface(0) |
52 | { | 53 | { |
53 | init(); | 54 | init(); |
54 | } | 55 | } |
55 | 56 | ||
56 | QSize SampleWindow::sizeHint() const | 57 | QSize SampleWindow::sizeHint() const |
57 | { | 58 | { |
58 | return container->sizeHint() + QSize( 10, 35 ); | 59 | return container->sizeHint() + QSize( 10, 35 ); |
59 | } | 60 | } |
60 | 61 | ||
61 | void SampleWindow::setFont( const QFont &f ) | 62 | void SampleWindow::setFont( const QFont &f ) |
62 | { | 63 | { |
63 | QWidget::setFont( f ); | 64 | QWidget::setFont( f ); |
64 | popup->setFont( f ); | 65 | popup->setFont( f ); |
65 | QTimer::singleShot ( 0, this, SLOT( fixGeometry ( ))); | 66 | QTimer::singleShot ( 0, this, SLOT( fixGeometry ( ))); |
66 | } | 67 | } |
67 | 68 | ||
68 | static void setStyleRecursive ( QWidget *w, QStyle *s ) | 69 | static void setStyleRecursive ( QWidget *w, QStyle *s ) |
69 | { | 70 | { |
71 | w->setStyle( s ); | ||
70 | QObjectList *childObjects=(QObjectList*)w->children(); | 72 | QObjectList *childObjects=(QObjectList*)w->children(); |
71 | if ( childObjects ) { | 73 | if ( childObjects ) { |
72 | QObject * o; | 74 | QObject * o; |
73 | for(o=childObjects->first();o!=0;o=childObjects->next()) { | 75 | for(o=childObjects->first();o!=0;o=childObjects->next()) { |
74 | if( o->isWidgetType() ) { | 76 | if( o->isWidgetType() ) { |
75 | setStyleRecursive((QWidget *)o,s); | 77 | setStyleRecursive((QWidget *)o,s); |
76 | } | 78 | } |
77 | } | 79 | } |
78 | } | 80 | } |
79 | w->setStyle( s ); | ||
80 | } | 81 | } |
81 | 82 | ||
82 | 83 | ||
83 | void SampleWindow::setStyle2 ( QStyle *sty ) | 84 | void SampleWindow::setStyle2 ( QStyle *sty ) |
84 | { | 85 | { |
86 | typedef void (QStyle::*QDrawMenuBarItemImpl) (QPainter *, int, int, int, int, QMenuItem *, QColorGroup &, bool, bool); | ||
87 | |||
88 | extern QDrawMenuBarItemImpl qt_set_draw_menu_bar_impl(QDrawMenuBarItemImpl); | ||
89 | |||
85 | QPixmapCache::clear ( ); | 90 | QPixmapCache::clear ( ); |
86 | QPalette p = palette ( ); | 91 | QPalette p = palette ( ); |
87 | sty-> polish ( p ); | 92 | sty-> polish ( p ); |
93 | qt_set_draw_menu_bar_impl ( 0 ); | ||
88 | setStyleRecursive ( this, sty ); | 94 | setStyleRecursive ( this, sty ); |
95 | setPalette ( p ); | ||
89 | QTimer::singleShot ( 0, this, SLOT( fixGeometry ( ))); | 96 | QTimer::singleShot ( 0, this, SLOT( fixGeometry ( ))); |
90 | } | 97 | } |
91 | 98 | ||
92 | 99 | ||
93 | void SampleWindow::setDecoration( WindowDecorationInterface *i ) | 100 | void SampleWindow::setDecoration( WindowDecorationInterface *i ) |
94 | { | 101 | { |
95 | iface = i; | 102 | iface = i; |
96 | wd.rect = QRect( 0, 0, 150, 75 ); | 103 | wd.rect = QRect( 0, 0, 150, 75 ); |
97 | wd.caption = tr("Sample"); | 104 | wd.caption = tr("Sample"); |
98 | wd.palette = palette(); | 105 | wd.palette = palette(); |
99 | wd.flags = WindowDecorationInterface::WindowData::Dialog | | 106 | wd.flags = WindowDecorationInterface::WindowData::Dialog | |
100 | WindowDecorationInterface::WindowData::Active; | 107 | WindowDecorationInterface::WindowData::Active; |
101 | wd.reserved = 1; | 108 | wd.reserved = 1; |
102 | 109 | ||
103 | th = iface->metric(WindowDecorationInterface::TitleHeight, &wd); | 110 | th = iface->metric(WindowDecorationInterface::TitleHeight, &wd); |
104 | tb = iface->metric(WindowDecorationInterface::TopBorder, &wd); | 111 | tb = iface->metric(WindowDecorationInterface::TopBorder, &wd); |
105 | lb = iface->metric(WindowDecorationInterface::LeftBorder, &wd); | 112 | lb = iface->metric(WindowDecorationInterface::LeftBorder, &wd); |
106 | rb = iface->metric(WindowDecorationInterface::RightBorder, &wd); | 113 | rb = iface->metric(WindowDecorationInterface::RightBorder, &wd); |
107 | bb = iface->metric(WindowDecorationInterface::BottomBorder, &wd); | 114 | bb = iface->metric(WindowDecorationInterface::BottomBorder, &wd); |
108 | 115 | ||
109 | int yoff = th + tb; | 116 | int yoff = th + tb; |
110 | int xoff = lb; | 117 | int xoff = lb; |
111 | 118 | ||
112 | wd.rect.setX( 0 ); | 119 | wd.rect.setX( 0 ); |
113 | wd.rect.setWidth( width() - lb - rb ); | 120 | wd.rect.setWidth( width() - lb - rb ); |
114 | wd.rect.setY( 0 ); | 121 | wd.rect.setY( 0 ); |
115 | wd.rect.setHeight( height() - yoff - bb ); | 122 | wd.rect.setHeight( height() - yoff - bb ); |
116 | 123 | ||
117 | container->setGeometry( xoff, yoff, wd.rect.width(), wd.rect.height() ); | 124 | container->setGeometry( xoff, yoff, wd.rect.width(), wd.rect.height() ); |
118 | setMinimumSize( container->sizeHint().width()+lb+rb, | 125 | setMinimumSize( container->sizeHint().width()+lb+rb, |
119 | container->sizeHint().height()+tb+th+bb ); | 126 | container->sizeHint().height()+tb+th+bb ); |
120 | } | 127 | } |
121 | 128 | ||
122 | void SampleWindow::paintEvent( QPaintEvent * ) | 129 | void SampleWindow::paintEvent( QPaintEvent * ) |
123 | { | 130 | { |
124 | if ( !iface ) | 131 | if ( !iface ) |
125 | return; | 132 | return; |
126 | 133 | ||
127 | QPainter p( this ); | 134 | QPainter p( this ); |
128 | 135 | ||
129 | p.translate( lb, th+tb ); | 136 | p.translate( lb, th+tb ); |
130 | 137 | ||
131 | iface->drawArea(WindowDecorationInterface::Border, &p, &wd); | 138 | iface->drawArea(WindowDecorationInterface::Border, &p, &wd); |
132 | iface->drawArea(WindowDecorationInterface::Title, &p, &wd); | 139 | iface->drawArea(WindowDecorationInterface::Title, &p, &wd); |
133 | 140 | ||
134 | p.setPen(palette().active().color(QColorGroup::HighlightedText)); | 141 | p.setPen(palette().active().color(QColorGroup::HighlightedText)); |
135 | QFont f( font() ); | 142 | QFont f( font() ); |
136 | f.setWeight( QFont::Bold ); | 143 | f.setWeight( QFont::Bold ); |
@@ -161,76 +168,76 @@ void SampleWindow::init() | |||
161 | mb->insertItem( tr("Menu"), popup ); | 168 | mb->insertItem( tr("Menu"), popup ); |
162 | QHBox *hb = new QHBox( container ); | 169 | QHBox *hb = new QHBox( container ); |
163 | QWidget *w = new QWidget( hb ); | 170 | QWidget *w = new QWidget( hb ); |
164 | (void)new QScrollBar( 0, 0, 0, 0, 0, Vertical, hb ); | 171 | (void)new QScrollBar( 0, 0, 0, 0, 0, Vertical, hb ); |
165 | 172 | ||
166 | QGridLayout *gl = new QGridLayout( w, 2, 2, 4 ); | 173 | QGridLayout *gl = new QGridLayout( w, 2, 2, 4 ); |
167 | SampleText *l = new SampleText( tr("Normal Text"), FALSE, w ); | 174 | SampleText *l = new SampleText( tr("Normal Text"), FALSE, w ); |
168 | gl->addWidget( l, 0, 0 ); | 175 | gl->addWidget( l, 0, 0 ); |
169 | 176 | ||
170 | l = new SampleText( tr("Highlighted Text"), TRUE, w ); | 177 | l = new SampleText( tr("Highlighted Text"), TRUE, w ); |
171 | gl->addWidget( l, 1, 0 ); | 178 | gl->addWidget( l, 1, 0 ); |
172 | 179 | ||
173 | QPushButton *pb = new QPushButton( tr("Button"), w ); | 180 | QPushButton *pb = new QPushButton( tr("Button"), w ); |
174 | gl->addWidget( pb, 0, 1 ); | 181 | gl->addWidget( pb, 0, 1 ); |
175 | pb->setFocusPolicy( NoFocus ); | 182 | pb->setFocusPolicy( NoFocus ); |
176 | 183 | ||
177 | QCheckBox *cb = new QCheckBox( tr("Check Box"), w ); | 184 | QCheckBox *cb = new QCheckBox( tr("Check Box"), w ); |
178 | gl->addWidget( cb, 1, 1 ); | 185 | gl->addWidget( cb, 1, 1 ); |
179 | cb->setFocusPolicy( NoFocus ); | 186 | cb->setFocusPolicy( NoFocus ); |
180 | cb->setChecked( TRUE ); | 187 | cb->setChecked( TRUE ); |
181 | 188 | ||
182 | QWhatsThis::add( this, tr("Sample window using the selected settings.") ); | 189 | QWhatsThis::add( this, tr("Sample window using the selected settings.") ); |
183 | } | 190 | } |
184 | 191 | ||
185 | bool SampleWindow::eventFilter( QObject *, QEvent *e ) | 192 | bool SampleWindow::eventFilter( QObject *, QEvent *e ) |
186 | { | 193 | { |
187 | switch ( e->type() ) { | 194 | switch ( e->type() ) { |
188 | case QEvent::MouseButtonPress: | 195 | case QEvent::MouseButtonPress: |
189 | case QEvent::MouseButtonRelease: | 196 | case QEvent::MouseButtonRelease: |
190 | case QEvent::MouseButtonDblClick: | 197 | case QEvent::MouseButtonDblClick: |
191 | case QEvent::MouseMove: | 198 | case QEvent::MouseMove: |
192 | case QEvent::KeyPress: | 199 | case QEvent::KeyPress: |
193 | case QEvent::KeyRelease: | 200 | case QEvent::KeyRelease: |
194 | return TRUE; | 201 | return TRUE; |
195 | default: | 202 | default: |
196 | break; | 203 | break; |
197 | } | 204 | } |
198 | 205 | ||
199 | return FALSE; | 206 | return FALSE; |
200 | } | 207 | } |
201 | 208 | ||
202 | void SampleWindow::paletteChange( const QPalette &old ) | 209 | void SampleWindow::paletteChange( const QPalette &old ) |
203 | { | 210 | { |
204 | QWidget::paletteChange ( old ); | 211 | QWidget::paletteChange ( old ); |
205 | wd. palette = palette ( ); | 212 | wd. palette = palette ( ); |
206 | popup-> setPalette ( palette ( )); | 213 | popup-> setPalette ( palette ( )); |
207 | } | 214 | } |
208 | 215 | ||
216 | |||
209 | void SampleWindow::setPalette ( const QPalette &pal ) | 217 | void SampleWindow::setPalette ( const QPalette &pal ) |
210 | { | 218 | { |
211 | QPixmapCache::clear ( ); | 219 | QPixmapCache::clear ( ); |
212 | QPalette p = pal; | 220 | QPalette p = pal; |
213 | style ( ). polish ( p ); | 221 | style ( ). polish ( p ); |
214 | |||
215 | QWidget::setPalette ( p ); | 222 | QWidget::setPalette ( p ); |
216 | } | 223 | } |
217 | 224 | ||
218 | void SampleWindow::resizeEvent( QResizeEvent *re ) | 225 | void SampleWindow::resizeEvent( QResizeEvent *re ) |
219 | { | 226 | { |
220 | wd.rect = QRect( 0, 0, 150, 75 ); | 227 | wd.rect = QRect( 0, 0, 150, 75 ); |
221 | 228 | ||
222 | wd.rect.setX( 0 ); | 229 | wd.rect.setX( 0 ); |
223 | wd.rect.setWidth( width() - lb - rb ); | 230 | wd.rect.setWidth( width() - lb - rb ); |
224 | wd.rect.setY( 0 ); | 231 | wd.rect.setY( 0 ); |
225 | wd.rect.setHeight( height() - th - tb - bb ); | 232 | wd.rect.setHeight( height() - th - tb - bb ); |
226 | 233 | ||
227 | container->setGeometry( lb, th+tb, wd.rect.width(), wd.rect.height() ); | 234 | container->setGeometry( lb, th+tb, wd.rect.width(), wd.rect.height() ); |
228 | QWidget::resizeEvent( re ); | 235 | QWidget::resizeEvent( re ); |
229 | } | 236 | } |
230 | 237 | ||
231 | void SampleWindow::fixGeometry() | 238 | void SampleWindow::fixGeometry() |
232 | { | 239 | { |
233 | setMinimumSize( container->sizeHint().width()+lb+rb, | 240 | setMinimumSize( container->sizeHint().width()+lb+rb, |
234 | container->sizeHint().height()+tb+th+bb ); | 241 | container->sizeHint().height()+tb+th+bb ); |
235 | } | 242 | } |
236 | 243 | ||