summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/xinevideowidget.cpp101
-rw-r--r--noncore/multimedia/opieplayer2/xinevideowidget.h42
2 files changed, 57 insertions, 86 deletions
diff --git a/noncore/multimedia/opieplayer2/xinevideowidget.cpp b/noncore/multimedia/opieplayer2/xinevideowidget.cpp
index 78ebe19..b27b8e1 100644
--- a/noncore/multimedia/opieplayer2/xinevideowidget.cpp
+++ b/noncore/multimedia/opieplayer2/xinevideowidget.cpp
@@ -1,51 +1,51 @@
1/* 1/*
2                This file is part of the Opie Project 2 This file is part of the Opie Project
3 3
4              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> 4 Copyright (c) 2002 Max Reiss <harlekin@handhelds.org>
5 Copyright (c) 2002 L. Potter <ljp@llornkcor.com> 5 Copyright (c) 2002 L. Potter <ljp@llornkcor.com>
6 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> 6 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org>
7 =. 7 =.
8 .=l. 8 .=l.
9           .>+-= 9 .>+-=
10 _;:,     .>    :=|. This program is free software; you can 10 _;:, .> :=|. This program is free software; you can
11.> <`_,   >  .   <= redistribute it and/or modify it under 11.> <`_, > . <= redistribute it and/or modify it under
12:`=1 )Y*s>-.--   : the terms of the GNU General Public 12:`=1 )Y*s>-.-- : the terms of the GNU General Public
13.="- .-=="i,     .._ License as published by the Free Software 13.="- .-=="i, .._ License as published by the Free Software
14 - .   .-<_>     .<> Foundation; either version 2 of the License, 14 - . .-<_> .<> Foundation; either version 2 of the License,
15     ._= =}       : or (at your option) any later version. 15 ._= =} : or (at your option) any later version.
16    .%`+i>       _;_. 16 .%`+i> _;_.
17    .i_,=:_.      -<s. This program is distributed in the hope that 17 .i_,=:_. -<s. This program is distributed in the hope that
18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 18 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
19    : ..    .:,     . . . without even the implied warranty of 19 : .. .:, . . . without even the implied warranty of
20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 20 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 21 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
22..}^=.=       =       ; Library General Public License for more 22..}^=.= = ; Library General Public License for more
23++=   -.     .`     .: details. 23++= -. .` .: details.
24 :     =  ...= . :.=- 24 : = ...= . :.=-
25 -.   .:....=;==+<; You should have received a copy of the GNU 25 -. .:....=;==+<; You should have received a copy of the GNU
26  -_. . .   )=.  = Library General Public License along with 26 -_. . . )=. = Library General Public License along with
27    --        :-=` this library; see the file COPYING.LIB. 27 -- :-=` this library; see the file COPYING.LIB.
28 If not, write to the Free Software Foundation, 28 If not, write to the Free Software Foundation,
29 Inc., 59 Temple Place - Suite 330, 29 Inc., 59 Temple Place - Suite 330,
30 Boston, MA 02111-1307, USA. 30 Boston, MA 02111-1307, USA.
31 31
32*/ 32*/
33 33
34#include "xinevideowidget.h" 34#include "xinevideowidget.h"
35#include <opie2/odebug.h> 35#include <opie2/odebug.h>
36 36
37#include <qimage.h> 37#include <qimage.h>
38#include <qdirectpainter_qws.h> 38#include <qdirectpainter_qws.h>
39#include <qgfx_qws.h> 39#include <qgfx_qws.h>
40#include <qsize.h> 40#include <qsize.h>
41#include <qapplication.h> 41#include <qapplication.h>
42 42
43#include <qpe/resource.h> 43#include <qpe/resource.h>
44 44
45#include <pthread.h> 45#include <pthread.h>
46 46
47 47
48 48
49// 0 deg rot: copy a line from src to dst (use libc memcpy) 49// 0 deg rot: copy a line from src to dst (use libc memcpy)
50 50
51// 180 deg rot: copy a line from src to dst reversed 51// 180 deg rot: copy a line from src to dst reversed
@@ -149,185 +149,156 @@ void XineVideoWidget::clear ( )
149 delete[]m_buff; 149 delete[]m_buff;
150 m_lastsize=0; 150 m_lastsize=0;
151 m_buff = 0; 151 m_buff = 0;
152 } 152 }
153 repaint ( false ); 153 repaint ( false );
154} 154}
155 155
156QSize XineVideoWidget::videoSize() const 156QSize XineVideoWidget::videoSize() const
157{ 157{
158 QSize s = size(); 158 QSize s = size();
159 bool fs = ( s == qApp->desktop()->size() ); 159 bool fs = ( s == qApp->desktop()->size() );
160 160
161 // if we are in fullscreen mode, do not rotate the video 161 // if we are in fullscreen mode, do not rotate the video
162 // (!! the paint routine uses m_rotation + qt_screen-> transformOrientation() !!) 162 // (!! the paint routine uses m_rotation + qt_screen-> transformOrientation() !!)
163 m_rotation = fs ? - qt_screen->transformOrientation() : 0; 163 m_rotation = fs ? - qt_screen->transformOrientation() : 0;
164 164
165 if ( fs && qt_screen->isTransformed() ) 165 if ( fs && qt_screen->isTransformed() )
166 s = qt_screen->mapToDevice( s ); 166 s = qt_screen->mapToDevice( s );
167 167
168 return s; 168 return s;
169} 169}
170 170
171void XineVideoWidget::paintEvent ( QPaintEvent * ) 171void XineVideoWidget::paintEvent ( QPaintEvent * )
172{ 172{
173 if (m_bufmutex.isLocked()) {
174 return;
175 }
176 ThreadUtil::AutoLock a(m_bufmutex);
177 QPainter p ( this ); 173 QPainter p ( this );
178 p. fillRect ( rect (), black ); 174 p. fillRect ( rect (), black );
179 if (m_logo) 175 if (m_logo)
180 p. drawImage ( 0, 0, *m_logo ); 176 p. drawImage ( 0, 0, *m_logo );
181} 177}
182 178
183void XineVideoWidget::paintEvent2 ( QPaintEvent * ) 179void XineVideoWidget::paintEvent2 ( QPaintEvent * )
184{ 180{
185 ThreadUtil::AutoLock a(m_bufmutex);
186 QPainter p (this);
187 if ( m_buff == 0 ) { 181 if ( m_buff == 0 ) {
188 p. fillRect ( rect ( ), black ); 182 return;
189 if ( m_logo )
190 p. drawImage ( 0, 0, *m_logo );
191 } else if (m_lastsize){ 183 } else if (m_lastsize){
192 // Qt needs to be notified which areas were really updated .. strange
193 QArray <QRect> qt_bug_workaround_clip_rects;
194
195 { 184 {
196 QDirectPainter dp ( this ); 185 QDirectPainter dp ( this );
197
198 int rot = dp. transformOrientation ( ) + m_rotation; // device rotation + custom rotation 186 int rot = dp. transformOrientation ( ) + m_rotation; // device rotation + custom rotation
199
200 bool rot90 = (( -m_rotation ) & 1 ); 187 bool rot90 = (( -m_rotation ) & 1 );
201
202 int _vw,_vh; 188 int _vw,_vh;
203 switch (rot90) { 189 switch (rot90) {
204 case true: 190 case true:
205 _vh = m_framesize.width(); 191 _vh = m_framesize.width();
206 _vw = m_framesize.height(); 192 _vw = m_framesize.height();
207 break; 193 break;
208 default: 194 default:
209 _vw = m_framesize.width(); 195 _vw = m_framesize.width();
210 _vh = m_framesize.height(); 196 _vh = m_framesize.height();
211 break; 197 break;
212 break; 198 break;
213 } 199 }
214 int middle_w = _vw/2; 200 int middle_w = _vw/2;
215 int middle_h = _vh/2; 201 int middle_h = _vh/2;
216 m_thisframe.setRect(width()/2-middle_w,height()/2-middle_h,_vw,_vh); 202 m_thisframe.setRect(width()/2-middle_w,height()/2-middle_h,_vw,_vh);
217
218 {
219 // is this stuff realy needed? it seems working without, too.
220 QRect topFill,rightFill,leftFill,downFill;
221 topFill. setRect(0,0 ,width(),m_thisframe.top());
222 downFill.setCoords(0,m_thisframe.bottom(),width(),height());
223 rightFill.setCoords(m_thisframe.right(),0,width(),height());
224 leftFill.setCoords(0,0,m_thisframe.left(),height());
225
226 if (topFill.isValid()) {
227 p.fillRect(topFill,black);
228 }
229 if (downFill.isValid()) {
230 p.fillRect(downFill,black);
231 }
232 if (rightFill.isValid()) {
233 p.fillRect(rightFill,black);
234 }
235 if (leftFill.isValid()) {
236 p.fillRect(leftFill,black);
237 }
238
239 }
240 uchar *fb = dp. frameBuffer ( ); 203 uchar *fb = dp. frameBuffer ( );
241 uchar *frame = m_buff; 204 uchar *frame = m_buff;
242 205
243 // where is the video frame in fb coordinates 206 // where is the video frame in fb coordinates
244 QRect framerect = qt_screen-> mapToDevice ( QRect ( mapToGlobal ( m_thisframe. topLeft ( )), m_thisframe. size ( )), QSize ( qt_screen-> width ( ), 207 QRect framerect = qt_screen-> mapToDevice ( QRect ( mapToGlobal ( m_thisframe. topLeft ( )), m_thisframe. size ( )), QSize ( qt_screen-> width ( ),
245 qt_screen-> height ( ))); 208 qt_screen-> height ( )));
246 209
247 uchar * src = frame; 210 uchar * src = frame;
248 uchar * dst = fb+framerect.y()*m_bytes_per_line_fb+framerect.x()*m_bytes_per_pixel; 211 uchar * dst = fb+framerect.y()*m_bytes_per_line_fb+framerect.x()*m_bytes_per_pixel;
249 212
250 for (int y=framerect.top();y<=framerect.bottom();++y) { 213 if (framerect.height()!=m_framesize.height()) {
214 odebug << "Hoehm: " << framerect.height() << " <-> " << m_framesize.height() << oendl;
215 }
216 for (int y = 0;y<framerect.height();++y) {
251 switch (rot) { 217 switch (rot) {
252 case 0: 218 case 0:
253 memcpy(dst,src,m_bytes_per_line_frame); 219 memcpy(dst,src,m_bytes_per_line_frame);
254 src+=m_bytes_per_line_frame; 220 src+=m_bytes_per_line_frame;
255 break; 221 break;
256 case 1: 222 case 1:
257 memcpy_step ( dst, src, m_thisframe.size().width(), m_bytes_per_line_frame ); 223 memcpy_step ( dst, src, m_thisframe.size().width(), m_bytes_per_line_frame );
258 src -= m_bytes_per_pixel; 224 src -= m_bytes_per_pixel;
259 break; 225 break;
260 case 2: 226 case 2:
261 memcpy_rev ( dst, src, m_thisframe.size().width()); 227 memcpy_rev ( dst, src, m_thisframe.size().width());
262 src-=m_bytes_per_line_frame; 228 src-=m_bytes_per_line_frame;
263 break; 229 break;
264 case 3: 230 case 3:
265 memcpy_step_rev ( dst, src, m_thisframe.size().width(), m_bytes_per_line_frame ); 231 memcpy_step_rev ( dst, src, m_thisframe.size().width(), m_bytes_per_line_frame );
266 src += m_bytes_per_pixel; 232 src += m_bytes_per_pixel;
267 break; 233 break;
268 default: 234 default:
269 break; 235 break;
270 } 236 }
271 dst += m_bytes_per_line_fb; 237 dst += m_bytes_per_line_fb;
272 } 238 }
273 } 239 }
274 } 240 }
275} 241}
276 242
277QImage *XineVideoWidget::logo ( ) const 243QImage *XineVideoWidget::logo ( ) const
278{ 244{
279 return m_logo; 245 return m_logo;
280} 246}
281 247
282 248
283void XineVideoWidget::setLogo ( QImage* logo ) 249void XineVideoWidget::setLogo ( QImage* logo )
284{ 250{
285 delete m_logo; 251 delete m_logo;
286 m_logo = logo; 252 m_logo = logo;
287} 253}
288 254
289void XineVideoWidget::setVideoFrame ( uchar* img, int w, int h, int bpl ) 255void XineVideoWidget::setVideoFrame ( uchar* img, int w, int h, int bpl )
290{ 256{
291 // mutex area for AutoLock 257 // mutex area for AutoLock
292 { 258 {
293 if (m_bufmutex.isLocked()||w>width()||h>height()) { 259#if 0
294 // no time to wait - drop frame 260 ThreadUtil::AutoLock a(m_bufmutex);
261#endif
262 if (!isVisible()||w>width()||h>height()/*||m_bufmutex.isLocked()*/) {
263 //drop frame
295 return; 264 return;
296 } 265 }
297 ThreadUtil::AutoLock a(m_bufmutex);
298 bool rot90 = (( -m_rotation ) & 1 ); 266 bool rot90 = (( -m_rotation ) & 1 );
299 int l = h*bpl; 267 int l = h*bpl;
300 if (l!=m_lastsize) { 268 if (l!=m_lastsize) {
301 if (m_buff) { 269 if (m_buff) {
302 delete[]m_buff; 270 delete[]m_buff;
303 } 271 }
304 if (l>0) { 272 if (l>0) {
305 m_buff = new uchar[l]; 273 m_buff = new uchar[l];
306 odebug << "Point to: " << (unsigned long)m_buff << oendl; 274 odebug << "Point to: " << (unsigned long)m_buff << oendl;
307 m_lastsize=l; 275 m_lastsize=l;
308 } else { 276 } else {
309 m_buff = 0; 277 m_buff = 0;
310 } 278 }
311 } 279 }
312 m_lastsize = l; 280 m_lastsize = l;
313 m_framesize = QSize(w,h); 281 m_framesize = QSize(w,h);
314 if (m_buff && m_lastsize) { 282 if (m_buff && m_lastsize) {
315 memcpy(m_buff,img,m_lastsize); 283 memcpy(m_buff,img,m_lastsize);
316 } 284 }
317 m_bytes_per_line_frame = bpl; 285 m_bytes_per_line_frame = bpl;
286 if (m_buff) paintEvent2(0);
318 } // Release Mutex 287 } // Release Mutex
319
320 if (m_buff) paintEvent2(0);
321} 288}
322 289
323void XineVideoWidget::resizeEvent ( QResizeEvent * ) 290void XineVideoWidget::resizeEvent ( QResizeEvent * )
324{ 291{
292#if 0
293 ThreadUtil::AutoLock a(m_bufmutex);
294#endif
325 emit videoResized( videoSize() ); 295 emit videoResized( videoSize() );
296 odebug << "All resize done" << oendl;
326} 297}
327 298
328 299
329void XineVideoWidget::mouseReleaseEvent ( QMouseEvent * /*me*/ ) 300void XineVideoWidget::mouseReleaseEvent ( QMouseEvent * /*me*/ )
330{ 301{
331 emit clicked(); 302 emit clicked();
332} 303}
333 304
diff --git a/noncore/multimedia/opieplayer2/xinevideowidget.h b/noncore/multimedia/opieplayer2/xinevideowidget.h
index eccff1a..a0ec5bc 100644
--- a/noncore/multimedia/opieplayer2/xinevideowidget.h
+++ b/noncore/multimedia/opieplayer2/xinevideowidget.h
@@ -1,52 +1,52 @@
1 1
2/* 2/*
3                This file is part of the Opie Project 3 This file is part of the Opie Project
4 4
5              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> 5 Copyright (c) 2002 Max Reiss <harlekin@handhelds.org>
6 Copyright (c) 2002 L. Potter <ljp@llornkcor.com> 6 Copyright (c) 2002 L. Potter <ljp@llornkcor.com>
7 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> 7 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org>
8 =. 8 =.
9 .=l. 9 .=l.
10           .>+-= 10 .>+-=
11 _;:,     .>    :=|. This program is free software; you can 11 _;:, .> :=|. This program is free software; you can
12.> <`_,   >  .   <= redistribute it and/or modify it under 12.> <`_, > . <= redistribute it and/or modify it under
13:`=1 )Y*s>-.--   : the terms of the GNU General Public 13:`=1 )Y*s>-.-- : the terms of the GNU General Public
14.="- .-=="i,     .._ License as published by the Free Software 14.="- .-=="i, .._ License as published by the Free Software
15 - .   .-<_>     .<> Foundation; either version 2 of the License, 15 - . .-<_> .<> Foundation; either version 2 of the License,
16     ._= =}       : or (at your option) any later version. 16 ._= =} : or (at your option) any later version.
17    .%`+i>       _;_. 17 .%`+i> _;_.
18    .i_,=:_.      -<s. This program is distributed in the hope that 18 .i_,=:_. -<s. This program is distributed in the hope that
19     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 19 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
20    : ..    .:,     . . . without even the implied warranty of 20 : .. .:, . . . without even the implied warranty of
21    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 21 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
22  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 22 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
23..}^=.=       =       ; Library General Public License for more 23..}^=.= = ; Library General Public License for more
24++=   -.     .`     .: details. 24++= -. .` .: details.
25 :     =  ...= . :.=- 25 : = ...= . :.=-
26 -.   .:....=;==+<; You should have received a copy of the GNU 26 -. .:....=;==+<; You should have received a copy of the GNU
27  -_. . .   )=.  = Library General Public License along with 27 -_. . . )=. = Library General Public License along with
28    --        :-=` this library; see the file COPYING.LIB. 28 -- :-=` this library; see the file COPYING.LIB.
29 If not, write to the Free Software Foundation, 29 If not, write to the Free Software Foundation,
30 Inc., 59 Temple Place - Suite 330, 30 Inc., 59 Temple Place - Suite 330,
31 Boston, MA 02111-1307, USA. 31 Boston, MA 02111-1307, USA.
32 32
33*/ 33*/
34 34
35 35
36#include <qwidget.h> 36#include <qwidget.h>
37 37
38#include "lib.h" 38#include "lib.h"
39 39
40class QImage; 40class QImage;
41 41
42 42
43class XineVideoWidget : public QWidget { 43class XineVideoWidget : public QWidget {
44 Q_OBJECT 44 Q_OBJECT
45 45
46public: 46public:
47 XineVideoWidget ( QWidget* parent, const char* name ); 47 XineVideoWidget ( QWidget* parent, const char* name );
48 ~XineVideoWidget ( ); 48 ~XineVideoWidget ( );
49 QImage *logo ( ) const; 49 QImage *logo ( ) const;
50 void setLogo ( QImage *image ); 50 void setLogo ( QImage *image );
51 void setVideoFrame ( uchar *image, int width, int height, int linestep ); 51 void setVideoFrame ( uchar *image, int width, int height, int linestep );
52 void clear ( ); 52 void clear ( );