summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFraxinas <andreas.frisch@multimedia-labs.de>2009-05-27 21:45:01 (GMT)
committerFraxinas <andreas.frisch@multimedia-labs.de>2009-05-27 21:45:01 (GMT)
commit3f71f581949b23c013b07a266e9aae0edd102a53 (patch)
treef00f579f20f3e473589bba09b4c42b51b48ba962
parent51e789a04f758941668b095fd8b051db2ce58281 (diff)
make subtitle font styles skinnable
-rwxr-xr-xdata/skin.xml8
-rw-r--r--lib/gui/esubtitle.cpp49
-rw-r--r--lib/gui/esubtitle.h24
-rw-r--r--lib/python/enigma_python.i2
-rw-r--r--skin.py35
-rw-r--r--tests/enigma.py1
6 files changed, 92 insertions, 27 deletions
diff --git a/data/skin.xml b/data/skin.xml
index ca1e97d..1592330 100755
--- a/data/skin.xml
+++ b/data/skin.xml
@@ -69,6 +69,14 @@
<font filename="ae_AlMateen.ttf" name="Replacement" scale="90" replacement="1" />
<font filename="tuxtxt.ttf" name="Console" scale="100" />
</fonts>
+ <!-- Subtitle effects -->
+ <subtitles>
+ <sub name="Subtitle_TTX" font="Regular;30" shadowColor="#40101010" shadowOffset="3,3" />
+ <sub name="Subtitle_Regular" font="Regular;30" foregroundColor="#DCDCDC" shadowColor="#40101010" shadowOffset="3,3" />
+ <sub name="Subtitle_Bold" font="Replacement;30" foregroundColor="#DCDCDC" shadowColor="#40101010" shadowOffset="3,3" />
+ <sub name="Subtitle_Italic" font="Regular;30" foregroundColor="#DCAAAA" shadowColor="#40101010" shadowOffset="3,3" />
+ <!-- omitting foregroundColor attribute will enable auto-assignment of color -->
+ </subtitles>
<!-- Main infobar -->
<screen name="InfoBar" flags="wfNoBorder" position="0,380" size="720,160" title="InfoBar" backgroundColor="transparent">
<!-- Background -->
diff --git a/lib/gui/esubtitle.cpp b/lib/gui/esubtitle.cpp
index ca5c20d..376fa24 100644
--- a/lib/gui/esubtitle.cpp
+++ b/lib/gui/esubtitle.cpp
@@ -10,6 +10,8 @@
....
*/
+eSubtitleWidget::eSubtitleStyle eSubtitleWidget::subtitleStyles[Subtitle_MAX];
+
eSubtitleWidget::eSubtitleWidget(eWidget *parent)
: eWidget(parent), m_hide_subtitles_timer(eTimer::create(eApp))
{
@@ -131,42 +133,42 @@ int eSubtitleWidget::event(int event, void *data, void *data2)
else if (m_page_ok)
{
int elements = m_page.m_elements.size();
- ePtr<gFont> font = new gFont("Regular", 38);
- painter.setFont(font);
+ painter.setFont(subtitleStyles[Subtitle_TTX].font);
for (int i=0; i<elements; ++i)
{
eDVBTeletextSubtitlePageElement &element = m_page.m_elements[i];
eRect &area = element.m_area;
eRect shadow = area;
- shadow.moveBy(3,3);
- painter.setForegroundColor(gRGB(0,0,0));
+ shadow.moveBy(subtitleStyles[Subtitle_TTX].shadow_offset);
+ painter.setForegroundColor(subtitleStyles[Subtitle_TTX].shadow_color);
painter.renderText(shadow, element.m_text, gPainter::RT_WRAP|gPainter::RT_VALIGN_CENTER|gPainter::RT_HALIGN_CENTER);
- painter.setForegroundColor(element.m_color);
+ if ( !subtitleStyles[Subtitle_TTX].have_foreground_color )
+ painter.setForegroundColor(element.m_color);
+ else
+ painter.setForegroundColor(subtitleStyles[Subtitle_TTX].foreground_color);
painter.renderText(area, element.m_text, gPainter::RT_WRAP|gPainter::RT_VALIGN_CENTER|gPainter::RT_HALIGN_CENTER);
}
}
else if (m_pango_page_ok)
{
int elements = m_pango_page.m_elements.size();
- ePtr<gFont> font = new gFont("Regular", 38);
+ subfont_t face;
+
for (int i=0; i<elements; ++i)
{
+ face = Subtitle_Regular;
ePangoSubtitlePageElement &element = m_pango_page.m_elements[i];
- std::string text = element.m_pango_line;
+ std::string text = element.m_pango_line;
std::string::size_type loc = text.find("<", 0 );
if ( loc != std::string::npos )
{
switch (char(text.at(1)))
{
case 'i':
- eDebug("found italic");
- font = new gFont("LCD", 40);
+ face = Subtitle_Italic;
break;
case 'b':
- eDebug("found bold");
- font = new gFont("Replacement", 40);
- break;
- default:
+ face = Subtitle_Bold;
break;
}
text = text.substr(3, text.length()-7);
@@ -174,13 +176,16 @@ int eSubtitleWidget::event(int event, void *data, void *data2)
text = replace_all(text, "&apos;", "'");
text = replace_all(text, "&quot;", "\"");
text = replace_all(text, "&amp;", "&");
- painter.setFont(font);
+ painter.setFont(subtitleStyles[face].font);
eRect &area = element.m_area;
eRect shadow = area;
- shadow.moveBy(3,3);
- painter.setForegroundColor(gRGB(0,0,0));
+ shadow.moveBy(subtitleStyles[face].shadow_offset);
+ painter.setForegroundColor(subtitleStyles[face].shadow_color);
painter.renderText(shadow, text, gPainter::RT_WRAP|gPainter::RT_VALIGN_CENTER|gPainter::RT_HALIGN_CENTER);
- painter.setForegroundColor(element.m_color);
+ if ( !subtitleStyles[face].have_foreground_color && element.m_have_color )
+ painter.setForegroundColor(element.m_color);
+ else
+ painter.setForegroundColor(subtitleStyles[face].foreground_color);
painter.renderText(area, text, gPainter::RT_WRAP|gPainter::RT_VALIGN_CENTER|gPainter::RT_HALIGN_CENTER);
}
}
@@ -195,3 +200,13 @@ int eSubtitleWidget::event(int event, void *data, void *data2)
return eWidget::event(event, data, data2);
}
}
+
+void eSubtitleWidget::setFontStyle(subfont_t face, gFont *font, int haveColor, const gRGB &col, const gRGB &shadowCol, const ePoint &shadowOffset)
+{
+ subtitleStyles[face].font = font;
+ subtitleStyles[face].have_foreground_color = haveColor;
+ subtitleStyles[face].foreground_color = col;
+ subtitleStyles[face].shadow_color = shadowCol;
+ subtitleStyles[face].shadow_offset = shadowOffset;
+}
+
diff --git a/lib/gui/esubtitle.h b/lib/gui/esubtitle.h
index 0a780ca..d728777 100644
--- a/lib/gui/esubtitle.h
+++ b/lib/gui/esubtitle.h
@@ -8,10 +8,15 @@
struct ePangoSubtitlePageElement
{
gRGB m_color;
+ bool m_have_color;
std::string m_pango_line;
eRect m_area;
ePangoSubtitlePageElement(const gRGB &color, const std::string &text)
- : m_color(color), m_pango_line(text)
+ : m_color(color), m_pango_line(text), m_have_color(true)
+ {
+ }
+ ePangoSubtitlePageElement(const std::string &text)
+ : m_pango_line(text), m_have_color(false)
{
}
};
@@ -37,11 +42,22 @@ public:
void setPage(const eDVBSubtitlePage &p);
void setPage(const ePangoSubtitlePage &p);
void clearPage();
-
void setPixmap(ePtr<gPixmap> &pixmap, gRegion changed);
+
+ typedef enum { Subtitle_TTX, Subtitle_Regular, Subtitle_Bold, Subtitle_Italic, Subtitle_MAX } subfont_t;
+ struct eSubtitleStyle
+ {
+ subfont_t face;
+ int have_foreground_color, have_shadow_color;
+ gRGB foreground_color, shadow_color;
+ ePoint shadow_offset;
+ ePtr<gFont> font;
+ };
+
+ static void setFontStyle(subfont_t face, gFont *font, int autoColor, const gRGB &col, const gRGB &shadowCol, const ePoint &shadowOffset);
+
protected:
int event(int event, void *data=0, void *data2=0);
-
private:
int m_page_ok;
eDVBTeletextSubtitlePage m_page;
@@ -56,6 +72,8 @@ private:
gRegion m_visible_region;
+ static eSubtitleStyle subtitleStyles[Subtitle_MAX];
+
ePtr<gPixmap> m_pixmap; // pixmap to paint on next evtPaint
};
diff --git a/lib/python/enigma_python.i b/lib/python/enigma_python.i
index fe0e71e..2fec2ff 100644
--- a/lib/python/enigma_python.i
+++ b/lib/python/enigma_python.i
@@ -69,6 +69,7 @@ is usually caused by not marking PSignals as immutable.
#include <lib/python/connections.h>
#include <lib/gui/elistbox.h>
#include <lib/gui/elistboxcontent.h>
+#include <lib/gui/esubtitle.h>
#include <lib/service/listboxservice.h>
#include <lib/nav/pcore.h>
#include <lib/actions/action.h>
@@ -183,6 +184,7 @@ typedef long time_t;
%include <lib/gui/ewindowstyleskinned.h>
%include <lib/gui/ewidgetanimation.h>
%include <lib/gui/evideo.h>
+%include <lib/gui/esubtitle.h>
%include <lib/service/listboxservice.h>
%include <lib/nav/pcore.h>
%include <lib/actions/action.h>
diff --git a/skin.py b/skin.py
index a37716f..d44e503 100644
--- a/skin.py
+++ b/skin.py
@@ -6,7 +6,6 @@ from os import path
profile("LOAD:enigma_skin")
from enigma import eSize, ePoint, gFont, eWindow, eLabel, ePixmap, eWindowStyleManager, \
addFont, gRGB, eWindowStyleSkinned
-
from Components.config import ConfigSubsection, ConfigText, config
from Components.Converter.Converter import Converter
from Components.Sources.Source import Source, ObsoleteSource
@@ -298,6 +297,28 @@ def loadSingleSkinData(desktop, skin, path_prefix):
addFont(resolved_font, name, scale, is_replacement)
#print "Font: ", resolved_font, name, scale, is_replacement
+ for c in skin.findall("subtitles"):
+ from enigma import eWidget, eSubtitleWidget
+ scale = ((1,1),(1,1))
+ for substyle in c.findall("sub"):
+ get_attr = substyle.attrib.get
+ font = parseFont(get_attr("font"), scale)
+ col = get_attr("foregroundColor")
+ if col:
+ foregroundColor = parseColor(col)
+ haveColor = 1
+ else:
+ foregroundColor = gRGB(0xFFFFFF)
+ haveColor = 0
+ col = get_attr("shadowColor")
+ if col:
+ shadowColor = parseColor(col)
+ else:
+ shadowColor = gRGB(0)
+ shadowOffset = parsePosition(get_attr("shadowOffset"), scale)
+ face = eval("eSubtitleWidget.%s" % get_attr("name"))
+ eSubtitleWidget.setFontStyle(face, font, haveColor, foregroundColor, shadowColor, shadowOffset)
+
for windowstyle in skin.findall("windowstyle"):
style = eWindowStyleSkinned()
id = windowstyle.attrib.get("id")
@@ -333,12 +354,12 @@ def loadSingleSkinData(desktop, skin, path_prefix):
for color in windowstyle.findall("color"):
get_attr = color.attrib.get
- type = get_attr("name")
+ colorType = get_attr("name")
color = parseColor(get_attr("color"))
try:
- style.setColor(eWindowStyleSkinned.__dict__["col" + type], color)
+ style.setColor(eWindowStyleSkinned.__dict__["col" + colorType], color)
except:
- raise SkinError("Unknown color %s" % (type))
+ raise SkinError("Unknown color %s" % (colorType))
#pass
#print " color:", type, color
@@ -528,15 +549,15 @@ def readSkin(screen, skin, names, desktop):
#print "Found code:"
#print codeText
- type = widget.attrib.get('type')
+ widgetType = widget.attrib.get('type')
code = compile(codeText, "skin applet", "exec")
- if type == "onLayoutFinish":
+ if widgetType == "onLayoutFinish":
screen.onLayoutFinish.append(code)
#print "onLayoutFinish = ", codeText
else:
- raise SkinError("applet type '%s' unknown!" % type)
+ raise SkinError("applet type '%s' unknown!" % widgetType)
#print "applet type '%s' unknown!" % type
continue
diff --git a/tests/enigma.py b/tests/enigma.py
index 2bf2a59..e82aa49 100644
--- a/tests/enigma.py
+++ b/tests/enigma.py
@@ -96,6 +96,7 @@ eWindowStyleSkinned = None
eButton = None
eListboxPythonStringContent = None
eListbox = None
+eSubtitleWidget = None
class eEPGCache:
@classmethod