- default fonts handled in windowstyle
[enigma2.git] / lib / gui / elabel.cpp
index f133b66142d325e34d5c8a798acf5bf1cf9ecfba..3519a7ac2fc0a8b944cb1ea5a5c47ef1726ccd21 100644 (file)
@@ -2,7 +2,14 @@
 
 eLabel::eLabel(eWidget *parent): eWidget(parent)
 {
+       ePtr<eWindowStyle> style;
+       getStyle(style);
        
+       style->getFont(eWindowStyle::fontStatic, m_font);
+       
+               /* default to topleft alignment */
+       m_valign = alignTop;
+       m_halign = alignLeft;
 }
 
 int eLabel::event(int event, void *data, void *data2)
@@ -11,18 +18,41 @@ int eLabel::event(int event, void *data, void *data2)
        {
        case evtPaint:
        {
+               ePtr<eWindowStyle> style;
+               
+               getStyle(style);
+               
+               eWidget::event(event, data, data2);
+
                gPainter &painter = *(gPainter*)data2;
-               ePtr<gFont> fnt = new gFont("Arial", 70);
-               painter.setFont(fnt);
-               painter.setBackgroundColor(gColor(0x10));
-               painter.setForegroundColor(gColor(0x1f));
-               painter.clear();
-               painter.setBackgroundColor(gColor(0x1f));
-               painter.setForegroundColor(gColor(0x10));
-               painter.renderText(eRect(0, 0, size().width(), size().height()), m_text);
+               painter.setFont(m_font);
+               style->setStyle(painter, eWindowStyle::styleLabel);
+               
+               int flags = 0;
+               if (m_valign == alignTop)
+                       flags |= gPainter::RT_VALIGN_TOP;
+               else if (m_valign == alignCenter)
+                       flags |= gPainter::RT_VALIGN_CENTER;
+               else if (m_valign == alignBottom)
+                       flags |= gPainter::RT_VALIGN_BOTTOM;
+
+               if (m_halign == alignLeft)
+                       flags |= gPainter::RT_HALIGN_LEFT;
+               else if (m_halign == alignCenter)
+                       flags |= gPainter::RT_HALIGN_CENTER;
+               else if (m_halign == alignRight)
+                       flags |= gPainter::RT_HALIGN_RIGHT;
+               else if (m_halign == alignBlock)
+                       flags |= gPainter::RT_HALIGN_BLOCK;
+               
+               flags |= gPainter::RT_WRAP;
+               painter.renderText(eRect(0, 0, size().width(), size().height()), m_text, flags);
+               
                return 0;
        }
+       case evtChangedFont:
        case evtChangedText:
+       case evtChangedAlignment:
                invalidate();
                return 0;
        default:
@@ -37,3 +67,21 @@ void eLabel::setText(const std::string &string)
        m_text = string;
        event(evtChangedText);
 }
+
+void eLabel::setFont(gFont *font)
+{
+       m_font = font;
+       event(evtChangedFont);
+}
+
+void eLabel::setVAlign(int align)
+{
+       m_valign = align;
+       event(evtChangedAlignment);
+}
+
+void eLabel::setHAlign(int align)
+{
+       m_halign = align;
+       event(evtChangedAlignment);
+}