diff -r 7516d6d86cf5 -r ed14f46c0e55 src/hbwidgets/itemviews/hbindexfeedback.cpp --- a/src/hbwidgets/itemviews/hbindexfeedback.cpp Mon Oct 04 17:49:30 2010 +0300 +++ b/src/hbwidgets/itemviews/hbindexfeedback.cpp Mon Oct 18 18:23:13 2010 +0300 @@ -29,14 +29,18 @@ #include "hbabstractitemview.h" #include -#include +#include +#include #include #include #include +#include +#include #include #include #include +#include /*! @alpha @@ -60,8 +64,8 @@ \sa HbAbstractItemView, HbIndexFeedback::IndexFeedbackPolicy. \primitives - \primitive{index-text} HbTextItem representing the text in the HbIndexFeedback. - \primitive{index-background} HbFrameItem representing the background of the HbIndexFeedback. + \primitive{index-text} HbTextItem with item name "index-text" representing the text in the HbIndexFeedback. + \primitive{index-background} HbFrameItem with item name "index-background" representing the background of the HbIndexFeedback. */ /*! @@ -172,7 +176,7 @@ d->_q_hideIndexFeedbackNow(); d->mIndexFeedbackPolicy = policy; d->calculatePopupRects(); - d->updatePrimitives(); + updatePrimitives(); } } @@ -292,7 +296,7 @@ case QEvent::Resize: d->_q_hideIndexFeedbackNow(); d->calculatePopupRects(); - d->updatePrimitives(); + updatePrimitives(); break; default: @@ -304,59 +308,76 @@ return QObject::eventFilter(obj, ev); } -/* - For use with HbStyle. - - Provide the correct data to use in the 'model.' +/*! + Initializes the HbIndexFeedback primitive data. + + This function calls HbWidgetBase::initPrimitiveData(). + \a primitiveData is data object, which is populated with data. \a primitive is the primitive. */ -void HbIndexFeedback::initStyleOption(HbStyleOptionIndexFeedback *option) const +void HbIndexFeedback::initPrimitiveData(HbStylePrimitiveData *primitiveData, + const QGraphicsObject *primitive) { - Q_D( const HbIndexFeedback ); - - HbWidget::initStyleOption(option); + Q_ASSERT_X(primitive && primitiveData, "HbIndexFeedback::initPrimitiveData" , "NULL data not permitted"); + Q_D(HbIndexFeedback); - if (!d->mItemView) { - return; - } + HbWidgetBase::initPrimitiveData(primitiveData, primitive); + + if (primitiveData->type == HbStylePrimitiveData::SPD_Text) { + HbStyleTextPrimitiveData *textPrimitiveData = hbstyleprimitivedata_cast(primitiveData); - HbFontSpec fontSpec; - qreal margin = 0; - - style()->parameter(QLatin1String("hb-param-margin-gene-popup"), margin); - - switch (d->mIndexFeedbackPolicy) { - case IndexFeedbackSingleCharacter: - { + HbFontSpec fontSpec; + switch (d->mIndexFeedbackPolicy) { + case IndexFeedbackSingleCharacter: { fontSpec = HbFontSpec(HbFontSpec::Primary); fontSpec.setTextHeight(d->textHeight()); - } - break; - - case IndexFeedbackThreeCharacter: - { + } + break; + case IndexFeedbackThreeCharacter: { fontSpec = HbFontSpec(HbFontSpec::Primary); fontSpec.setTextHeight(d->textHeight()); - } - break; - - case IndexFeedbackString: - { + } + break; + case IndexFeedbackString: { fontSpec = HbFontSpec(HbFontSpec::Primary); qreal textHeight = 0; style()->parameter(QLatin1String("hb-param-text-height-primary"), textHeight); fontSpec.setTextHeight( textHeight ); - } - break; + } + break; + case IndexFeedbackNone: + // no initialisation + return; + } + textPrimitiveData->fontSpec = fontSpec; + + textPrimitiveData->text = d->mPopupContent; + textPrimitiveData->geometry = d->mPopupTextRect; + + } else if (primitiveData->type == HbStylePrimitiveData::SPD_Frame) { + HbStyleFramePrimitiveData *framePrimitiveData = hbstyleprimitivedata_cast(primitiveData); + framePrimitiveData->geometry = d->mPopupBackgroundRect; + } +} + - case IndexFeedbackNone: - // leave the HbStyleOption uninitialized - return; - } + +/* + Update the primitives for the index feedback. +*/ +void HbIndexFeedback::updatePrimitives() +{ + Q_D( HbIndexFeedback ); - option->text = d->mPopupContent; - option->fontSpec = fontSpec; - option->textRect = d->mPopupTextRect; - option->popupRect = d->mPopupBackgroundRect; + if (d->mTextItem) { + HbStyleTextPrimitiveData textPrimitiveData; + initPrimitiveData(&textPrimitiveData, d->mTextItem); + style()->updatePrimitive(d->mTextItem, &textPrimitiveData, this); + } + if (d->mPopupItem) { + HbStyleFramePrimitiveData framePrimitiveData; + initPrimitiveData(&framePrimitiveData, d->mPopupItem); + style()->updatePrimitive(d->mPopupItem, &framePrimitiveData, this); + } } void HbIndexFeedback::polish(HbStyleParameters& params)