src/hbwidgets/itemviews/hbindexfeedback.cpp
changeset 34 ed14f46c0e55
parent 7 923ff622b8b9
--- 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 <hbscrollbar.h>
-#include <hbstyleoptionindexfeedback_p.h>
+#include <hbframeitem.h>
+#include <hbtextitem.h>
 #include <hbstyleparameters.h>
 #include <hbstyle.h>
 #include <hbdeviceprofile.h>
+#include <hbstyletextprimitivedata.h>
+#include <hbstyleframeprimitivedata.h>
 
 #include <QEvent>
 #include <QObject>
 #include <QGraphicsScene>
+#include <QGraphicsObject>
 
 /*!
     @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<HbStyleTextPrimitiveData*>(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<HbStyleFramePrimitiveData*>(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)