summaryrefslogtreecommitdiffstats
path: root/plugin/simplestyle.cpp
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2012-03-16 18:16:40 -0500
committerTimothy Pearson <[email protected]>2012-03-16 18:16:40 -0500
commitde9aa982847ea40eaf9defa0da25e93201559d5d (patch)
treee5a6f29724dcb8c4d783c95e49d38d5e59df385d /plugin/simplestyle.cpp
parent7506cadc8d243931a745a50ff4a83c89af95a19f (diff)
downloadqt4-tqt-theme-engine-de9aa982847ea40eaf9defa0da25e93201559d5d.tar.gz
qt4-tqt-theme-engine-de9aa982847ea40eaf9defa0da25e93201559d5d.zip
Add support for a number of new complex controls
Diffstat (limited to 'plugin/simplestyle.cpp')
-rw-r--r--plugin/simplestyle.cpp658
1 files changed, 558 insertions, 100 deletions
diff --git a/plugin/simplestyle.cpp b/plugin/simplestyle.cpp
index 08299dc..dcba17a 100644
--- a/plugin/simplestyle.cpp
+++ b/plugin/simplestyle.cpp
@@ -27,7 +27,12 @@
#include <tqpopupmenu.h>
#include <tqmenudata.h>
#include <tqcombobox.h>
+#include <tqslider.h>
+#include <tqscrollbar.h>
+#include <tqspinbox.h>
#include <tqiconset.h>
+#include <tqmenubar.h>
+#include <qtitlebar_p.h>
#undef Qt
#include <QtGui/QtGui>
@@ -50,6 +55,50 @@
#define DEBUG_WARNINGS 1
// #define DEBUG_SPEW 1
+inline TQt::Orientation convertQt4ToTQt3Orientation(Qt::Orientation qt4orient)
+{
+ TQt::Orientation tqt3orient;
+
+ switch ( qt4orient ) {
+ case Qt::Horizontal:
+ tqt3orient = TQt::Horizontal;
+ break;
+ case Qt::Vertical:
+ tqt3orient = TQt::Vertical;
+ break;
+ }
+
+ return tqt3orient;
+}
+
+inline TQSlider::TickSetting convertQt4ToTQt3TickSetting(QSlider::TickPosition qt4ts)
+{
+ TQSlider::TickSetting tqt3ts;
+
+ switch ( qt4ts ) {
+ case QSlider::NoTicks:
+ tqt3ts = TQSlider::NoMarks;
+ break;
+ case QSlider::TicksBothSides:
+ tqt3ts = TQSlider::Both;
+ break;
+ case QSlider::TicksAbove:
+ tqt3ts = TQSlider::Above;
+ break;
+ case QSlider::TicksBelow:
+ tqt3ts = TQSlider::Below;
+ break;
+// case QSlider::TicksLeft:
+// tqt3ts = TQSlider::Left;
+// break;
+// case QSlider::TicksRight:
+// tqt3ts = TQSlider::Right;
+// break;
+ }
+
+ return tqt3ts;
+}
+
inline QColor convertTQt3ToQt4Color(TQColor tqt3color)
{
return QColor(tqt3color.red(), tqt3color.green(), tqt3color.blue());
@@ -422,7 +471,7 @@ inline TQStyle::SFlags convertQt4ToTQt3SFlags(QStyle::State qt4stateflags, TQt3W
TQStyle::SFlags sflags = 0;
if (qt4stateflags & QStyle::State_Active) {
- if (wt != TQT3WT_TQPopupMenu) {
+ if ((wt != TQT3WT_TQPopupMenu) && (wt != TQT3WT_TQMenuBar)) {
sflags = sflags | TQStyle::Style_Active;
}
}
@@ -472,7 +521,7 @@ inline TQStyle::SFlags convertQt4ToTQt3SFlags(QStyle::State qt4stateflags, TQt3W
// sflags = sflags | TQStyle::;
// }
if (qt4stateflags & QStyle::State_Selected) {
- if (wt == TQT3WT_TQPopupMenu) {
+ if ((wt == TQT3WT_TQPopupMenu) || (wt == TQT3WT_TQMenuBar)) {
sflags = sflags | TQStyle::Style_Active;
}
sflags = sflags | TQStyle::Style_Selected;
@@ -487,6 +536,9 @@ inline TQStyle::SFlags convertQt4ToTQt3SFlags(QStyle::State qt4stateflags, TQt3W
// sflags = sflags | TQStyle::;
// }
if (qt4stateflags & QStyle::State_Sunken) {
+ if ((wt == TQT3WT_TQPopupMenu) || (wt == TQT3WT_TQMenuBar)) {
+ sflags = sflags | TQStyle::Style_Down;
+ }
sflags = sflags | TQStyle::Style_Sunken;
}
if (qt4stateflags & QStyle::State_UpArrow) {
@@ -502,6 +554,9 @@ inline TQStyle::SFlags convertQt4ToTQt3SFlags(QStyle::State qt4stateflags, TQt3W
return sflags;
}
+#define NO_QT3_EQUIVALENT can_override = false;
+#define DO_NOT_DRAW can_override = false; do_not_draw = true;
+
SimpleStyle::SimpleStyle()
{
#ifdef INTEGRATE_WITH_TDE
@@ -541,11 +596,18 @@ SimpleStyle::SimpleStyle()
// Create interface widgets
m_tqt3parent_widget = new TQWidget();
+ m_tqt3generic_widget = new TQWidget(m_tqt3parent_widget);
m_tqt3progressbar_widget = new TQProgressBar(m_tqt3parent_widget);
m_tqt3tabbar_widget = new TQTabBar(m_tqt3parent_widget);
m_tqt3radiobutton_widget = new TQRadioButton(m_tqt3parent_widget);
m_tqt3popupmenu_widget = new TQPopupMenu(m_tqt3parent_widget);
m_tqt3combobox_widget = new TQComboBox(m_tqt3parent_widget);
+ m_tqt3slider_widget = new TQSlider(m_tqt3parent_widget);
+ m_tqt3scrollbar_widget = new TQScrollBar(m_tqt3parent_widget);
+ m_tqt3spinbox_widget = new TQSpinBox(m_tqt3parent_widget);
+ m_tqt3window_widget = new TQWidget(m_tqt3parent_widget);
+ m_tqt3titlebar_widget = new TQTitleBar(m_tqt3window_widget, m_tqt3parent_widget);
+ m_tqt3menubar_widget = new TQMenuBar(m_tqt3parent_widget);
}
SimpleStyle::~SimpleStyle()
@@ -554,11 +616,18 @@ SimpleStyle::~SimpleStyle()
// Delete interface widgets
// Widgets are deleted when their parent is deleted...these lines will cause a crash on exit
+// delete m_tqt3generic_widget;
// delete m_tqt3progressbar_widget;
// delete m_tqt3tabbar_widget;
// delete m_tqt3radiobutton_widget;
// delete m_tqt3popupmenu_widget;
// delete m_tqt3combobox_widget;
+// delete m_tqt3slider_widget;
+// delete m_tqt3scrollbar_widget;
+// delete m_tqt3spinbox_widget;
+// delete m_tqt3window_widget;
+// delete m_tqt3titlebar_widget;
+// delete m_tqt3menubar_widget;
// FIXME
// Verify I'm not leaking memory like a sieve when this is commented out!!!
@@ -599,7 +668,7 @@ bool SimpleStyle::eventFilter(QObject *obj, QEvent *ev)
return false;
}
- QWidget* widget = static_cast<QWidget*>(obj);
+ QWidget* widget = dynamic_cast<QWidget*>(obj);
if ((ev->type() == QEvent::FocusIn) || (ev->type() == QEvent::FocusOut)
|| (ev->type() == QEvent::Enter) || (ev->type() == QEvent::Leave) || (ev->type() == QEvent::Wheel)) {
@@ -681,14 +750,10 @@ int SimpleStyle::pixelMetric(PixelMetric metric, const QStyleOption *opt, const
// tqt3pixelmetric = TQStyle::PM_ComboBoxFrameWidth;
// retswitch = 1;
// break;
- case QStyle::PM_MDIFrameWidth:
+ case QStyle::PM_MdiSubWindowFrameWidth:
tqt3pixelmetric = TQStyle::PM_MDIFrameWidth;
retswitch = 1;
break;
-// case QStyle::PM_MdiSubWindowFrameWidth:
-// tqt3pixelmetric = TQStyle::PM_MdiSubWindowFrameWidth;
-// retswitch = 1;
-// break;
case QStyle::PM_MDIMinimizedWidth:
tqt3pixelmetric = TQStyle::PM_MDIMinimizedWidth;
retswitch = 1;
@@ -697,30 +762,30 @@ int SimpleStyle::pixelMetric(PixelMetric metric, const QStyleOption *opt, const
// tqt3pixelmetric = TQStyle::PM_MdiSubWindowMinimizedWidth;
// retswitch = 1;
// break;
- case QStyle::PM_LayoutLeftMargin:
- retval = 0;
- retswitch = 2;
- break;
- case QStyle::PM_LayoutTopMargin:
- retval = 0;
- retswitch = 2;
- break;
- case QStyle::PM_LayoutRightMargin:
- retval = 0;
- retswitch = 2;
- break;
- case QStyle::PM_LayoutBottomMargin:
- retval = 0;
- retswitch = 2;
- break;
- case QStyle::PM_LayoutHorizontalSpacing:
- retval = 0;
- retswitch = 2;
- break;
- case QStyle::PM_LayoutVerticalSpacing:
- retval = 0;
- retswitch = 2;
- break;
+// case QStyle::PM_LayoutLeftMargin:
+// retval = 0;
+// retswitch = 2;
+// break;
+// case QStyle::PM_LayoutTopMargin:
+// retval = 0;
+// retswitch = 2;
+// break;
+// case QStyle::PM_LayoutRightMargin:
+// retval = 0;
+// retswitch = 2;
+// break;
+// case QStyle::PM_LayoutBottomMargin:
+// retval = 0;
+// retswitch = 2;
+// break;
+// case QStyle::PM_LayoutHorizontalSpacing:
+// retval = 0;
+// retswitch = 2;
+// break;
+// case QStyle::PM_LayoutVerticalSpacing:
+// retval = 0;
+// retswitch = 2;
+// break;
case QStyle::PM_MaximumDragDistance:
tqt3pixelmetric = TQStyle::PM_MaximumDragDistance;
retswitch = 1;
@@ -859,6 +924,10 @@ int SimpleStyle::pixelMetric(PixelMetric metric, const QStyleOption *opt, const
break;
case QStyle::PM_TitleBarHeight:
tqt3pixelmetric = TQStyle::PM_TitleBarHeight;
+ if (opt) {
+ m_tqt3generic_widget->setGeometry(0, 0, opt->rect.width(), opt->rect.height());
+ interfaceWidget = m_tqt3generic_widget;
+ }
retswitch = 1;
break;
case QStyle::PM_IndicatorWidth:
@@ -881,14 +950,14 @@ int SimpleStyle::pixelMetric(PixelMetric metric, const QStyleOption *opt, const
// retval = 0;
// retswitch = 2;
// break;
- case QStyle::PM_MenuHMargin:
- retval = 0;
- retswitch = 2;
- break;
- case QStyle::PM_MenuVMargin:
- retval = 0;
- retswitch = 2;
- break;
+// case QStyle::PM_MenuHMargin:
+// retval = 0;
+// retswitch = 2;
+// break;
+// case QStyle::PM_MenuVMargin:
+// retval = 0;
+// retswitch = 2;
+// break;
// case QStyle::PM_MenuScrollerHeight:
// tqt3pixelmetric = TQStyle::PM_MenuScrollerHeight;
// retswitch = 1;
@@ -1006,21 +1075,28 @@ int SimpleStyle::pixelMetric(PixelMetric metric, const QStyleOption *opt, const
if (retswitch == 1) {
retval = tqApp->style().pixelMetric(tqt3pixelmetric, interfaceWidget);
+ // HACK
+ // For some reason Qt4 tacks on a pixel to this by default
+ // FIXME
+ // Figure out why!
+ if (tqt3pixelmetric == TQStyle::PM_TabBarTabVSpace) {
+ retval = retval - 1;
+ }
}
else {
-// if (retswitch == 2) {
-// // retval was already set
-// }
-// else {
+ if (retswitch == 2) {
+ // retval was already set
+ }
+ else {
// Tell Qt4 to get the information
retval = QCommonStyle::pixelMetric(metric, opt, w);
-// }
+ }
}
return retval;
}
-TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidget* w) const
+TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidget* w, const QStyleOption* qt4styleoptions) const
{
int i;
TQWidget* interfaceWidget = 0;
@@ -1031,14 +1107,23 @@ TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidge
const QMenu* qt4menu_widget = 0;
const QProgressBar* qt4progressbar_widget = 0;
const QComboBox* qt4combobox_widget = 0;
+ const QSlider* qt4slider_widget = 0;
+ const QScrollBar* qt4scrollbar_widget = 0;
+ const QSpinBox* qt4spinbox_widget = 0;
+ const QMenuBar* qt4menubar_widget = 0;
+
+ const QStyleOptionTitleBar* qt4titlebar_options = 0;
TQTabBar::Shape tqt3tbshape = TQTabBar::RoundedAbove;
+ QList<QAction*> qt4menuactions;
+ QAction* currentAction;
+
switch (wt) {
case TQT3WT_TQProgressBar:
interfaceWidget = m_tqt3progressbar_widget;
// Copy over all widget attributes
- qt4progressbar_widget = static_cast<const QProgressBar*>(w);
+ qt4progressbar_widget = dynamic_cast<const QProgressBar*>(w);
m_tqt3progressbar_widget->setGeometry(0, 0, qt4progressbar_widget->width(), qt4progressbar_widget->height());
m_tqt3progressbar_widget->setProgress(qt4progressbar_widget->value()-qt4progressbar_widget->minimum(),qt4progressbar_widget->maximum()-qt4progressbar_widget->minimum());
if (qt4progressbar_widget->orientation() != Qt::Horizontal) {
@@ -1052,52 +1137,60 @@ TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidge
case TQT3WT_TQTabBar:
interfaceWidget = m_tqt3tabbar_widget;
// Copy over all widget attributes
- qt4tabbar_widget = static_cast<const QTabBar*>(w);
- m_tqt3tabbar_widget->setGeometry(0, 0, qt4tabbar_widget->width(), qt4tabbar_widget->height());
- // Clear out tabbar
- for (i=0;i<m_tqt3tabbar_widget->count();i++) {
- m_tqt3tabbar_widget->removeTab(m_tqt3tabbar_widget->tabAt(i));
- }
- // Copy over all tabs
- for (i=0;i<qt4tabbar_widget->count();i++) {
- if (qt4tabbar_widget->tabIcon(i).isNull()) {
- TQTab* newTab = new TQTab(convertQt4ToTQt3String(qt4tabbar_widget->tabText(i)));
- m_tqt3tabbar_widget->insertTab(newTab, i);
- newTab->setIdentifier(i);
+ qt4tabbar_widget = dynamic_cast<const QTabBar*>(w);
+ if (qt4tabbar_widget) {
+ m_tqt3tabbar_widget->setGeometry(0, 0, qt4tabbar_widget->width(), qt4tabbar_widget->height());
+ // Clear out tabbar
+ for (i=0;i<m_tqt3tabbar_widget->count();i++) {
+ m_tqt3tabbar_widget->removeTab(m_tqt3tabbar_widget->tabAt(i));
}
- else {
- TQTab* newTab = new TQTab(convertQt4ToTQt3IconSet(qt4tabbar_widget->tabIcon(i)), convertQt4ToTQt3String(qt4tabbar_widget->tabText(i)));
- m_tqt3tabbar_widget->insertTab(newTab, i);
- newTab->setIdentifier(i);
+ // Copy over all tabs
+ for (i=0;i<qt4tabbar_widget->count();i++) {
+ if (qt4tabbar_widget->tabIcon(i).isNull()) {
+ TQTab* newTab = new TQTab(convertQt4ToTQt3String(qt4tabbar_widget->tabText(i)));
+ m_tqt3tabbar_widget->insertTab(newTab, i);
+ newTab->setIdentifier(i);
+ }
+ else {
+ TQTab* newTab = new TQTab(convertQt4ToTQt3IconSet(qt4tabbar_widget->tabIcon(i)), convertQt4ToTQt3String(qt4tabbar_widget->tabText(i)));
+ m_tqt3tabbar_widget->insertTab(newTab, i);
+ newTab->setIdentifier(i);
+ }
+ }
+ m_tqt3tabbar_widget->setCurrentTab(qt4tabbar_widget->currentIndex());
+ switch (qt4tabbar_widget->shape()) {
+ case QTabBar::RoundedNorth:
+ tqt3tbshape = TQTabBar::RoundedAbove;
+ break;
+ case QTabBar::RoundedSouth:
+ tqt3tbshape = TQTabBar::RoundedBelow;
+ break;
+ case QTabBar::TriangularNorth:
+ tqt3tbshape = TQTabBar::TriangularAbove;
+ break;
+ case QTabBar::TriangularSouth:
+ tqt3tbshape = TQTabBar::TriangularBelow;
+ break;
+ default:
+ // Qt3 cannot draw other tab shapes
+#ifdef DEBUG_WARNINGS
+ printf("No rules to draw Qt4 tab shape %d\n\r", qt4tabbar_widget->shape()); fflush(stdout);
+ interfaceWidget = 0;
+#endif
}
+ m_tqt3tabbar_widget->setShape(tqt3tbshape);
}
- m_tqt3tabbar_widget->setCurrentTab(qt4tabbar_widget->currentIndex());
- switch (qt4tabbar_widget->shape()) {
- case QTabBar::RoundedNorth:
- tqt3tbshape = TQTabBar::RoundedAbove;
- break;
- case QTabBar::RoundedSouth:
- tqt3tbshape = TQTabBar::RoundedBelow;
- break;
- case QTabBar::TriangularNorth:
- tqt3tbshape = TQTabBar::TriangularAbove;
- break;
- case QTabBar::TriangularSouth:
- tqt3tbshape = TQTabBar::TriangularBelow;
- break;
- default:
- // Qt3 cannot draw other tab shapes
+ else {
#ifdef DEBUG_WARNINGS
- printf("No rules to draw Qt4 tab shape %d\n\r", qt4tabbar_widget->shape()); fflush(stdout);
- interfaceWidget = 0;
+ printf("Unable to draw Qt4 tabbar with no Qt4 object available\n\r"); fflush(stdout);
+ interfaceWidget = 0;
#endif
}
- m_tqt3tabbar_widget->setShape(tqt3tbshape);
break;
case TQT3WT_TQRadioButton:
interfaceWidget = m_tqt3radiobutton_widget;
// Copy over all widget attributes
- qt4radiobutton_widget = static_cast<const QRadioButton*>(w);
+ qt4radiobutton_widget = dynamic_cast<const QRadioButton*>(w);
m_tqt3radiobutton_widget->setGeometry(0, 0, qt4radiobutton_widget->width(), qt4radiobutton_widget->height());
m_tqt3radiobutton_widget->setText(convertQt4ToTQt3String(qt4radiobutton_widget->text()));
m_tqt3radiobutton_widget->setDown(qt4radiobutton_widget->isDown());
@@ -1105,7 +1198,7 @@ TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidge
case TQT3WT_TQComboBox:
interfaceWidget = m_tqt3combobox_widget;
// Copy over all widget attributes
- qt4combobox_widget = static_cast<const QComboBox*>(w);
+ qt4combobox_widget = dynamic_cast<const QComboBox*>(w);
m_tqt3combobox_widget->setGeometry(0, 0, qt4combobox_widget->width(), qt4combobox_widget->height());
// Clear out all combobox items
m_tqt3combobox_widget->clear();
@@ -1123,14 +1216,14 @@ TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidge
case TQT3WT_TQPopupMenu:
interfaceWidget = m_tqt3popupmenu_widget;
// Copy over all widget attributes
- qt4menu_widget = static_cast<const QMenu*>(w);
+ qt4menu_widget = dynamic_cast<const QMenu*>(w);
m_tqt3popupmenu_widget->setGeometry(0, 0, qt4menu_widget->width(), qt4menu_widget->height());
// Clear out menu
m_tqt3popupmenu_widget->clear();
m_tqt3popupmenu_widget->setCheckable(false);
// Copy over all menu items
- QList<QAction*> qt4menuactions = qt4menu_widget->actions();
- QAction* currentAction = 0;
+ qt4menuactions = qt4menu_widget->actions();
+ currentAction = 0;
for (i=0; i<qt4menuactions.size();++i) {
currentAction = qt4menuactions.at(i);
if (currentAction) {
@@ -1156,6 +1249,109 @@ TQWidget* SimpleStyle::initializeInterfaceWidget(TQt3WidgetType wt, const QWidge
}
}
break;
+ case TQT3WT_TQMenuBar:
+ interfaceWidget = m_tqt3menubar_widget;
+ // Copy over all widget attributes
+ qt4menubar_widget = dynamic_cast<const QMenuBar*>(w);
+ m_tqt3menubar_widget->setGeometry(0, 0, qt4menubar_widget->width(), qt4menubar_widget->height());
+ // Clear out menu
+ m_tqt3menubar_widget->clear();
+ // Copy over all menu items
+ qt4menuactions = qt4menubar_widget->actions();
+ currentAction = 0;
+ for (i=0; i<qt4menuactions.size();++i) {
+ currentAction = qt4menuactions.at(i);
+ if (currentAction) {
+ if (currentAction->isSeparator()) {
+ m_tqt3menubar_widget->insertSeparator(i);
+ }
+ else {
+ if (currentAction->icon().isNull()) {
+ m_tqt3menubar_widget->insertItem(convertQt4ToTQt3String(currentAction->text()), i, i);
+ }
+ else {
+ m_tqt3menubar_widget->insertItem(convertQt4ToTQt3IconSet(currentAction->icon()), convertQt4ToTQt3String(currentAction->text()), i, i);
+ }
+ // FIXME
+ // Handle pixmaps, etc.
+ }
+ m_tqt3menubar_widget->setItemEnabled(i, currentAction->isEnabled());
+ m_tqt3menubar_widget->setItemChecked(i, currentAction->isChecked());
+ m_tqt3menubar_widget->setItemVisible(i, currentAction->isVisible());
+ }
+ }
+ break;
+ case TQT3WT_TQSlider:
+ interfaceWidget = m_tqt3slider_widget;
+ // Copy over all widget attributes
+ qt4slider_widget = dynamic_cast<const QSlider*>(w);
+ if (qt4slider_widget) {
+ m_tqt3slider_widget->setGeometry(0, 0, qt4slider_widget->width(), qt4slider_widget->height());
+ m_tqt3slider_widget->setOrientation(convertQt4ToTQt3Orientation(qt4slider_widget->orientation()));
+ m_tqt3slider_widget->setTracking(qt4slider_widget->hasTracking());
+// m_tqt3slider_widget->setPalette(); // FIXME
+ m_tqt3slider_widget->setTickmarks(convertQt4ToTQt3TickSetting(qt4slider_widget->tickPosition()));
+ m_tqt3slider_widget->setTickInterval(qt4slider_widget->tickInterval());
+ m_tqt3slider_widget->setMinValue(qt4slider_widget->minimum());
+ m_tqt3slider_widget->setMaxValue(qt4slider_widget->maximum());
+ m_tqt3slider_widget->setLineStep(qt4slider_widget->singleStep());
+ m_tqt3slider_widget->setPageStep(qt4slider_widget->pageStep());
+ m_tqt3slider_widget->setValue(qt4slider_widget->value());
+ }
+ else {
+#ifdef DEBUG_WARNINGS
+ printf("Unable to draw Qt4 slider with no Qt4 object available\n\r"); fflush(stdout);
+ interfaceWidget = 0;
+#endif
+ }
+ break;
+ case TQT3WT_TQScrollBar:
+ interfaceWidget = m_tqt3scrollbar_widget;
+ // Copy over all widget attributes
+ qt4scrollbar_widget = dynamic_cast<const QScrollBar*>(w);
+ if (qt4scrollbar_widget) {
+ m_tqt3scrollbar_widget->setGeometry(0, 0, qt4scrollbar_widget->width(), qt4scrollbar_widget->height());
+ m_tqt3scrollbar_widget->setOrientation(convertQt4ToTQt3Orientation(qt4scrollbar_widget->orientation()));
+ m_tqt3scrollbar_widget->setTracking(qt4scrollbar_widget->hasTracking());
+ m_tqt3scrollbar_widget->setMinValue(qt4scrollbar_widget->minimum());
+ m_tqt3scrollbar_widget->setMaxValue(qt4scrollbar_widget->maximum());
+ m_tqt3scrollbar_widget->setLineStep(qt4scrollbar_widget->singleStep());
+ m_tqt3scrollbar_widget->setPageStep(qt4scrollbar_widget->pageStep());
+ m_tqt3scrollbar_widget->setValue(qt4scrollbar_widget->value());
+ }
+ else {
+#ifdef DEBUG_WARNINGS
+ printf("Unable to draw Qt4 scrollbar with no Qt4 object available\n\r"); fflush(stdout);
+ interfaceWidget = 0;
+#endif
+ }
+ break;
+ case TQT3WT_TQSpinBox:
+ interfaceWidget = m_tqt3spinbox_widget;
+ // Copy over all widget attributes
+ qt4spinbox_widget = dynamic_cast<const QSpinBox*>(w);
+ if (qt4spinbox_widget) {
+ m_tqt3spinbox_widget->setGeometry(0, 0, qt4spinbox_widget->width(), qt4spinbox_widget->height());
+ m_tqt3spinbox_widget->setMinValue(qt4spinbox_widget->minimum());
+ m_tqt3spinbox_widget->setMaxValue(qt4spinbox_widget->maximum());
+ m_tqt3spinbox_widget->setLineStep(qt4spinbox_widget->singleStep());
+ m_tqt3spinbox_widget->setValue(qt4spinbox_widget->value());
+ }
+ else {
+#ifdef DEBUG_WARNINGS
+ printf("Unable to draw Qt4 spinbox with no Qt4 object available\n\r"); fflush(stdout);
+ interfaceWidget = 0;
+#endif
+ }
+ break;
+ case TQT3WT_TQTitleBar:
+ interfaceWidget = m_tqt3titlebar_widget;
+ qt4titlebar_options = static_cast<const QStyleOptionTitleBar*>(qt4styleoptions);
+ // Construct an internal TQTitleBar widget from the options and widget provided by Qt4
+ m_tqt3titlebar_widget->setGeometry(qt4styleoptions->rect.x(), qt4styleoptions->rect.y(), qt4styleoptions->rect.width(), qt4styleoptions->rect.height());
+ m_tqt3titlebar_widget->setCaption(convertQt4ToTQt3String(qt4titlebar_options->text));
+ m_tqt3titlebar_widget->setIcon(convertQt4ToTQt3Pixmap(qt4titlebar_options->icon));
+ m_tqt3titlebar_widget->setActive(qt4titlebar_options->titleBarState & Qt::WindowActive);
}
return interfaceWidget;
@@ -1216,6 +1412,8 @@ void SimpleStyle::drawComplexControl(ComplexControl control, const QStyleOptionC
TQWidget* interfaceWidget = 0;
TQStyleOption tqt3opt(TQStyleOption::Default);
+ TQRect tqt3rect(opt->rect.x(), opt->rect.y(), opt->rect.width(), opt->rect.height());
+
// Determine the correct color group
sflags = convertQt4ToTQt3SFlags(opt->state, TQT3WT_NONE);
TQPalette tqt3palette = convertQt4ToTQt3Palette(opt->palette);
@@ -1232,6 +1430,15 @@ void SimpleStyle::drawComplexControl(ComplexControl control, const QStyleOptionC
tqt3colorgroup = tqt3palette.disabled();
}
+ const QStyleOptionTitleBar* tbopt;
+ bool drawCloseButton;
+ bool drawMaxButton;
+ bool drawMinButton;
+ bool drawNormalButton;
+ bool drawShadeButton;
+ bool drawUnshadeButton;
+ bool drawSysMenuButton;
+
switch (control) {
case CC_ComboBox:
tqtCC = TQStyle::CC_ComboBox;
@@ -1240,6 +1447,120 @@ void SimpleStyle::drawComplexControl(ComplexControl control, const QStyleOptionC
can_override = false;
}
break;
+ case CC_Slider:
+ tqtCC = TQStyle::CC_Slider;
+ interfaceWidget = initializeInterfaceWidget(TQT3WT_TQSlider, w);
+ if (interfaceWidget == 0) {
+ can_override = false;
+ }
+ break;
+ case CC_ScrollBar:
+ tqtCC = TQStyle::CC_ScrollBar;
+ interfaceWidget = initializeInterfaceWidget(TQT3WT_TQScrollBar, w);
+ if (interfaceWidget == 0) {
+ can_override = false;
+ }
+ break;
+// case CC_SpinBox:
+// // FIXME FIXME FIXME
+// // This is more complex to interface with
+// // Under TQt3 there is an internal SpinWidget, and the SpinBox draws the editor through another call
+// // Under Qt4 there is only the SpinBox, and we would need to draw both the SpinWidget and the editor
+// tqtCC = TQStyle::CC_SpinWidget;
+// interfaceWidget = initializeInterfaceWidget(TQT3WT_TQSpinBox, w);
+// if (interfaceWidget == 0) {
+// can_override = false;
+// }
+// break;
+ case CC_TitleBar:
+ tqtCC = TQStyle::CC_TitleBar;
+ interfaceWidget = initializeInterfaceWidget(TQT3WT_TQTitleBar, w, opt);
+ if (interfaceWidget == 0) {
+ can_override = false;
+ }
+ else {
+ // Select subcontrol(s) to be drawn
+ // Qt4 made this hard again (surprise surprise)
+ tbopt = static_cast<const QStyleOptionTitleBar*>(opt);
+
+ // This logic is taken from Qt4 (qcommonstyle.cpp)
+ // It will need to be kept in sync with whatever Nokia does
+ drawCloseButton = (tbopt->subControls & SC_TitleBarCloseButton && tbopt->titleBarFlags & Qt::WindowSystemMenuHint);
+ drawMaxButton = (tbopt->subControls & SC_TitleBarMaxButton && tbopt->titleBarFlags & Qt::WindowMaximizeButtonHint && !(tbopt->titleBarState & Qt::WindowMaximized));
+ drawMinButton = (tbopt->subControls & SC_TitleBarMinButton && tbopt->titleBarFlags & Qt::WindowMinimizeButtonHint && !(tbopt->titleBarState & Qt::WindowMinimized));
+ drawNormalButton = (tbopt->subControls & SC_TitleBarNormalButton) && (((tbopt->titleBarFlags & Qt::WindowMinimizeButtonHint) && (tbopt->titleBarState & Qt::WindowMinimized)) || ((tbopt->titleBarFlags & Qt::WindowMaximizeButtonHint) && (tbopt->titleBarState & Qt::WindowMaximized)));
+ drawShadeButton = (tbopt->subControls & SC_TitleBarShadeButton && tbopt->titleBarFlags & Qt::WindowShadeButtonHint && !(tbopt->titleBarState & Qt::WindowMinimized));
+ drawUnshadeButton = (tbopt->subControls & SC_TitleBarUnshadeButton && tbopt->titleBarFlags & Qt::WindowShadeButtonHint && tbopt->titleBarState & Qt::WindowMinimized);
+ drawSysMenuButton = (tbopt->subControls & SC_TitleBarSysMenu && tbopt->titleBarFlags & Qt::WindowSystemMenuHint);
+ // End logic taken from Qt4
+
+ // FIXME
+ // TQt3 has no idea how to draw the restore button on a maximized window!!!
+ // This needs to be fixed in qcommonstyle.cpp drawComplexControl, case CC_TitleBar
+ // Once this is fixed in TQt3, the logic below needs to be updated
+
+ subControl = 0;
+ if (drawSysMenuButton) {
+ subControl = subControl | TQStyle::SC_TitleBarSysMenu;
+ }
+ if (drawMinButton) {
+ subControl = subControl | TQStyle::SC_TitleBarMinButton;
+ }
+ if (drawMaxButton) {
+ subControl = subControl | TQStyle::SC_TitleBarMaxButton;
+ }
+ if (drawCloseButton) {
+ subControl = subControl | TQStyle::SC_TitleBarCloseButton;
+ }
+ if (tbopt->subControls & SC_TitleBarLabel) {
+ subControl = subControl | TQStyle::SC_TitleBarLabel;
+ }
+ if (drawNormalButton && !(tbopt->titleBarState & Qt::WindowMaximized)) {
+ subControl = subControl | TQStyle::SC_TitleBarNormalButton;
+ }
+ if (drawShadeButton) {
+ subControl = subControl | TQStyle::SC_TitleBarShadeButton;
+ }
+ if (drawUnshadeButton) {
+ subControl = subControl | TQStyle::SC_TitleBarUnshadeButton;
+ }
+// if (tbopt->subControls & SC_TitleBarContextHelpButton) {
+// subControl = subControl | TQStyle::SC_TitleBarContextHelpButton;
+// }
+
+ subControlActive = 0;
+ if (tbopt->activeSubControls & SC_TitleBarSysMenu) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarSysMenu;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarMinButton) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarMinButton;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarMaxButton) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarMaxButton;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarCloseButton) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarCloseButton;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarLabel) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarLabel;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarNormalButton) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarNormalButton;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarShadeButton) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarShadeButton;
+ }
+ if (tbopt->activeSubControls & SC_TitleBarUnshadeButton) {
+ subControlActive = subControlActive | TQStyle::SC_TitleBarUnshadeButton;
+ }
+// if (tbopt->activeSubControls & SC_TitleBarContextHelpButton) {
+// subControlActive = subControlActive | TQStyle::SC_TitleBarContextHelpButton;
+// }
+ }
+ break;
+ case CC_GroupBox:
+ NO_QT3_EQUIVALENT
+ break;
default:
#ifdef DEBUG_WARNINGS
printf("No rules to draw Qt4 complex control %d\n\r", control); fflush(stdout);
@@ -1253,8 +1574,20 @@ void SimpleStyle::drawComplexControl(ComplexControl control, const QStyleOptionC
TQPainter tqtPainter(&qt4pd);
+ if (tqtCC == TQStyle::CC_TitleBar) {
+ // TQt3 is expecting to see a rect() from the titlebar that excludes the window frame,
+ // while Qt4 provides the entire rectangle (including the frame) via the widget/QStyleOptionTitleBar
+ // This is due to the fact that under TQt3 the titlebar is a correctly position widget,
+ // whereas under Qt4 the titlebar is part of the base widget itself.
+ // Compensate...
+ if (interfaceWidget) {
+ TQRect tbg = interfaceWidget->geometry();
+ tqtPainter.translate(tbg.x(), tbg.y());
+ }
+ }
+
// Instruct TQt3 to draw the complex control
- tqApp->style().drawComplexControl(tqtCC, &tqtPainter, interfaceWidget, TQRect(opt->rect.x(), opt->rect.y(), opt->rect.width(), opt->rect.height()), tqt3colorgroup, sflags, subControl, subControlActive, tqt3opt);
+ tqApp->style().drawComplexControl(tqtCC, &tqtPainter, interfaceWidget, tqt3rect, tqt3colorgroup, sflags, subControl, subControlActive, tqt3opt);
tqtPainter.end();
@@ -1356,7 +1689,7 @@ void SimpleStyle::drawControl(ControlElement element, const QStyleOption *opt, Q
// Qt4 makes this really, really hard...
// I have to guess based on the Qt4 position of the tab in the tab bar, which may or may not work 100% in all cases
drawingTab = 0;
- estimated_tab_index = static_cast<const QTabBar*>(w)->tabAt(QPoint(opt->rect.x(), opt->rect.y()));
+ estimated_tab_index = dynamic_cast<const QTabBar*>(w)->tabAt(QPoint(opt->rect.x(), opt->rect.y()));
drawingTab = m_tqt3tabbar_widget->tabAt(estimated_tab_index);
if (drawingTab) {
@@ -1375,6 +1708,13 @@ void SimpleStyle::drawControl(ControlElement element, const QStyleOption *opt, Q
if (tqt3tabwidth > 0) {
tqt3elementrect = TQRect(tqt3elementrect.x()-tqt3tabwidth, tqt3elementrect.y(), tqt3elementrect.width()+(tqt3tabwidth*1), tqt3elementrect.height());
}
+ if (drawingTab) {
+ if (drawingTab->identifier() == 0) {
+ // This is the first tab in the tab bar
+ // We will end up clipping on the left edge if the rectangle is not adjusted
+ tqt3elementrect = TQRect(tqt3elementrect.x()+tqt3tabwidth, tqt3elementrect.y(), tqt3elementrect.width()-(tqt3tabwidth*1), tqt3elementrect.height());
+ }
+ }
}
break;
#if 0
@@ -1403,8 +1743,8 @@ void SimpleStyle::drawControl(ControlElement element, const QStyleOption *opt, Q
// Qt4 makes this really, really hard...
// I have to guess based on the Qt4 position of the item in the menu, which may or may not work 100% in all cases
drawingItem = 0;
- drawingAction = static_cast<const QMenu*>(w)->actionAt(QPoint(opt->rect.x(), opt->rect.y()));
- qt4menuactions = static_cast<const QMenu*>(w)->actions();
+ drawingAction = dynamic_cast<const QMenu*>(w)->actionAt(QPoint(opt->rect.x(), opt->rect.y()));
+ qt4menuactions = dynamic_cast<const QMenu*>(w)->actions();
for (i=0; i<qt4menuactions.size();++i) {
if (qt4menuactions.at(i) == drawingAction) {
drawingItem = m_tqt3popupmenu_widget->findItem(m_tqt3popupmenu_widget->idAt(i));
@@ -1418,10 +1758,74 @@ void SimpleStyle::drawControl(ControlElement element, const QStyleOption *opt, Q
}
}
break;
+ case QStyle::CE_MenuBarItem:
+ tqtCE = TQStyle::CE_MenuBarItem;
+ sflags = convertQt4ToTQt3SFlags(opt->state, TQT3WT_TQMenuBar);
+ interfaceWidget = initializeInterfaceWidget(TQT3WT_TQMenuBar, w);
+ if (interfaceWidget == 0) {
+ can_override = false;
+ }
+ else {
+ // Convert the QStyleOption to the proper TQStyleOption
+ // In other words, figure out which TQt3 menu item is currently being drawn
+ // Qt4 makes this really, really hard...
+ // I have to guess based on the Qt4 position of the item in the menu, which may or may not work 100% in all cases
+ drawingItem = 0;
+ drawingAction = dynamic_cast<const QMenuBar*>(w)->actionAt(QPoint(opt->rect.x(), opt->rect.y()));
+ qt4menuactions = dynamic_cast<const QMenuBar*>(w)->actions();
+ for (i=0; i<qt4menuactions.size();++i) {
+ if (qt4menuactions.at(i) == drawingAction) {
+ drawingItem = m_tqt3menubar_widget->findItem(m_tqt3menubar_widget->idAt(i));
+ }
+ }
+
+ if (drawingItem) {
+ tqt3opt = TQStyleOption(drawingItem);
+ }
+ }
+ break;
+ case QStyle::CE_MenuBarEmptyArea:
+ tqtCE = TQStyle::CE_MenuBarEmptyArea;
+ break;
+ case QStyle::CE_MenuEmptyArea:
+ tqtCE = TQStyle::CE_MenuBarEmptyArea;
+ break;
+ case QStyle::CE_ShapedFrame:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
case QStyle::CE_TabBarTabShape:
// Ignore request as Qt3 has no equivalent
can_override = false;
break;
+ case QStyle::CE_ScrollBarAddLine:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
+ case QStyle::CE_ScrollBarSubLine:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
+ case QStyle::CE_ScrollBarAddPage:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
+ case QStyle::CE_ScrollBarSubPage:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
+ case QStyle::CE_ScrollBarSlider:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
+ case QStyle::CE_ScrollBarFirst:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
+ case QStyle::CE_ScrollBarLast:
+ // Ignore request as Qt3 has no equivalent
+ can_override = false;
+ break;
default:
#ifdef DEBUG_WARNINGS
printf("No rules to draw Qt4 control %d\n\r", element); fflush(stdout);
@@ -1435,6 +1839,12 @@ void SimpleStyle::drawControl(ControlElement element, const QStyleOption *opt, Q
TQPainter tqtPainter(&qt4pd);
+ if (element == QStyle::CE_TabBarTab) {
+ // CE_TabBarTab doesn't draw the base panel of the tab
+ tqt3tabwidth = tqApp->style().pixelMetric(TQStyle::PM_TabBarTabOverlap, interfaceWidget);
+ tqtPainter.fillRect(TQRect(tqt3elementrect.x()+tqt3tabwidth, tqt3elementrect.y(), tqt3elementrect.width()-(tqt3tabwidth*2), tqt3elementrect.height()), tqt3colorgroup.background());
+ }
+
// Instruct TQt3 to draw the control
// FIXME
// Implement sflags and QStyleOption
@@ -1460,8 +1870,6 @@ void SimpleStyle::drawControl(ControlElement element, const QStyleOption *opt, Q
}
}
-#define NO_QT3_EQUIVALENT can_override = false;
-
void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QPainter *p, const QWidget *w) const
{
// Construct a Qt3 paint device translator on the Qt4 painter
@@ -1470,7 +1878,10 @@ void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QP
// Open a painter on the paint device translator
TQPainter tqtPainter(&qt4pd);
+ TQRect tqt3paintrect = TQRect(opt->rect.x(), opt->rect.y(), opt->rect.width(), opt->rect.height());
+
bool can_override = true;
+ bool do_not_draw = false;
TQStyle::PrimitiveElement tqtPE;
TQStyleOption tqt3opt(TQStyleOption::Default);
@@ -1485,9 +1896,26 @@ void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QP
tqtPE = TQStyle::PE_PanelPopup;
tqt3opt = TQStyleOption(static_cast<const QStyleOptionFrame*>(opt)->lineWidth, static_cast<const QStyleOptionFrame*>(opt)->midLineWidth);
break;
+ case QStyle::PE_PanelMenuBar:
+ tqtPE = TQStyle::PE_PanelMenuBar;
+ tqt3opt = TQStyleOption(static_cast<const QStyleOptionFrame*>(opt)->lineWidth, static_cast<const QStyleOptionFrame*>(opt)->midLineWidth);
+ break;
+ case QStyle::PE_PanelMenu:
+ tqtPE = TQStyle::PE_PanelPopup;
+ tqt3opt = TQStyleOption(static_cast<const QStyleOptionFrame*>(opt)->lineWidth, static_cast<const QStyleOptionFrame*>(opt)->midLineWidth);
+ break;
case QStyle::PE_PanelButtonBevel:
tqtPE = TQStyle::PE_ButtonBevel;
break;
+ case QStyle::PE_FrameLineEdit:
+ tqtPE = TQStyle::PE_PanelLineEdit;
+ break;
+ case QStyle::PE_PanelStatusBar:
+ tqtPE = TQStyle::PE_Panel;
+ break;
+ case QStyle::PE_PanelButtonTool:
+ tqtPE = TQStyle::PE_ButtonTool;
+ break;
case QStyle::PE_FrameGroupBox:
tqtPE = TQStyle::PE_GroupBoxFrame;
tqt3opt = TQStyleOption(static_cast<const QStyleOptionFrame*>(opt)->lineWidth, static_cast<const QStyleOptionFrame*>(opt)->midLineWidth);
@@ -1503,6 +1931,15 @@ void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QP
break;
case QStyle::PE_FrameTabWidget:
tqtPE = TQStyle::PE_PanelTabWidget;
+ // HACK
+ // For an unknown reason Qt4 paints the tab border 2 pixels lower and shorter than it should
+ // FIXME
+ // Figure out why that happens!
+ tqt3paintrect = TQRect(tqt3paintrect.x(), tqt3paintrect.y()-2, tqt3paintrect.width(), tqt3paintrect.height()+2);
+ p->setClipRect(QRect(tqt3paintrect.x(), tqt3paintrect.y(), tqt3paintrect.width(), tqt3paintrect.height()));
+ break;
+ case QStyle::PE_FrameDefaultButton:
+ tqtPE = TQStyle::PE_ButtonDefault;
break;
case QStyle::PE_PanelButtonCommand:
tqtPE = TQStyle::PE_ButtonCommand;
@@ -1528,15 +1965,34 @@ void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QP
case QStyle::PE_IndicatorRadioButton:
tqtPE = TQStyle::PE_ExclusiveIndicator;
break;
- case QStyle::PE_PanelMenu:
- tqtPE = TQStyle::PE_PanelPopup;
+ case QStyle::PE_IndicatorSpinDown:
+ tqtPE = TQStyle::PE_SpinWidgetDown;
break;
- case QStyle::PE_PanelButtonTool:
- tqtPE = TQStyle::PE_ButtonTool;
+ case QStyle::PE_IndicatorSpinUp:
+ tqtPE = TQStyle::PE_SpinWidgetUp;
+ break;
+ case QStyle::PE_IndicatorSpinPlus:
+ tqtPE = TQStyle::PE_SpinWidgetPlus;
+ break;
+ case QStyle::PE_IndicatorSpinMinus:
+ tqtPE = TQStyle::PE_SpinWidgetMinus;
+ break;
+ case QStyle::PE_FrameWindow:
+ tqtPE = TQStyle::PE_WindowFrame;
break;
case QStyle::PE_IndicatorTabTear:
NO_QT3_EQUIVALENT
break;
+ case QStyle::PE_FrameStatusBarItem:
+ NO_QT3_EQUIVALENT
+ break;
+ case QStyle::PE_PanelLineEdit:
+ NO_QT3_EQUIVALENT
+ break;
+ // Qt3 support elements
+ case QStyle::PE_Q3Separator:
+ tqtPE = TQStyle::PE_Separator;
+ break;
default:
#ifdef DEBUG_WARNINGS
printf("No rules to draw Qt4 element %d\n\r", pe); fflush(stdout);
@@ -1570,7 +2026,7 @@ void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QP
TQPainter tqtPainter(&qt4pd);
// Instruct TQt3 to draw the primitive
- tqApp->style().drawPrimitive(tqtPE, &tqtPainter, TQRect(opt->rect.x(), opt->rect.y(), opt->rect.width(), opt->rect.height()), tqt3colorgroup, sflags, tqt3opt);
+ tqApp->style().drawPrimitive(tqtPE, &tqtPainter, tqt3paintrect, tqt3colorgroup, sflags, tqt3opt);
tqtPainter.end();
#ifdef DEBUG_WARNINGS
@@ -1580,7 +2036,9 @@ void SimpleStyle::drawPrimitive(PrimitiveElement pe, const QStyleOption *opt, QP
#endif
}
else {
- // Tell Qt4 to draw it
- QCommonStyle::drawPrimitive(pe, opt, p, w);
+ if (do_not_draw == false) {
+ // Tell Qt4 to draw it
+ QCommonStyle::drawPrimitive(pe, opt, p, w);
+ }
}
}