aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2005-03-31 19:55:46 +0000
committerFelix Domke <tmbinc@elitedvb.net>2005-03-31 19:55:46 +0000
commit77c45c9d2cabd3c1dc028c41d26573ac62147a34 (patch)
treed2264677d28a4220458f3269b2fadacdad3a9905 /lib
parent29a034f2d2cc8e6b63632d6d959388b719f7c9fd (diff)
downloadenigma2-77c45c9d2cabd3c1dc028c41d26573ac62147a34.tar.gz
enigma2-77c45c9d2cabd3c1dc028c41d26573ac62147a34.zip
- fixed blit in gRC
- enable use of loadPNG trough python (something is still broken, sorry) - add ePixmap - dummy widgets now possible as pixmaps
Diffstat (limited to 'lib')
-rw-r--r--lib/gdi/epng.h2
-rw-r--r--lib/gdi/gpixmap.cpp2
-rw-r--r--lib/gdi/gpixmap.h2
-rw-r--r--lib/gdi/grc.cpp9
-rw-r--r--lib/gui/Makefile.am3
-rw-r--r--lib/gui/epixmap.cpp37
-rw-r--r--lib/gui/epixmap.h22
-rw-r--r--lib/python/enigma_python.i9
8 files changed, 81 insertions, 5 deletions
diff --git a/lib/gdi/epng.h b/lib/gdi/epng.h
index 244019f3..09f30233 100644
--- a/lib/gdi/epng.h
+++ b/lib/gdi/epng.h
@@ -1,7 +1,7 @@
#ifndef __png_h
#define __png_h
-#include "grc.h"
+#include <lib/gdi/gpixmap.h>
int loadPNG(ePtr<gPixmap> &pixmap, const char *filename);
int savePNG(const char *filename, gPixmap *pixmap);
diff --git a/lib/gdi/gpixmap.cpp b/lib/gdi/gpixmap.cpp
index c2c75e7a..fe0c0a1f 100644
--- a/lib/gdi/gpixmap.cpp
+++ b/lib/gdi/gpixmap.cpp
@@ -147,7 +147,7 @@ void gPixmap::blit(const gPixmap &src, ePoint pos, const gRegion &clip, int flag
eRect srcarea=area;
srcarea.moveBy(-pos.x(), -pos.y());
-
+
if ((surface->bpp == 8) && (src.surface->bpp==8))
{
__u8 *srcptr=(__u8*)src.surface->data;
diff --git a/lib/gdi/gpixmap.h b/lib/gdi/gpixmap.h
index e549787c..f29a0fe7 100644
--- a/lib/gdi/gpixmap.h
+++ b/lib/gdi/gpixmap.h
@@ -128,4 +128,6 @@ public:
virtual ~gPixmap();
};
+TEMPLATE_TYPEDEF(ePtr<gPixmap>, gPixmapPtr);
+
#endif
diff --git a/lib/gdi/grc.cpp b/lib/gdi/grc.cpp
index e7748967..3b5476a2 100644
--- a/lib/gdi/grc.cpp
+++ b/lib/gdi/grc.cpp
@@ -188,7 +188,7 @@ void gPainter::clear()
void gPainter::blit(gPixmap *pixmap, ePoint pos, const eRect &clip, int flags)
{
gOpcode o;
-
+
o.opcode=gOpcode::blit;
o.dc = m_dc.grabRef();
pixmap->AddRef();
@@ -398,11 +398,16 @@ void gDC::exec(gOpcode *o)
case gOpcode::blit:
{
gRegion clip;
- if (!o->parm.blit->clip.valid())
+ // this code should be checked again but i'm too tired now
+
+ o->parm.blit->position += m_current_offset;
+
+ if (o->parm.blit->clip.valid())
{
clip.intersect(gRegion(o->parm.blit->clip), clip);
} else
clip = m_current_clip;
+
m_pixmap->blit(*o->parm.blit->pixmap, o->parm.blit->position, clip, o->parm.blit->flags);
o->parm.blit->pixmap->Release();
delete o->parm.blit;
diff --git a/lib/gui/Makefile.am b/lib/gui/Makefile.am
index 375a9469..076ee36a 100644
--- a/lib/gui/Makefile.am
+++ b/lib/gui/Makefile.am
@@ -6,6 +6,7 @@ noinst_LIBRARIES = libenigma_gui.a
libenigma_gui_a_SOURCES = \
ebutton.cpp elabel.cpp eslider.cpp ewidget.cpp ewidgetdesktop.cpp \
- ewindow.cpp ewindowstyle.cpp elistbox.cpp elistboxcontent.cpp
+ ewindow.cpp ewindowstyle.cpp elistbox.cpp elistboxcontent.cpp \
+ epixmap.cpp
diff --git a/lib/gui/epixmap.cpp b/lib/gui/epixmap.cpp
new file mode 100644
index 00000000..a0655aa9
--- /dev/null
+++ b/lib/gui/epixmap.cpp
@@ -0,0 +1,37 @@
+#include <lib/gui/epixmap.h>
+
+ePixmap::ePixmap(eWidget *parent): eWidget(parent)
+{
+}
+
+void ePixmap::setPixmap(gPixmap *pixmap)
+{
+ m_pixmap = pixmap;
+ event(evtChangedPixmap);
+}
+
+int ePixmap::event(int event, void *data, void *data2)
+{
+ switch (event)
+ {
+ case evtPaint:
+ {
+ ePtr<eWindowStyle> style;
+
+ getStyle(style);
+
+ eWidget::event(event, data, data2);
+
+ gPainter &painter = *(gPainter*)data2;
+ if (m_pixmap)
+ painter.blit(m_pixmap, ePoint(0, 0));
+
+ return 0;
+ }
+ case evtChangedPixmap:
+ invalidate();
+ return 0;
+ default:
+ return eWidget::event(event, data, data2);
+ }
+}
diff --git a/lib/gui/epixmap.h b/lib/gui/epixmap.h
new file mode 100644
index 00000000..8a12e2e9
--- /dev/null
+++ b/lib/gui/epixmap.h
@@ -0,0 +1,22 @@
+#ifndef __lib_gui_epximap_h
+#define __lib_gui_epixmap_h
+
+#include <lib/gui/ewidget.h>
+
+class ePixmap: public eWidget
+{
+public:
+ ePixmap(eWidget *parent);
+
+ void setPixmap(gPixmap *pixmap);
+protected:
+ ePtr<gPixmap> m_pixmap;
+ int event(int event, void *data=0, void *data2=0);
+private:
+ enum eLabelEvent
+ {
+ evtChangedPixmap = evtUserWidget,
+ };
+};
+
+#endif
diff --git a/lib/python/enigma_python.i b/lib/python/enigma_python.i
index 59133cc5..7369b646 100644
--- a/lib/python/enigma_python.i
+++ b/lib/python/enigma_python.i
@@ -44,8 +44,11 @@ is usually caused by not marking PSignals as immutable.
#include <lib/service/service.h>
#include <lib/service/event.h>
+#include <lib/gdi/gpixmap.h>
+
#include <lib/gui/ewidget.h>
#include <lib/gui/elabel.h>
+#include <lib/gui/epixmap.h>
#include <lib/gui/ebutton.h>
#include <lib/gui/ewindow.h>
#include <lib/gui/ewidgetdesktop.h>
@@ -59,6 +62,7 @@ is usually caused by not marking PSignals as immutable.
#include <lib/nav/pcore.h>
#include <lib/actions/action.h>
#include <lib/gdi/gfont.h>
+#include <lib/gdi/epng.h>
extern void runMainloop();
extern void quitMainloop();
@@ -90,12 +94,16 @@ extern PSignal1<void,int> &keyPressedSignal();
%immutable eComponentScan::statusChanged;
%immutable pNavigation::m_event;
+
+%include <lib/gdi/gpixmap.h>
+
%include <lib/gdi/epoint.h>
%include <lib/gdi/erect.h>
%include <lib/gdi/esize.h>
%include <lib/gdi/region.h>
%include <lib/gui/ewidget.h>
%include <lib/gui/elabel.h>
+%include <lib/gui/epixmap.h>
%include <lib/gui/ebutton.h>
%include <lib/gui/ewindow.h>
%include <lib/gui/eslider.h>
@@ -108,6 +116,7 @@ extern PSignal1<void,int> &keyPressedSignal();
%include <lib/nav/pcore.h>
%include <lib/actions/action.h>
%include <lib/gdi/gfont.h>
+%include <lib/gdi/epng.h>
/************** eptr **************/