Fix crashes when used with third party toolkit

pull/1/head
Timothy Pearson 12 years ago
parent 8bf50f1d81
commit b2be7bd4d6

@ -1088,9 +1088,8 @@ void dotNETstyle::drawControl(TQ_ControlElement element,
} }
case CE_PushButton: { case CE_PushButton: {
TQPushButton *button = (TQPushButton *)widget;
TQRect br = r; TQRect br = r;
bool btnDefault = button->isDefault(); bool btnDefault = (elementFlags & CEF_IsDefault);
static int di = pixelMetric(PM_ButtonDefaultIndicator, ceData, elementFlags); static int di = pixelMetric(PM_ButtonDefaultIndicator, ceData, elementFlags);
br.addCoords(di, di, -di, -di); br.addCoords(di, di, -di, -di);
@ -1581,8 +1580,6 @@ void dotNETstyle::drawComplexControl(ComplexControl control,
// TOOLBUTTON // TOOLBUTTON
// ---------- // ----------
case CC_ToolButton: { case CC_ToolButton: {
const TQToolButton *tb = (const TQToolButton *) widget;
TQRect button, menuarea; TQRect button, menuarea;
button = querySubControlMetrics(control, ceData, elementFlags, SC_ToolButton, opt, widget); button = querySubControlMetrics(control, ceData, elementFlags, SC_ToolButton, opt, widget);
menuarea = querySubControlMetrics(control, ceData, elementFlags, SC_ToolButtonMenu, opt, widget); menuarea = querySubControlMetrics(control, ceData, elementFlags, SC_ToolButtonMenu, opt, widget);
@ -1600,11 +1597,9 @@ void dotNETstyle::drawComplexControl(ComplexControl control,
// If we're pressed, on, or raised... // If we're pressed, on, or raised...
if (bflags & (Style_Down | Style_On | Style_Raised)) { if (bflags & (Style_Down | Style_On | Style_Raised)) {
drawPrimitive(PE_ButtonTool, p, ceData, elementFlags, button, cg, bflags, opt); drawPrimitive(PE_ButtonTool, p, ceData, elementFlags, button, cg, bflags, opt);
} else if (tb->parentWidget() && } else if (!ceData.parentWidgetData.bgPixmap.isNull()) {
tb->parentWidget()->backgroundPixmap() && TQPixmap pixmap = ceData.parentWidgetData.bgPixmap;
!tb->parentWidget()->backgroundPixmap()->isNull()) { p->drawTiledPixmap( r, pixmap, ceData.pos );
TQPixmap pixmap = *(tb->parentWidget()->backgroundPixmap());
p->drawTiledPixmap( r, pixmap, tb->pos() );
} }
} }
@ -1616,8 +1611,8 @@ void dotNETstyle::drawComplexControl(ComplexControl control,
drawPrimitive(PE_ArrowDown, p, ceData, elementFlags, menuarea, cg, mflags, opt); drawPrimitive(PE_ArrowDown, p, ceData, elementFlags, menuarea, cg, mflags, opt);
} }
if (tb->hasFocus() && !tb->focusProxy()) { if ((elementFlags & CEF_HasFocus) && !(elementFlags & CEF_HasFocusProxy)) {
TQRect fr = tb->rect(); TQRect fr = ceData.rect;
fr.addCoords(2, 2, -2, -2); fr.addCoords(2, 2, -2, -2);
drawPrimitive(PE_FocusRect, p, ceData, elementFlags, fr, cg); drawPrimitive(PE_FocusRect, p, ceData, elementFlags, fr, cg);
} }

@ -1643,13 +1643,6 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
switch (control) { switch (control) {
case CC_ComboBox: { case CC_ComboBox: {
const TQComboBox * combo = ::tqqt_cast<const TQComboBox*>(widget);
if (!combo) {
KStyle::drawComplexControl(control, painter, ceData, elementFlags, rect, group,
flags, controls, active, option, widget);
return;
}
sunken = (active == SC_ComboBoxArrow); sunken = (active == SC_ComboBoxArrow);
drawPhaseButton(painter, x, y, w, h, group, drawPhaseButton(painter, x, y, w, h, group,
(flags & Style_MouseOver) (flags & Style_MouseOver)
@ -1669,7 +1662,7 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
} }
if (controls & SC_ComboBoxEditField) { // draw edit box if (controls & SC_ComboBoxEditField) { // draw edit box
if (combo->editable()) { // editable box if (elementFlags & CEF_IsEditable) { // editable box
subrect = visualRect(querySubControlMetrics(CC_ComboBox, subrect = visualRect(querySubControlMetrics(CC_ComboBox,
ceData, elementFlags, SC_ComboBoxEditField, TQStyleOption::Default, widget), ceData, elementFlags); ceData, elementFlags, SC_ComboBoxEditField, TQStyleOption::Default, widget), ceData, elementFlags);
x2 = subrect.right(); y2 = subrect.bottom(); x2 = subrect.right(); y2 = subrect.bottom();
@ -1679,9 +1672,9 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
painter->drawLine(x2+2, y, x2+2, y2-1); painter->drawLine(x2+2, y, x2+2, y2-1);
painter->setPen(group.button()); painter->setPen(group.button());
painter->drawPoint(x2+2, y2); painter->drawPoint(x2+2, y2);
} else if (combo->hasFocus()) { // non editable box } else if (elementFlags & CEF_HasFocus) { // non editable box
subrect = visualRect(subRect(SR_ComboBoxFocusRect, ceData, elementFlags, subrect = visualRect(subRect(SR_ComboBoxFocusRect, ceData, elementFlags,
combo), ceData, elementFlags); widget), ceData, elementFlags);
drawPrimitive(PE_FocusRect, painter, ceData, elementFlags, subrect, group, drawPrimitive(PE_FocusRect, painter, ceData, elementFlags, subrect, group,
Style_FocusAtBorder, Style_FocusAtBorder,
TQStyleOption(group.highlight())); TQStyleOption(group.highlight()));
@ -1694,18 +1687,11 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
case CC_ScrollBar: { case CC_ScrollBar: {
// always a three button scrollbar // always a three button scrollbar
const TQScrollBar *sb = ::tqqt_cast<const TQScrollBar*>(widget);
if (!sb) {
KStyle::drawComplexControl(control, painter, ceData, elementFlags, rect, group,
flags, controls, active, option, widget);
return;
}
TQRect srect; TQRect srect;
bool horizontal = (sb->orientation() == Qt::Horizontal); bool horizontal = (ceData.orientation == TQt::Horizontal);
SFlags scrollflags = (horizontal ? Style_Horizontal : Style_Default); SFlags scrollflags = (horizontal ? Style_Horizontal : Style_Default);
if (sb->minValue() == sb->maxValue()) scrollflags |= Style_Default; if (ceData.minSteps == ceData.maxSteps) scrollflags |= Style_Default;
else scrollflags |= Style_Enabled; else scrollflags |= Style_Enabled;
// addline // addline
@ -1765,7 +1751,7 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
// slider // slider
if (controls & SC_ScrollBarSlider) { if (controls & SC_ScrollBarSlider) {
if (sb->minValue() == sb->maxValue()) { if (ceData.minSteps == ceData.maxSteps) {
// maxed out // maxed out
srect = querySubControlMetrics(control, ceData, elementFlags, srect = querySubControlMetrics(control, ceData, elementFlags,
SC_ScrollBarGroove, option, widget); SC_ScrollBarGroove, option, widget);
@ -1780,7 +1766,7 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
scrollflags | ((active == SC_ScrollBarSlider) scrollflags | ((active == SC_ScrollBarSlider)
? Style_Down : Style_Default)); ? Style_Down : Style_Default));
// focus // focus
if (sb->hasFocus()) { if (elementFlags & CEF_HasFocus) {
srect.addCoords(2, 2, -2, -2); srect.addCoords(2, 2, -2, -2);
drawPrimitive(PE_FocusRect, painter, ceData, elementFlags, srect, group, drawPrimitive(PE_FocusRect, painter, ceData, elementFlags, srect, group,
Style_Default); Style_Default);
@ -1852,11 +1838,6 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
case CC_ToolButton: { case CC_ToolButton: {
const TQToolButton *btn = ::tqqt_cast<const TQToolButton*>(widget); const TQToolButton *btn = ::tqqt_cast<const TQToolButton*>(widget);
if (!btn) {
KStyle::drawComplexControl(control, painter, ceData, elementFlags, rect, group,
flags, controls, active, option, widget);
return;
}
TQToolBar *toolbar; TQToolBar *toolbar;
bool horiz = true; bool horiz = true;
@ -1866,19 +1847,18 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
y2 = rect.bottom(); y2 = rect.bottom();
// check for TQToolBar parent // check for TQToolBar parent
if (btn->parent() && btn->parent()->inherits(TQTOOLBAR_OBJECT_NAME_STRING)) { if (ceData.parentWidgetData.widgetObjectTypes.contains(TQTOOLBAR_OBJECT_NAME_STRING)) {
toolbar = ::tqqt_cast<TQToolBar*>(btn->parent()); toolbar = (btn)?::tqqt_cast<TQToolBar*>(btn->parent()):NULL;
if (toolbar) { horiz = (ceData.toolBarData.orientation == TQt::Horizontal);
horiz = (toolbar->orientation() == Qt::Horizontal);
if (normal) { // draw background if (normal) { // draw background
if (flatToolbar(ceData, elementFlags, toolbar)) { if (toolbar && flatToolbar(ceData, elementFlags, toolbar)) {
// toolbar not floating or in a TQMainWindow // toolbar not floating or in a TQMainWindow
painter->fillRect(rect, group.background()); painter->fillRect(rect, group.background());
} else { } else {
drawPhaseGradient(painter, rect, group.background(), drawPhaseGradient(painter, rect, group.background(),
!horiz, 0, 0, !horiz, 0, 0,
toolbar->width()-3, ceData.parentWidgetData.rect.width()-3,
toolbar->height()-3, true); ceData.parentWidgetData.rect.height()-3, true);
painter->setPen(group.mid()); painter->setPen(group.mid());
if (horiz) { if (horiz) {
painter->drawLine(x, y2, x2, y2); painter->drawLine(x, y2, x2, y2);
@ -1888,10 +1868,8 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
} }
} }
} }
}
// check for TQToolBarExtensionWidget parent // check for TQToolBarExtensionWidget parent
else if (btn->parent() && else if (btn && ceData.parentWidgetData.widgetObjectTypes.contains(TQTOOLBAREXTENSION)) {
btn->parent()->inherits(TQTOOLBAREXTENSION)) {
TQWidget *extension; TQWidget *extension;
if ((extension = ::tqqt_cast<TQWidget*>(btn->parent()))) { if ((extension = ::tqqt_cast<TQWidget*>(btn->parent()))) {
toolbar = ::tqqt_cast<TQToolBar*>(extension->parent()); toolbar = ::tqqt_cast<TQToolBar*>(extension->parent());
@ -1906,11 +1884,10 @@ void PhaseStyle::drawComplexControl(TQ_ComplexControl control,
} }
} }
// check for background pixmap // check for background pixmap
else if (normal && btn->parentWidget() && else if (normal &&
btn->parentWidget()->backgroundPixmap() && !ceData.parentWidgetData.bgPixmap.isNull()) {
!btn->parentWidget()->backgroundPixmap()->isNull()) { TQPixmap pixmap = ceData.parentWidgetData.bgPixmap;
TQPixmap pixmap = *(btn->parentWidget()->backgroundPixmap()); painter->drawTiledPixmap(rect, pixmap, ceData.pos);
painter->drawTiledPixmap(rect, pixmap, btn->pos());
} }
// everything else // everything else
else if (normal) { else if (normal) {

Loading…
Cancel
Save