patch by Pieter Grimmerink: use ext3 largefile option only for disks > 4G
[enigma2.git] / lib / gdi / grc.cpp
index b3ad2ccc13feb95dd5f6be25be319a5f47968314..a46b218c3d74a4169b38a70c1c6bf6712fb6d7fc 100644 (file)
@@ -106,6 +106,9 @@ void *gRC::thread()
 #endif
                if ( rp != wp )
                {
+                               /* make sure the spinner is not displayed when we something is painted */
+                       disableSpinner();
+
                        gOpcode o(queue[rp++]);
                        if ( rp == MAXSIZE )
                                rp=0;
@@ -146,7 +149,7 @@ void *gRC::thread()
                                if (m_spinner_enabled)
                                        timeout.tv_nsec += 100*1000*1000;
                                else
-                                       timeout.tv_nsec += 500*1000*1000;
+                                       timeout.tv_sec += 2;
 
                                        /* yes, this is required. */
                                if (timeout.tv_nsec > 1000*1000*1000)
@@ -167,8 +170,9 @@ void *gRC::thread()
 
                                if (!idle)
                                {
+                                       if (!m_spinner_enabled)
+                                               eDebug("main thread is non-idle! display spinner!");
                                        enableSpinner();
-                                       eDebug("main thread is non-idle! display spinner!");
                                } else
                                        disableSpinner();
                        }
@@ -199,11 +203,12 @@ void gRC::enableSpinner()
                return;
        }
 
-       m_spinner_enabled = 1;
-
        gOpcode o;
        o.opcode = m_spinner_enabled ? gOpcode::incrementSpinner : gOpcode::enableSpinner;
        m_spinner_dc->exec(&o);
+       m_spinner_enabled = 1;
+       o.opcode = gOpcode::flush;
+       m_spinner_dc->exec(&o);
 }
 
 void gRC::disableSpinner()
@@ -222,6 +227,8 @@ void gRC::disableSpinner()
        gOpcode o;
        o.opcode = gOpcode::disableSpinner;
        m_spinner_dc->exec(&o);
+       o.opcode = gOpcode::flush;
+       m_spinner_dc->exec(&o);
 }
 
 static int gPainter_instances;
@@ -516,16 +523,6 @@ void gPainter::clippop()
        m_rc->submit(o);
 }
 
-void gPainter::flush()
-{
-       if ( m_dc->islocked() )
-               return;
-       gOpcode o;
-       o.opcode = gOpcode::flush;
-       o.dc = m_dc.grabRef();
-       m_rc->submit(o);
-}
-
 void gPainter::waitVSync()
 {
        if ( m_dc->islocked() )
@@ -568,14 +565,17 @@ void gPainter::end()
 
 gDC::gDC()
 {
+       m_spinner_pic = 0;
 }
 
 gDC::gDC(gPixmap *pixmap): m_pixmap(pixmap)
 {
+       m_spinner_pic = 0;
 }
 
 gDC::~gDC()
 {
+       delete[] m_spinner_pic;
 }
 
 void gDC::exec(gOpcode *o)
@@ -751,10 +751,13 @@ void gDC::exec(gOpcode *o)
        case gOpcode::flush:
                break;
        case gOpcode::enableSpinner:
+               enableSpinner();
                break;
        case gOpcode::disableSpinner:
+               disableSpinner();
                break;
        case gOpcode::incrementSpinner:
+               incrementSpinner();
                break;
        default:
                eFatal("illegal opcode %d. expect memory leak!", o->opcode);
@@ -773,6 +776,76 @@ gRGB gDC::getRGB(gColor col)
        return m_pixmap->surface->clut.data[col];
 }
 
+void gDC::enableSpinner()
+{
+       ASSERT(m_spinner_saved);
+       
+               /* save the background to restore it later. We need to negative position because we want to blit from the middle of the screen. */
+       m_spinner_saved->blit(*m_pixmap, -m_spinner_pos.topLeft(), gRegion(eRect(ePoint(0, 0), m_spinner_saved->size())), 0);
+       
+       incrementSpinner();
+}
+
+void gDC::disableSpinner()
+{
+       ASSERT(m_spinner_saved);
+
+               /* restore background */
+       m_pixmap->blit(*m_spinner_saved, m_spinner_pos.topLeft(), gRegion(m_spinner_pos), 0);
+}
+
+void gDC::incrementSpinner()
+{
+       ASSERT(m_spinner_saved);
+       
+       static int blub;
+       blub++;
+
+#if 0
+       int i;
+       
+       for (i = 0; i < 5; ++i)
+       {
+               int x = i * 20 + m_spinner_pos.left();
+               int y = m_spinner_pos.top();
+               
+               int col = ((blub - i) * 30) % 256;
+
+               m_pixmap->fill(eRect(x, y, 10, 10), gRGB(col, col, col));
+       }
+#endif
+
+       m_spinner_temp->blit(*m_spinner_saved, ePoint(0, 0), eRect(ePoint(0, 0), m_spinner_pos.size()));
+
+       if (m_spinner_pic[m_spinner_i])
+               m_spinner_temp->blit(*m_spinner_pic[m_spinner_i], ePoint(0, 0), eRect(ePoint(0, 0), m_spinner_pos.size()), gPixmap::blitAlphaTest);
+
+       m_pixmap->blit(*m_spinner_temp, m_spinner_pos.topLeft(), gRegion(m_spinner_pos), 0);
+       m_spinner_i++;
+       m_spinner_i %= m_spinner_num;
+}
+
+void gDC::setSpinner(eRect pos, ePtr<gPixmap> *pic, int len)
+{
+       ASSERT(m_pixmap);
+       ASSERT(m_pixmap->surface);
+       m_spinner_saved = new gPixmap(pos.size(), m_pixmap->surface->bpp);
+       m_spinner_temp = new gPixmap(pos.size(), m_pixmap->surface->bpp);
+       m_spinner_pos = pos;
+       
+       m_spinner_i = 0;
+       m_spinner_num = len;
+       
+       int i;
+       if (m_spinner_pic)
+               delete[] m_spinner_pic;
+       
+       m_spinner_pic = new ePtr<gPixmap>[len];
+       
+       for (i = 0; i < len; ++i)
+               m_spinner_pic[i] = pic[i];
+}
+
 DEFINE_REF(gDC);
 
 eAutoInitPtr<gRC> init_grc(eAutoInitNumbers::graphic, "gRC");