summaryrefslogtreecommitdiff
path: root/noncore/multimedia/opieplayer2/xinevideowidget.cpp
Side-by-side diff
Diffstat (limited to 'noncore/multimedia/opieplayer2/xinevideowidget.cpp') (more/less context) (show whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/xinevideowidget.cpp97
1 files changed, 69 insertions, 28 deletions
diff --git a/noncore/multimedia/opieplayer2/xinevideowidget.cpp b/noncore/multimedia/opieplayer2/xinevideowidget.cpp
index 9e86041..211791b 100644
--- a/noncore/multimedia/opieplayer2/xinevideowidget.cpp
+++ b/noncore/multimedia/opieplayer2/xinevideowidget.cpp
@@ -2,5 +2,6 @@
/*
-                This file is part of the Opie Project
+                This file is part of the Opie Project
- Copyright (c) 2002 Robert Griebl <sandman@handhelds.org>
+              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org>
+ Copyright (c) 2002 L. Potter <ljp@llornkcor.com>
Copyright (c) 2002 Holger Freyther <zecke@handhelds.org>
@@ -8,21 +9,21 @@
.=l.
-           .>+-=
- _;:,     .>    :=|. This program is free software; you can
-.> <`_,   >  .   <= redistribute it and/or modify it under
-:`=1 )Y*s>-.--   : the terms of the GNU General Public
-.="- .-=="i,     .._ License as published by the Free Software
- - .   .-<_>     .<> Foundation; either version 2 of the License,
-     ._= =}       : or (at your option) any later version.
-    .%`+i>       _;_.
-    .i_,=:_.      -<s. This program is distributed in the hope that
-     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
-    : ..    .:,     . . . without even the implied warranty of
-    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
-  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
-..}^=.=       =       ; Library General Public License for more
-++=   -.     .`     .: details.
- :     =  ...= . :.=-
- -.   .:....=;==+<; You should have received a copy of the GNU
-  -_. . .   )=.  = Library General Public License along with
-    --        :-=` this library; see the file COPYING.LIB.
+           .>+-=
+ _;:,     .>    :=|. This program is free software; you can
+.> <`_,   >  .   <= redistribute it and/or modify it under
+:`=1 )Y*s>-.--   : the terms of the GNU General Public
+.="- .-=="i,     .._ License as published by the Free Software
+ - .   .-<_>     .<> Foundation; either version 2 of the License,
+     ._= =}       : or (at your option) any later version.
+    .%`+i>       _;_.
+    .i_,=:_.      -<s. This program is distributed in the hope that
+     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
+    : ..    .:,     . . . without even the implied warranty of
+    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
+  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
+..}^=.=       =       ; Library General Public License for more
+++=   -.     .`     .: details.
+ :     =  ...= . :.=-
+ -.   .:....=;==+<; You should have received a copy of the GNU
+  -_. . .   )=.  = Library General Public License along with
+    --        :-=` this library; see the file COPYING.LIB.
If not, write to the Free Software Foundation,
@@ -33,2 +34,5 @@
+#include "xinevideowidget.h"
+#include <opie2/odebug.h>
+
#include <qimage.h>
@@ -41,3 +45,4 @@
-#include "xinevideowidget.h"
+#include <pthread.h>
+
@@ -123,2 +128,3 @@ XineVideoWidget::XineVideoWidget ( QWidget* parent, const char* name )
m_rotation = 0;
+ m_lastsize = 0;
}
@@ -128,4 +134,12 @@ XineVideoWidget::~XineVideoWidget ( )
{
+ ThreadUtil::AutoLock a(m_bufmutex);
+ if (m_buff) {
+ delete[]m_buff;
+ m_lastsize=0;
+ m_buff = 0;
+ }
+ if (m_logo) {
delete m_logo;
}
+}
@@ -133,3 +147,8 @@ void XineVideoWidget::clear ( )
{
+ ThreadUtil::AutoLock a(m_bufmutex);
+ if (m_buff) {
+ delete[]m_buff;
+ m_lastsize=0;
m_buff = 0;
+ }
repaint ( false );
@@ -154,2 +173,12 @@ void XineVideoWidget::paintEvent ( QPaintEvent * )
{
+ ThreadUtil::AutoLock a(m_bufmutex);
+ QPainter p ( this );
+ p. fillRect ( rect (), black );
+ if (m_logo)
+ p. drawImage ( 0, 0, *m_logo );
+}
+
+void XineVideoWidget::paintEvent2 ( QPaintEvent * )
+{
+ ThreadUtil::AutoLock a(m_bufmutex);
if ( m_buff == 0 ) {
@@ -274,3 +303,18 @@ void XineVideoWidget::setVideoFrame ( uchar* img, int w, int h, int bpl )
{
+ // mutex area for AutoLock
+ {
+ if (m_bufmutex.isLocked()) {
+ // no time to wait - drop frame
+ return;
+ }
+ ThreadUtil::AutoLock a(m_bufmutex);
bool rot90 = (( -m_rotation ) & 1 );
+ int l = h*m_bytes_per_pixel*w;
+ if (l>m_lastsize) {
+ if (m_buff) {
+ delete[]m_buff;
+ }
+ m_buff = new uchar[l];
+ m_lastsize=l;
+ }
@@ -285,10 +329,7 @@ void XineVideoWidget::setVideoFrame ( uchar* img, int w, int h, int bpl )
- m_buff = img;
+ memcpy(m_buff,img,m_lastsize);
m_bytes_per_line_frame = bpl;
+ } // Release Mutex
- // only repaint the area that *really* needs to be repainted
-
- repaint ((( m_thisframe & m_lastframe ) != m_lastframe ) ? m_lastframe : m_thisframe, false );
- // ensure that we always have a valid frame!
- m_buff = 0;
+ paintEvent2(0);
}