diff -r ce961d2c008b -r 6745d806c5ff qhbstyle/qhbstyle.cpp --- a/qhbstyle/qhbstyle.cpp Mon Jun 21 22:38:54 2010 +0100 +++ b/qhbstyle/qhbstyle.cpp Thu Jul 22 16:42:52 2010 +0100 @@ -28,15 +28,12 @@ //Qt widgets #include #include -#include #include #include #include #include #include -#include #include -#include #include #include #include @@ -66,22 +63,23 @@ QT_BEGIN_NAMESPACE -QHbStylePrivate::QHbStylePrivate() +QHbStylePrivate::QHbStylePrivate() : m_styleManager(0), + m_frameDrawer(0), + m_animationGroup(0) { - m_frameDrawer = 0; - m_styleManager = 0; - - m_animationGroup = q_check_ptr(new QParallelAnimationGroup()); } QHbStylePrivate::~QHbStylePrivate() { - delete m_frameDrawer; - delete m_animationGroup; } HbStyle* QHbStylePrivate::styleManager() { + if (!m_styleManager) { + HbInstance *instance = HbInstance::instance(); + setStyleManager(instance->style()); + } + return m_styleManager; } @@ -93,7 +91,9 @@ QParallelAnimationGroup* QHbStylePrivate::animationGroup() { - return m_animationGroup; + if (m_animationGroup.isNull()) + m_animationGroup.reset(new QParallelAnimationGroup()); + return m_animationGroup.data(); } /*! @@ -102,9 +102,6 @@ QHbStyle::QHbStyle() : QCommonStyle() { m_private = new QHbStylePrivate(); - HbInstance *instance = HbInstance::instance(); - - m_private->setStyleManager(instance->style()); } /*! @@ -158,12 +155,11 @@ state |= SS_Focused; if (vopt->state & State_Sunken || vopt->state & State_Raised) state |= SS_Pressed; -#ifndef QT_NO_TREEVIEW - if (qobject_cast(widget)) { - if (option->state & State_Children) { - m_private->drawMultiPartItem(SM_ListParent, painter, vopt->rect, state); - break; - } + +#ifndef QT_NO_TABLEVIEW + if (qobject_cast(widget)) { + m_private->drawMultiPartItem(SM_TableItem, painter, vopt->rect, state); + break; } #endif if (vopt->features & QStyleOptionViewItemV2::Alternate) @@ -219,7 +215,7 @@ #ifndef QT_NO_LINEEDIT case PE_PanelLineEdit: { #ifndef QT_NO_COMBOBOX - if (widget && qobject_cast(widget->parentWidget())) + if ( (widget && qobject_cast(widget->parentWidget()) ) && (!widget->hasFocus())) break; #endif #ifndef QT_NO_SPINBOX @@ -280,16 +276,17 @@ if (const QStyleOptionFocusRect *highlight = qstyleoption_cast(option)) { if (false #ifndef QT_NO_LISTVIEW - || qobject_cast(widget) + || qobject_cast(widget) #endif #ifndef QT_NO_TABLEVIEW - || qobject_cast(widget) + || qobject_cast(widget) #endif #ifndef QT_NO_TREEVIEW - || qobject_cast(widget) + || qobject_cast(widget) #endif ) - m_private->drawMultiPartItem(SM_ItemViewHighlight, painter, highlight->rect); + if (option->state & State_HasFocus) + m_private->drawMultiPartItem(SM_ItemViewItem, painter, highlight->rect, SS_Focused); } break; } @@ -373,13 +370,16 @@ break; } case CE_ItemViewItem: { + //@todo: headerviews and listviews should show selection tick at the beginning of the row (in place of checkbox rect) + //@todo: headerview should select also parent when child is selected + //@todo: headerview should draw highlight rect if (const QStyleOptionViewItemV4 *itemOption = qstyleoption_cast(option)) { const QRect checkRect = subElementRect(SE_ItemViewItemCheckIndicator, itemOption, widget); const QRect iconRect = subElementRect(SE_ItemViewItemDecoration, itemOption, widget); QRect textRect = subElementRect(SE_ItemViewItemText, itemOption, widget); //background for list items (other itemviews use PE_PanelItemViewRow drawing) - if (qobject_cast(widget)) + if (qobject_cast(widget)) proxy()->drawPrimitive(PE_PanelItemViewItem, itemOption, painter, widget); //checkbox @@ -393,7 +393,7 @@ //selection indication if (itemOption->state & State_Selected) { const QAbstractItemView *itemView = qobject_cast(widget); - if (itemView->selectionMode() != QAbstractItemView::SingleSelection) { + if (itemView->selectionMode() != QAbstractItemView::NoSelection) { QStyleOptionViewItemV4 selectOption; selectOption.QStyleOption::operator=(*itemOption); int iconSize = 0; @@ -881,7 +881,43 @@ case CC_ComboBox: { if (const QStyleOptionComboBox *cmb = qstyleoption_cast(option)) { const QRect cmbxFrame = cmb->rect; - ItemStates state = SS_Active; + + const bool isDisabled = !(cmb->state & State_Enabled); + ItemStates state = (isDisabled) ? SS_Disabled : SS_Active; + + if (cmb->state & State_Active && + cmb->state & State_Enabled && + !cmb->state & State_HasFocus && + !cmb->state & State_MouseOver && + !cmb->state & State_Selected) { + state |= SS_Active; + } + if (cmb->state & State_Active && + cmb->state & State_Enabled && + cmb->state & State_On && + !cmb->state & State_HasFocus && + !cmb->state & State_MouseOver && + !cmb->state & State_Selected) { + state |= SS_Active; + } + else if (cmb->state & State_Active && + cmb->state & State_Enabled && + cmb->state & State_HasFocus && + cmb->state & State_MouseOver && + cmb->state & State_Selected) { + state |= SS_Pressed; + } + else if (cmb->state & State_Active && + cmb->state & State_Enabled && + cmb->state & State_HasFocus && + cmb->state & State_MouseOver) { + state |= SS_Pressed; + } + /* else if (cmb->state & State_Active && + cmb->state & State_Enabled && + cmb->state & State_Sunken) { + state |= SS_Pressed; + }*/ // Button frame QStyleOptionFrame buttonOption; @@ -891,42 +927,24 @@ const int topLeftPoint = (cmb->direction == Qt::LeftToRight) ? (cmbxFrame.width() - buttonMaxWidth) : 0; const QRect buttonRect(topLeftPoint, cmbxFrame.top(), buttonMaxHeight, buttonMaxWidth); - buttonOption.rect = buttonRect; - buttonOption.state = cmb->state; - ItemStates buttonState = (buttonOption.state & State_Sunken) ? ItemStates(SS_Pressed | SS_Active) : ItemStates(SS_Active); - if (cmb->direction == Qt::RightToLeft) - buttonState |= SS_Mirrored; - if (buttonOption.state & State_HasFocus) { - buttonState |= SS_Selected; - state |= SS_Selected; //set frame status to follow button status for highlight + if (cmb->direction == Qt::RightToLeft){ + + state |= SS_Mirrored; } - m_private->drawItem(SP_BoxButton, painter, buttonRect.adjusted(0, 1, 0, -1), buttonState); //@todo: remove magic - if (cmb->subControls & SC_ComboBoxFrame) { - const bool isDisabled = !(cmb->state & State_Enabled); - const bool isPressed = (cmb->state & State_Sunken); - const bool isEditable = cmb->editable; - if (isDisabled) - state = SS_Disabled; - else if (isPressed) - state |= SS_Pressed; - if (isEditable) - state |= SS_Edited; QRect frameRect = QRect(cmb->rect); int frameWidth = pixelMetric(PM_DefaultFrameWidth); int maxRight = cmb->rect.height() - 2 * frameWidth; frameRect.adjust(0, 0, -maxRight, 0); - int adjustX = 0; - if (option->direction == Qt::RightToLeft) { - adjustX = buttonOption.rect.topRight().x(); - state |= SS_Mirrored; - } + const QRect frame = subControlRect(CC_ComboBox, option, SC_ComboBoxFrame, widget); - // @todo: if SC_ComboBoxFrame needs adjusting, move that code to subControlRect - m_private->drawMultiPartItem(SM_BoxFrame, painter, frame.adjusted(adjustX, 1, -4 + adjustX, -1), state); + //Draw the frame + m_private->drawMultiPartItem(SM_BoxFrame, painter, frame, state); } + //Draw the dropdown button + m_private->drawItem(SP_BoxButton, painter, buttonRect, state); //@todo: remove magic } break; } @@ -1008,32 +1026,75 @@ v = nextInterval; } } - QRect filledRect; - if ( horizontal ){ - const int sliderPosition = sliderHandle.center().x(); - const int sliderWidth = sliderHandle.width()/2; + + QRect filledRect; + QRect filledRectMask; + if ( horizontal ){ + if (slider && (slider->layoutDirection() == Qt::LeftToRight) ^ slider->invertedAppearance()){ + filledRect = QRect( sliderGroove.x(), + sliderGroove.y(), + qMax(sliderGroove.width()-sliderHandle.right(), sliderHandle.right()), + sliderGroove.height()); + + int x = qMin(sliderHandle.left(), sliderGroove.x() + sliderGroove.width()-sliderHandle.right()); + filledRectMask = QRect(x, + sliderGroove.y(), + sliderGroove.width()-x, + sliderGroove.height()); + } else { + filledRect = QRect( qMin(sliderGroove.width()-sliderHandle.left(),sliderHandle.left()), + sliderGroove.y(), + qMax(sliderGroove.width()-sliderHandle.left(), sliderHandle.left()), + sliderGroove.height()); + + filledRectMask = QRect( sliderGroove.x(), + sliderGroove.y(), + qMax(sliderGroove.width()-sliderHandle.right(), sliderHandle.right()), + sliderGroove.height()); + + } + } else { if (slider && (slider->layoutDirection() == Qt::LeftToRight) ^ slider->invertedAppearance()){ - filledRect = QRect(sliderGroove.x(), sliderGroove.y(), sliderPosition+sliderWidth, sliderGroove.height()); - } else { - filledRect = QRect(sliderGroove.x()+sliderPosition-sliderWidth, sliderGroove.y(), sliderGroove.width()-sliderPosition+sliderWidth, sliderGroove.height()); - } - } else { - const int sliderPosition = sliderHandle.center().y(); - const int sliderHeight = sliderHandle.height()/2; - if (slider && (slider->layoutDirection() == Qt::LeftToRight) ^ slider->invertedAppearance()){ - filledRect = QRect(sliderGroove.x(), sliderGroove.y()+sliderPosition-sliderHeight, sliderGroove.width(), sliderGroove.height()-sliderPosition+sliderHeight); - } else { - filledRect = QRect(sliderGroove.x(), sliderGroove.y(), sliderGroove.width(), sliderPosition+sliderHeight); - } - } + filledRect = QRect(sliderGroove.x(), + qMin(sliderGroove.height()-sliderHandle.top(), sliderHandle.top()), + sliderGroove.width(), + qMax(sliderGroove.height()-sliderHandle.top(), sliderHandle.top())); + + filledRectMask = QRect(sliderGroove.x(), + sliderGroove.y(), + sliderGroove.width(), + qMax(sliderGroove.height()-sliderHandle.bottom(), sliderHandle.bottom())); + } else { + filledRect = QRect(sliderGroove.x(), + sliderGroove.y(), + sliderGroove.width(), + qMax(sliderGroove.height()-sliderHandle.bottom(),sliderHandle.bottom())); - //Groove - m_private->drawMultiPartItem(SM_SliderGroove, painter, sliderGroove, grooveState); + int y = qMin(sliderHandle.top(), sliderGroove.y() + sliderGroove.height()-sliderHandle.bottom()); + filledRectMask = QRect( sliderGroove.x(), + y, + sliderGroove.width(), + sliderGroove.height()-y ); + } + } + + if (filledRect.width() < filledRectMask.width() || filledRect.height() < filledRectMask.height()){ + // Progress + groove + m_private->drawMultiPartItem(SM_SliderGroove, painter, filledRect, grooveState ); + m_private->drawMultiPartItem(SM_SliderProgress, painter, filledRect, grooveState | SS_Filled); - //Progress - m_private->drawMultiPartItem(SM_SliderProgress, painter, filledRect, grooveState | SS_Filled); + // Groove + m_private->drawMultiPartItem(SM_SliderGroove, painter, filledRectMask, grooveState); + } else { + // Groove + m_private->drawMultiPartItem(SM_SliderGroove, painter, filledRectMask, grooveState); - //handle + // Progess + groove + m_private->drawMultiPartItem(SM_SliderGroove, painter, filledRect, grooveState ); + m_private->drawMultiPartItem(SM_SliderProgress, painter, filledRect, grooveState | SS_Filled); + } + + //handle m_private->drawItem(SP_SliderHandle, painter, sliderHandle, handleState); } break; @@ -1194,28 +1255,29 @@ const QRect spinboxButtonDownRect = subControlRect(control, optionSpinbox, SC_SpinBoxDown, widget); const QRect spinboxEditorRect = subControlRect(control, optionSpinbox, SC_SpinBoxEditField, widget); - QStyleOptionSpinBox copy = *optionSpinbox; - //Frame & background const bool isDisabled = !(optionSpinbox->state & State_Enabled); ItemStates state = (isDisabled) ? SS_Disabled : SS_Active; if (optionSpinbox->state & State_HasFocus) state |= SS_Selected; - m_private->drawMultiPartItem(SM_BoxFrame, painter, spinboxEditorRect, state); + //Draw the rounded border of edit field frame under button, half spin button width + //Label drawn to spinboxEditorRect + m_private->drawMultiPartItem(SM_BoxFrame, painter, spinboxEditorRect.adjusted((-0.5*spinboxButtonDownRect.width()),0,0,0), state); + + QStyle::State buttonState; //Buttons if (optionSpinbox->subControls & SC_SpinBoxUp) { - copy.subControls = SC_SpinBoxUp; if (!(optionSpinbox->stepEnabled & QAbstractSpinBox::StepUpEnabled)) - copy.state &= ~State_Enabled; + buttonState &= ~State_Enabled; if (optionSpinbox->activeSubControls == SC_SpinBoxUp && (optionSpinbox->state & State_Sunken)) { - copy.state |= State_On; - copy.state |= State_Sunken; + buttonState |= State_On; + buttonState |= State_Sunken; } else { - copy.state |= State_Raised; - copy.state &= ~State_Sunken; + buttonState |= State_Raised; + buttonState &= ~State_Sunken; } - const bool isPressed = (copy.state & State_Sunken); + const bool isPressed = (buttonState & State_Sunken); ItemStates upButtonState = (isPressed) ? ItemStates(SS_Pressed | SS_Active) : ItemStates(SS_Active); if (optionSpinbox->direction == Qt::RightToLeft) upButtonState = upButtonState | SS_Flipped; @@ -1223,23 +1285,22 @@ upButtonState = upButtonState | SS_Flipped | SS_Mirrored; if (optionSpinbox->state & State_HasFocus) upButtonState |= SS_Selected; - if (!(copy.state & State_Enabled)) + if (!(optionSpinbox->stepEnabled & QAbstractSpinBox::StepUpEnabled)) upButtonState |= SS_Disabled; m_private->drawItem(SP_BoxButton, painter, spinboxButtonUpRect, upButtonState); } if (optionSpinbox->subControls & SC_SpinBoxDown) { - copy.subControls = SC_SpinBoxDown; if (!(optionSpinbox->stepEnabled & QAbstractSpinBox::StepDownEnabled)) - copy.state &= ~State_Enabled; + buttonState &= ~State_Enabled; if (optionSpinbox->activeSubControls == SC_SpinBoxDown && (optionSpinbox->state & State_Sunken)) { - copy.state |= State_On; - copy.state |= State_Sunken; + buttonState |= State_On; + buttonState |= State_Sunken; } else { - copy.state |= State_Raised; - copy.state &= ~State_Sunken; + buttonState |= State_Raised; + buttonState &= ~State_Sunken; } - const bool isPressed = (copy.state & State_Sunken); + const bool isPressed = (buttonState & State_Sunken); ItemStates downButtonState = (isPressed) ? ItemStates(SS_Pressed | SS_Active) : ItemStates(SS_Active); if (optionSpinbox->direction == Qt::RightToLeft) downButtonState = downButtonState; @@ -1247,7 +1308,7 @@ downButtonState = downButtonState | SS_Mirrored; if (optionSpinbox->state & State_HasFocus) downButtonState |= SS_Selected; - if (!(copy.state & State_Enabled)) + if (!(optionSpinbox->stepEnabled & QAbstractSpinBox::StepDownEnabled)) downButtonState |= SS_Disabled; m_private->drawItem(SP_BoxButton, painter, spinboxButtonDownRect, downButtonState); } @@ -1301,6 +1362,14 @@ const QRect baseSize = QCommonStyle::subElementRect(element, option, widget); QRect elementSize = baseSize; switch (element) { + case SE_LineEditContents: { + qreal metric = 0; + m_private->styleManager()->parameter(QLatin1String("hb-param-margin-gene-middle-horizontal"), metric); + const int metricValue = metric + 0.5; + elementSize = visualRect( + option->direction, option->rect, option->rect.adjusted(metricValue, 0, 0, 0)); + } + break; case SE_ItemViewItemText: { if (const QStyleOptionMenuItem *menuItem = qstyleoption_cast(option)) { elementSize = menuItem->rect; @@ -1316,17 +1385,27 @@ elementSize.setWidth(menuItem->rect.width() - widthMod); } else if (const QStyleOptionViewItemV4 *itemView = qstyleoption_cast(option)) { elementSize = itemView->rect; - const QRect iconRect = subElementRect(SE_ItemViewItemDecoration, option, widget); - const QRect checkBoxRect = subElementRect(SE_ViewItemCheckIndicator, option, widget); - const int indicatorSpacing = proxy()->pixelMetric(PM_LayoutHorizontalSpacing, option, widget); - int totalXMod = qMax(0, qMax((checkBoxRect.isValid() ? checkBoxRect.topRight().x() : 0), - (iconRect.isValid() ? iconRect.topRight().x() : 0))); - const int widthMod = checkBoxRect.width() + iconRect.width() + indicatorSpacing; - totalXMod = (itemView->direction == Qt::LeftToRight) ? qMax(0, totalXMod - elementSize.topLeft().x()): 0; - totalXMod += indicatorSpacing; - elementSize.translate(totalXMod, 0); - elementSize.setWidth(itemView->rect.width() - widthMod); - elementSize = visualRect(itemView->direction, itemView->rect, elementSize); + if (itemView->decorationPosition == QStyleOptionViewItem::Left || + itemView->decorationPosition == QStyleOptionViewItem::Right) { + const QRect iconRect = subElementRect(SE_ItemViewItemDecoration, option, widget); + const QRect checkBoxRect = subElementRect(SE_ViewItemCheckIndicator, option, widget); + const int indicatorSpacing = proxy()->pixelMetric(PM_LayoutHorizontalSpacing, option, widget); + int totalXMod = qMax(0, qMax((checkBoxRect.isValid() ? checkBoxRect.topRight().x() : 0), + (iconRect.isValid() ? iconRect.topRight().x() : 0))); + const int widthMod = checkBoxRect.width() + iconRect.width() + indicatorSpacing; + totalXMod = (itemView->direction == Qt::LeftToRight) ? qMax(0, totalXMod - elementSize.topLeft().x()): 0; + totalXMod += indicatorSpacing; + elementSize.translate(totalXMod, 0); + elementSize.setWidth(itemView->rect.width() - widthMod); + elementSize = visualRect(itemView->direction, itemView->rect, elementSize); + } else { + const QRect iconRect = subElementRect(SE_ItemViewItemDecoration, option, widget); + const bool decoratorOnTop = (itemView->decorationPosition == QStyleOptionViewItem::Top); + if (decoratorOnTop) + elementSize.translate(0, iconRect.height()); + else + elementSize.translate(0, -iconRect.height()); + } } break; } @@ -1423,16 +1502,28 @@ QRect frameRect = QRect(cmb->rect); int frameWidth = pixelMetric(PM_DefaultFrameWidth, cmb, widget); int maxRight = cmb->rect.height() - 2 * frameWidth; - frameRect.adjust(0, 0, -maxRight, 0); + if(cmb->direction == Qt::RightToLeft) { + frameRect.adjust(+ 0.25 * buttonWidth, 0, -0.25 * buttonWidth, 0); + }else{ + frameRect.adjust(0, 0, -maxRight-4, 0); + } elementSize = frameRect; break; } case SC_ComboBoxEditField: { - const int withFrameX = cmb->rect.x() + cmb->rect.width() - frameThickness - buttonSize.width(); + int withFrameX = 0; + int offSet = 0; + if(cmb->direction == Qt::RightToLeft) { + withFrameX = cmb->rect.x() + cmb->rect.width() - frameThickness; + offSet = buttonWidth; + } + else{ + withFrameX = cmb->rect.x() + cmb->rect.width() - frameThickness - buttonSize.width(); + } elementSize = QRect( - frameThickness, + frameThickness + offSet, frameThickness - 2, - withFrameX - frameThickness, + withFrameX - frameThickness - offSet, cmb->rect.height() - 2 * frameThickness ); break; } @@ -1648,27 +1739,32 @@ case CC_SpinBox: { if (const QStyleOptionSpinBox *spinbox = qstyleoption_cast(option)) { const int buttonIconSize = pixelMetric(PM_ButtonIconSize); - const int buttonWidth = qMax(spinbox->rect.height(), buttonIconSize); + // Spinbox buttons should be no larger than one fourth of total width. + const int maxSize = qMax(spinbox->rect.width() / 4, buttonIconSize + 4); //@magic + QSize buttonSize; + buttonSize.setHeight(qMin(maxSize, qMax(8, spinbox->rect.height()))); + buttonSize.setWidth(buttonSize.height()); //make buttons square + switch (sc) { case SC_SpinBoxFrame: - elementSize = option->rect.adjusted(0, 0, -buttonWidth + 5, 0); + elementSize = option->rect.adjusted(0, 0, -buttonSize.width() + 5, 0); //@magic break; case SC_SpinBoxDown: { if (option->direction == Qt::RightToLeft) - elementSize = QRect(option->rect.right() - buttonWidth, option->rect.y(),buttonWidth, option->rect.height()); + elementSize = QRect(option->rect.right() - buttonSize.width(), option->rect.y(), buttonSize.width(), option->rect.height()); else - elementSize = QRect( option->rect.x(), option->rect.y(), buttonWidth,option->rect.height()); + elementSize = QRect(option->rect.x(), option->rect.y(), buttonSize.width(), option->rect.height()); } break; case SC_SpinBoxUp: { if (option->direction == Qt::RightToLeft) - elementSize = QRect( option->rect.x(), option->rect.y(), buttonWidth,option->rect.height()); + elementSize = QRect(option->rect.x(), option->rect.y(), buttonSize.width(), option->rect.height()); else - elementSize = QRect(option->rect.right() - buttonWidth,option->rect.y(),buttonWidth,option->rect.height()); + elementSize = QRect(option->rect.right() - buttonSize.width(), option->rect.y(), buttonSize.width(), option->rect.height()); } break; case SC_SpinBoxEditField: - elementSize = option->rect.adjusted(buttonWidth, 0, -buttonWidth, 0); + elementSize = option->rect.adjusted(buttonSize.width(), 0, -buttonSize.width(), 0); break; default: break; @@ -2195,6 +2291,8 @@ void QHbStyle::polish(QWidget *widget) { + QCommonStyle::polish(widget); + if (!widget) return; @@ -2211,8 +2309,7 @@ } m_private->polishFont(widget); - - QCommonStyle::polish(widget); + m_private->polishPalette(widget); #ifndef QT_NO_PROGRESSBAR if (qobject_cast(widget)) @@ -2228,66 +2325,6 @@ void QHbStyle::polish(QPalette &palette) { QCommonStyle::polish(palette); - - palette.setBrush(QPalette::Disabled, QPalette::WindowText, QColor(QRgb(0xff808080))); - palette.setBrush(QPalette::Disabled, QPalette::Button, QColor(QRgb(0xffdddfe4))); - palette.setBrush(QPalette::Disabled, QPalette::Light, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Disabled, QPalette::Midlight, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Disabled, QPalette::Dark, QColor(QRgb(0xff555555))); - palette.setBrush(QPalette::Disabled, QPalette::Mid, QColor(QRgb(0xffc7c7c7))); - palette.setBrush(QPalette::Disabled, QPalette::Text, QColor(QRgb(0xffc7c7c7))); - palette.setBrush(QPalette::Disabled, QPalette::BrightText, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Disabled, QPalette::ButtonText, QColor(QRgb(0xff808080))); - palette.setBrush(QPalette::Disabled, QPalette::Base, QColor(QRgb(0xffefefef))); - palette.setBrush(QPalette::Disabled, QPalette::AlternateBase, palette.color(QPalette::Disabled, QPalette::Base).darker(110)); - palette.setBrush(QPalette::Disabled, QPalette::Window, QColor(QRgb(0xffefefef))); - palette.setBrush(QPalette::Disabled, QPalette::Shadow, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Disabled, QPalette::Highlight, QColor(QRgb(0xff567594))); - palette.setBrush(QPalette::Disabled, QPalette::HighlightedText, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Disabled, QPalette::Link, QColor(QRgb(0xff0000ee))); - palette.setBrush(QPalette::Disabled, QPalette::LinkVisited, QColor(QRgb(0xff52188b))); - palette.setBrush(QPalette::Disabled, QPalette::ToolTipBase, QColor(QRgb(0xff0000ee))); - palette.setBrush(QPalette::Disabled, QPalette::ToolTipText, QColor(QRgb(0xff52188b))); - - palette.setBrush(QPalette::Active, QPalette::WindowText, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Active, QPalette::Button, QColor(QRgb(0xffdddfe4))); - palette.setBrush(QPalette::Active, QPalette::Light, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Active, QPalette::Midlight, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Active, QPalette::Dark, QColor(QRgb(0xff555555))); - palette.setBrush(QPalette::Active, QPalette::Mid, QColor(QRgb(0xffc7c7c7))); - palette.setBrush(QPalette::Active, QPalette::Text, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Active, QPalette::BrightText, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Active, QPalette::ButtonText, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Active, QPalette::Base, QColor(QRgb(0xE4E4E4))); - palette.setBrush(QPalette::Active, QPalette::AlternateBase, palette.color(QPalette::Active, QPalette::Base).darker(110)); - palette.setBrush(QPalette::Active, QPalette::Window, QColor(QRgb(0xffefefef))); - palette.setBrush(QPalette::Active, QPalette::Shadow, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Active, QPalette::Highlight, QColor(QRgb(0xffE4E4E4))); - palette.setBrush(QPalette::Active, QPalette::HighlightedText, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Active, QPalette::Link, QColor(QRgb(0xff0000ee))); - palette.setBrush(QPalette::Active, QPalette::LinkVisited, QColor(QRgb(0xff52188b))); - palette.setBrush(QPalette::Active, QPalette::ToolTipBase, QColor(QRgb(0xff0000ee))); - palette.setBrush(QPalette::Active, QPalette::ToolTipText, QColor(QRgb(0xff52188b))); - - palette.setBrush(QPalette::Inactive, QPalette::WindowText, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Inactive, QPalette::Button, QColor(QRgb(0xffdddfe4))); - palette.setBrush(QPalette::Inactive, QPalette::Light, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Inactive, QPalette::Midlight, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Inactive, QPalette::Dark, QColor(QRgb(0xff555555))); - palette.setBrush(QPalette::Inactive, QPalette::Mid, QColor(QRgb(0xffc7c7c7))); - palette.setBrush(QPalette::Inactive, QPalette::Text, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Inactive, QPalette::BrightText, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Inactive, QPalette::ButtonText, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Inactive, QPalette::Base, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Inactive, QPalette::AlternateBase, palette.color(QPalette::Inactive, QPalette::Base).darker(110)); - palette.setBrush(QPalette::Inactive, QPalette::Window, QColor(QRgb(0xffefefef))); - palette.setBrush(QPalette::Inactive, QPalette::Shadow, QColor(QRgb(0xff000000))); - palette.setBrush(QPalette::Inactive, QPalette::Highlight, QColor(QRgb(0xff678db2))); - palette.setBrush(QPalette::Inactive, QPalette::HighlightedText, QColor(QRgb(0xffffffff))); - palette.setBrush(QPalette::Inactive, QPalette::Link, QColor(QRgb(0xff0000ee))); - palette.setBrush(QPalette::Inactive, QPalette::LinkVisited, QColor(QRgb(0xff52188b))); - palette.setBrush(QPalette::Inactive, QPalette::ToolTipBase, QColor(QRgb(0xff0000ee))); - palette.setBrush(QPalette::Inactive, QPalette::ToolTipText, QColor(QRgb(0xff52188b))); } void QHbStyle::unpolish(QWidget *widget) @@ -2391,19 +2428,14 @@ break; } case SP_ComputerIcon: { - iconName = QLatin1String("qtg_mono_mobile"); - break; - } - case SP_DriveFDIcon: { + iconName = QLatin1String("qtg_small_mobile"); break; } - case SP_DriveHDIcon: { - break; - } - case SP_DriveCDIcon: { - break; - } + case SP_DriveFDIcon: + case SP_DriveHDIcon: + case SP_DriveCDIcon: case SP_DriveDVDIcon: { + iconName = QLatin1String("qtg_large_mmc"); break; } case SP_DriveNetIcon: { @@ -2419,15 +2451,18 @@ break; } case SP_FileIcon: { + iconName = QLatin1String("qtg_large_notes"); break; } case SP_FileLinkIcon: { break; } case SP_ToolBarHorizontalExtensionButton: { + iconName = QLatin1String("qtg_mono_more"); break; } case SP_ToolBarVerticalExtensionButton: { + iconName = QLatin1String("qtg_mono_more"); break; } case SP_FileDialogStart: { @@ -2446,6 +2481,7 @@ break; } case SP_FileDialogInfoView: { + iconName = QLatin1String("qtg_large_info"); break; } case SP_FileDialogContentsView: { @@ -2461,12 +2497,14 @@ break; } case SP_DialogOkButton: { + iconName = QLatin1String("qtg_large_ok"); break; } case SP_DialogCancelButton: { break; } case SP_DialogHelpButton: { + iconName = QLatin1String("qtg_large_help"); break; } case SP_DialogOpenButton: { @@ -2479,12 +2517,14 @@ break; } case SP_DialogApplyButton: { + iconName = QLatin1String("qtg_large_ok"); break; } case SP_DialogResetButton: { break; } case SP_DialogDiscardButton: { + iconName = QLatin1String("qtg_small_fail"); break; } case SP_DialogYesButton: { @@ -2564,7 +2604,7 @@ QIcon icon; if (!iconName.isNull()) { - HbIcon* hbicon = q_check_ptr(new HbIcon(iconName)); + HbIcon* hbicon = new HbIcon(iconName); hbicon->setSize(iconRect.size()); icon = QIcon(hbicon->qicon()); delete hbicon; @@ -2645,9 +2685,9 @@ } } if (!alreadyAnimated) { - QHbStyleAnimation* target = q_check_ptr(new QHbStyleAnimation(const_cast(bar))); + QHbStyleAnimation* target = new QHbStyleAnimation(const_cast(bar)); target->createAnimationIcon(CE_ProgressBarContents, bar->orientation()); - QPropertyAnimation* animation = q_check_ptr(new QPropertyAnimation(target, "point")); + QPropertyAnimation* animation = new QPropertyAnimation(target, "point"); animation->setLoopCount(-1); //run until stopped const int chunk = pixelMetric(PM_ProgressBarChunkWidth, option, widget)-1; if (bar->orientation()== Qt::Horizontal) { @@ -2769,11 +2809,11 @@ break; } case SP_TreeViewExpanded: { - iconName = QLatin1String("qtg_small_hl_opened"); + iconName = QLatin1String("qtg_small_expand"); break; } case SP_TreeViewCollapsed: { - iconName = QLatin1String("qtg_small_hl_closed"); + iconName = QLatin1String("qtg_small_collapse"); break; } case SP_SubMenuIndicator: @@ -2782,7 +2822,7 @@ } } if (!iconName.isNull() && !rect.isEmpty()) { - HbIcon *icon = q_check_ptr(new HbIcon(iconName)); + HbIcon *icon = new HbIcon(iconName); icon->setSize(rect.size()); if (color.spec() != QColor::Invalid) icon->setColor(color); @@ -2809,8 +2849,8 @@ { //Q_Q(QHbStyle); - if (!m_frameDrawer) - m_frameDrawer = q_check_ptr(new HbFrameDrawer()); + if (m_frameDrawer.isNull()) + m_frameDrawer.reset(new HbFrameDrawer()); HbFrameDrawer::FrameType frameType = HbFrameDrawer::Undefined; QString frameName; @@ -2858,28 +2898,22 @@ frameType = HbFrameDrawer::NinePieces; break; } - case SM_ItemViewHighlight: { - frameName = QLatin1String("qtg_fr_list_highlight"); - frameType = HbFrameDrawer::NinePieces; - break; - } case SM_ItemViewItem: { if (state & SS_Pressed) frameName = QLatin1String("qtg_fr_list_pressed"); else if (state & SS_Focused) frameName = QLatin1String("qtg_fr_list_highlight"); - else - frameName = QLatin1String("qtg_fr_list_normal"); frameType = HbFrameDrawer::NinePieces; styleManager()->parameter(QLatin1String("hb-param-background-list-main"), border); break; } + case SM_TextEdit: //@todo: fallthrough for now, since no specific graphic for editors in releases case SM_LineEdit: { styleManager()->parameter(QLatin1String("hb-param-background-editor"), border); if (state & SS_Selected) - frameName = QLatin1String("qtg_fr_editor_highlight"); + frameName = QLatin1String("qtg_fr_lineedit_highlight"); else - frameName = QLatin1String("qtg_fr_editor_normal"); + frameName = QLatin1String("qtg_fr_lineedit_normal"); frameType = HbFrameDrawer::NinePieces; break; } @@ -2918,7 +2952,7 @@ break; } case SM_Panel: { - frameName = QLatin1String("qtg_fr_settingform"); + frameName = QLatin1String("qtg_fr_groupbox_normal"); frameType = HbFrameDrawer::NinePieces; styleManager()->parameter(QLatin1String("hb-param-background-list-main"), border); break; @@ -2945,6 +2979,16 @@ } break; } + //@todo: enable separate graphic for texteditor. Graphic was not included in the wk12 release. + /*case SM_TextEdit: { + styleManager()->parameter(QLatin1String("hb-param-background-editor"), border); + if (state & SS_Selected) + frameName = QLatin1String("qtg_fr_textedit_highlight"); + else + frameName = QLatin1String("qtg_fr_textedit_normal"); + frameType = HbFrameDrawer::NinePieces; + break; + }*/ case SM_ToolButton: { frameType = HbFrameDrawer::ThreePiecesHorizontal; frameGraphicsHeader = QLatin1String("qtg_fr_tb_h_"); @@ -3040,6 +3084,15 @@ } break; } + case SM_TableItem: { + if (state & SS_Pressed) + frameName = QLatin1String("qtg_fr_grid_pressed"); + else if (state & SS_Focused) + frameName = QLatin1String("qtg_fr_grid_highlight"); + frameType = HbFrameDrawer::NinePieces; + styleManager()->parameter(QLatin1String("hb-param-background-list-main"), border); + break; + } case SM_TabShape: { if (state & SS_Horizontal) { frameType = HbFrameDrawer::ThreePiecesHorizontal; @@ -3075,12 +3128,6 @@ frameGraphicsFooter = QLatin1String("normal"); break; } - case SM_TextEdit: { //@todo: combine this and case SM_LineEdit to "case SM_TextEditor"? - styleManager()->parameter(QLatin1String("hb-param-background-editor"), border); - frameName = QLatin1String("qtg_fr_editor"); - frameType = HbFrameDrawer::NinePieces; - break; - } case SM_ToolBarButton: { if (state & SS_Horizontal) { frameType = HbFrameDrawer::ThreePiecesHorizontal; @@ -3110,6 +3157,13 @@ styleManager()->parameter(QLatin1String("hb-param-background-button"), border); break; } + case SM_ToolBarExtension:{ +// fillRect = true; +// styleManager()->parameter(QLatin1String("hb-param-background-editor"), border); + frameName = QLatin1String("qtg_fr_tb_ext"); + frameType = HbFrameDrawer::NinePieces; + } + break; case SM_ToolTip: { fillRect = true; frameType = HbFrameDrawer::NinePieces; @@ -3117,7 +3171,6 @@ break; } case SM_HeaderItem: - case SM_TableItem: case SM_ThemeBackground: case SM_ToolBar: default: { @@ -3277,7 +3330,7 @@ valueFound = styleManager()->parameter(QLatin1String("hb-param-text-height-tiny"), fontSize); } - HbFontSpec *fontSpec = q_check_ptr(new HbFontSpec(fontRole)); + HbFontSpec *fontSpec = new HbFontSpec(fontRole); if (valueFound) { fontSpec->setTextHeight(fontSize); QFont widgetFont = fontSpec->font(); @@ -3287,4 +3340,29 @@ delete fontSpec; } +void QHbStylePrivate::polishPalette(QWidget *widget) +{ + QPalette widgetPalette = widget->palette(); + if (false +#ifndef QT_NO_TEXTEDIT + || qobject_cast(widget) +#endif + ) { + widgetPalette.setColor(QPalette::Active, QPalette::Highlight, HbColorScheme::color("qtc_lineedit_marker_normal")); + widgetPalette.setColor(QPalette::Active, QPalette::HighlightedText, HbColorScheme::color("qtc_lineedit_selected")); + widgetPalette.setColor(QPalette::Active, QPalette::Text, HbColorScheme::color("qtc_lineedit_normal")); + //QTextEdits have specific graphic in QHbStyle for background + widgetPalette.setColor(QPalette::Active, QPalette::Base, Qt::transparent); + } else if (false +#ifndef QT_NO_LINEEDIT + || qobject_cast(widget) +#endif + ) { + widgetPalette.setColor(QPalette::Active, QPalette::Highlight, HbColorScheme::color("qtc_lineedit_marker_normal")); + widgetPalette.setColor(QPalette::Active, QPalette::HighlightedText, HbColorScheme::color("qtc_lineedit_selected")); + widgetPalette.setColor(QPalette::Active, QPalette::Text, HbColorScheme::color("qtc_lineedit_normal")); + } + widget->setPalette(widgetPalette); +} + QT_END_NAMESPACE