summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/videowidget.cpp32
-rw-r--r--noncore/multimedia/opieplayer2/videowidget.h2
2 files changed, 12 insertions, 22 deletions
diff --git a/noncore/multimedia/opieplayer2/videowidget.cpp b/noncore/multimedia/opieplayer2/videowidget.cpp
index 089ef6a..3baa087 100644
--- a/noncore/multimedia/opieplayer2/videowidget.cpp
+++ b/noncore/multimedia/opieplayer2/videowidget.cpp
@@ -89,137 +89,127 @@ VideoWidget::VideoWidget( PlayListWidget &playList, MediaPlayerState &mediaPlaye
89 89
90 Config cfg("OpiePlayer"); 90 Config cfg("OpiePlayer");
91 cfg.setGroup("Options"); 91 cfg.setGroup("Options");
92 skin = cfg.readEntry("Skin","default"); 92 skin = cfg.readEntry("Skin","default");
93 93
94 QString skinPath = "opieplayer2/skins/" + skin; 94 QString skinPath = "opieplayer2/skins/" + skin;
95 pixBg = QPixmap( Resource::loadPixmap( QString("%1/background").arg(skinPath) ) ); 95 pixBg = QPixmap( Resource::loadPixmap( QString("%1/background").arg(skinPath) ) );
96 imgUp = QImage( Resource::loadImage( QString("%1/skinV_up").arg(skinPath) ) ); 96 imgUp = QImage( Resource::loadImage( QString("%1/skinV_up").arg(skinPath) ) );
97 imgDn = QImage( Resource::loadImage( QString("%1/skinV_down").arg(skinPath) ) ); 97 imgDn = QImage( Resource::loadImage( QString("%1/skinV_down").arg(skinPath) ) );
98 98
99 buttonMask = QImage( imgUp.width(), imgUp.height(), 8, 255 ); 99 buttonMask = QImage( imgUp.width(), imgUp.height(), 8, 255 );
100 buttonMask.fill( 0 ); 100 buttonMask.fill( 0 );
101 101
102 for ( int i = 0; i < 7; i++ ) { 102 for ( int i = 0; i < 7; i++ ) {
103 Button &button = buttons[ i ]; 103 Button &button = buttons[ i ];
104 104
105 QString filename = QString( QPEApplication::qpeDir() + "/pics/" + skinPath + "/skinV_mask_" + skinV_mask_file_names[i] + ".png" ); 105 QString filename = QString( QPEApplication::qpeDir() + "/pics/" + skinPath + "/skinV_mask_" + skinV_mask_file_names[i] + ".png" );
106 button.mask = QBitmap( filename ); 106 button.mask = QBitmap( filename );
107 107
108 if ( !button.mask.isNull() ) { 108 if ( !button.mask.isNull() ) {
109 QImage imgMask = button.mask.convertToImage(); 109 QImage imgMask = button.mask.convertToImage();
110 uchar **dest = buttonMask.jumpTable(); 110 uchar **dest = buttonMask.jumpTable();
111 for ( int y = 0; y < imgUp.height(); y++ ) { 111 for ( int y = 0; y < imgUp.height(); y++ ) {
112 uchar *line = dest[y]; 112 uchar *line = dest[y];
113 for ( int x = 0; x < imgUp.width(); x++ ) { 113 for ( int x = 0; x < imgUp.width(); x++ ) {
114 if ( !qRed( imgMask.pixel( x, y ) ) ) 114 if ( !qRed( imgMask.pixel( x, y ) ) )
115 line[x] = i + 1; 115 line[x] = i + 1;
116 } 116 }
117 } 117 }
118 } 118 }
119 } 119 }
120 120
121 for ( int i = 0; i < 7; i++ ) {
122 buttonPixUp[i] = NULL;
123 buttonPixDown[i] = NULL;
124 }
125
126 setBackgroundPixmap( pixBg ); 121 setBackgroundPixmap( pixBg );
127 122
128 slider = new QSlider( Qt::Horizontal, this ); 123 slider = new QSlider( Qt::Horizontal, this );
129 slider->setMinValue( 0 ); 124 slider->setMinValue( 0 );
130 slider->setMaxValue( 1 ); 125 slider->setMaxValue( 1 );
131 slider->setBackgroundPixmap( Resource::loadPixmap( backgroundPix ) ); 126 slider->setBackgroundPixmap( Resource::loadPixmap( backgroundPix ) );
132 //slider->setFocusPolicy( QWidget::NoFocus ); 127 //slider->setFocusPolicy( QWidget::NoFocus );
133 128
134 resizeEvent( NULL ); 129 resizeEvent( NULL );
135 130
136 setLength( mediaPlayerState.length() ); 131 setLength( mediaPlayerState.length() );
137 setPosition( mediaPlayerState.position() ); 132 setPosition( mediaPlayerState.position() );
138 setFullscreen( mediaPlayerState.isFullscreen() ); 133 setFullscreen( mediaPlayerState.isFullscreen() );
139 setPlaying( mediaPlayerState.isPlaying() ); 134 setPlaying( mediaPlayerState.isPlaying() );
140} 135}
141 136
142 137
143VideoWidget::~VideoWidget() { 138VideoWidget::~VideoWidget()
144 for ( int i = 0; i < 7; i++ ) { 139{
145 delete buttonPixUp[i];
146 delete buttonPixDown[i];
147 }
148} 140}
149 141
150QPixmap *combineVImageWithBackground( QImage img, QPixmap bg, QPoint offset ) { 142QPixmap *combineVImageWithBackground( QImage img, QPixmap bg, QPoint offset ) {
151 QPixmap pix( img.width(), img.height() ); 143 QPixmap pix( img.width(), img.height() );
152 QPainter p( &pix ); 144 QPainter p( &pix );
153 p.drawTiledPixmap( pix.rect(), bg, offset ); 145 p.drawTiledPixmap( pix.rect(), bg, offset );
154 p.drawImage( 0, 0, img ); 146 p.drawImage( 0, 0, img );
155 return new QPixmap( pix ); 147 return new QPixmap( pix );
156} 148}
157 149
158QPixmap *maskVPixToMask( QPixmap pix, QBitmap mask ) { 150QPixmap maskVPixToMask( QPixmap pix, QBitmap mask ) {
159 QPixmap *pixmap = new QPixmap( pix ); 151 QPixmap pixmap( pix );
160 pixmap->setMask( mask ); 152 pixmap.setMask( mask );
161 return pixmap; 153 return pixmap;
162} 154}
163 155
164void VideoWidget::resizeEvent( QResizeEvent * ) { 156void VideoWidget::resizeEvent( QResizeEvent * ) {
165 int h = height(); 157 int h = height();
166 int w = width(); 158 int w = width();
167 //int Vh = 160; 159 //int Vh = 160;
168 //int Vw = 220; 160 //int Vw = 220;
169 161
170 slider->setFixedWidth( w - 20 ); 162 slider->setFixedWidth( w - 20 );
171 slider->setGeometry( QRect( 15, h - 22, w - 90, 20 ) ); 163 slider->setGeometry( QRect( 15, h - 22, w - 90, 20 ) );
172 slider->setBackgroundOrigin( QWidget::ParentOrigin ); 164 slider->setBackgroundOrigin( QWidget::ParentOrigin );
173 slider->setFocusPolicy( QWidget::NoFocus ); 165 slider->setFocusPolicy( QWidget::NoFocus );
174 slider->setBackgroundPixmap( pixBg ); 166 slider->setBackgroundPixmap( pixBg );
175 167
176 upperLeftOfButtonMask.rx() = 0;// ( imgUp->width() ) / 2; 168 upperLeftOfButtonMask.rx() = 0;// ( imgUp->width() ) / 2;
177 if(w>h) 169 if(w>h)
178 upperLeftOfButtonMask.ry() = 0; 170 upperLeftOfButtonMask.ry() = 0;
179 else 171 else
180 upperLeftOfButtonMask.ry() = 185;//(( Vh - imgUp->height() ) / 2) - 10; 172 upperLeftOfButtonMask.ry() = 185;//(( Vh - imgUp->height() ) / 2) - 10;
181 QPoint p = upperLeftOfButtonMask; 173 QPoint p = upperLeftOfButtonMask;
182 174
183 QPixmap *pixUp = combineVImageWithBackground( imgUp, pixBg, p ); 175 QPixmap *pixUp = combineVImageWithBackground( imgUp, pixBg, p );
184 QPixmap *pixDn = combineVImageWithBackground( imgDn, pixBg, p ); 176 QPixmap *pixDn = combineVImageWithBackground( imgDn, pixBg, p );
185 177
186 for ( int i = 0; i < 7; i++ ) { 178 for ( int i = 0; i < 7; i++ ) {
187 Button &button = buttons[ i ]; 179 Button &button = buttons[ i ];
188 180
189 if ( !button.mask.isNull() ) { 181 if ( !button.mask.isNull() ) {
190 delete buttonPixUp[i]; 182 button.pixUp = maskVPixToMask( *pixUp, button.mask );
191 delete buttonPixDown[i]; 183 button.pixDown = maskVPixToMask( *pixDn, button.mask );
192 buttonPixUp[i] = maskVPixToMask( *pixUp, button.mask );
193 buttonPixDown[i] = maskVPixToMask( *pixDn, button.mask );
194 } 184 }
195 } 185 }
196 186
197 delete pixUp; 187 delete pixUp;
198 delete pixDn; 188 delete pixDn;
199} 189}
200 190
201static bool videoSliderBeingMoved = FALSE; 191static bool videoSliderBeingMoved = FALSE;
202 192
203void VideoWidget::sliderPressed() { 193void VideoWidget::sliderPressed() {
204 videoSliderBeingMoved = TRUE; 194 videoSliderBeingMoved = TRUE;
205} 195}
206 196
207void VideoWidget::sliderReleased() { 197void VideoWidget::sliderReleased() {
208 videoSliderBeingMoved = FALSE; 198 videoSliderBeingMoved = FALSE;
209 if ( slider->width() == 0 ) { 199 if ( slider->width() == 0 ) {
210 return; 200 return;
211 } 201 }
212 long val = long((double)slider->value() * mediaPlayerState.length() / slider->width()); 202 long val = long((double)slider->value() * mediaPlayerState.length() / slider->width());
213 mediaPlayerState.setPosition( val ); 203 mediaPlayerState.setPosition( val );
214} 204}
215 205
216void VideoWidget::setPosition( long i ) { 206void VideoWidget::setPosition( long i ) {
217 updateSlider( i, mediaPlayerState.length() ); 207 updateSlider( i, mediaPlayerState.length() );
218} 208}
219 209
220 210
221void VideoWidget::setLength( long max ) { 211void VideoWidget::setLength( long max ) {
222 updateSlider( mediaPlayerState.position(), max ); 212 updateSlider( mediaPlayerState.position(), max );
223} 213}
224 214
225void VideoWidget::setDisplayType( MediaPlayerState::DisplayType displayType ) 215void VideoWidget::setDisplayType( MediaPlayerState::DisplayType displayType )
@@ -231,68 +221,70 @@ void VideoWidget::setDisplayType( MediaPlayerState::DisplayType displayType )
231 221
232 // Effectively blank the view next time we show it so it looks nicer 222 // Effectively blank the view next time we show it so it looks nicer
233 scaledWidth = 0; 223 scaledWidth = 0;
234 scaledHeight = 0; 224 scaledHeight = 0;
235 hide(); 225 hide();
236} 226}
237 227
238void VideoWidget::updateSlider( long i, long max ) { 228void VideoWidget::updateSlider( long i, long max ) {
239 // Will flicker too much if we don't do this 229 // Will flicker too much if we don't do this
240 if ( max == 0 ) { 230 if ( max == 0 ) {
241 return; 231 return;
242 } 232 }
243 int width = slider->width(); 233 int width = slider->width();
244 int val = int((double)i * width / max); 234 int val = int((double)i * width / max);
245 if ( !mediaPlayerState.isFullscreen() && !videoSliderBeingMoved ) { 235 if ( !mediaPlayerState.isFullscreen() && !videoSliderBeingMoved ) {
246 if ( slider->value() != val ) { 236 if ( slider->value() != val ) {
247 slider->setValue( val ); 237 slider->setValue( val );
248 } 238 }
249 if ( slider->maxValue() != width ) { 239 if ( slider->maxValue() != width ) {
250 slider->setMaxValue( width ); 240 slider->setMaxValue( width );
251 } 241 }
252 } 242 }
253} 243}
254 244
255void VideoWidget::setToggleButton( int i, bool down ) { 245void VideoWidget::setToggleButton( int i, bool down ) {
256 if ( down != buttons[i].isDown ) { 246 if ( down != buttons[i].isDown ) {
257 toggleButton( i ); 247 toggleButton( i );
258 } 248 }
259} 249}
260 250
261void VideoWidget::paintButton( QPainter &p, int i ) { 251void VideoWidget::paintButton( QPainter &p, int i ) {
262 252
263 if ( buttons[i].isDown ) { 253 Button &button = buttons[ i ];
264 p.drawPixmap( upperLeftOfButtonMask, *buttonPixDown[i] ); 254
255 if ( button.isDown ) {
256 p.drawPixmap( upperLeftOfButtonMask, button.pixDown );
265 } else { 257 } else {
266 p.drawPixmap( upperLeftOfButtonMask, *buttonPixUp[i] ); 258 p.drawPixmap( upperLeftOfButtonMask, button.pixUp );
267 } 259 }
268} 260}
269 261
270void VideoWidget::mouseMoveEvent( QMouseEvent *event ) { 262void VideoWidget::mouseMoveEvent( QMouseEvent *event ) {
271 for ( unsigned int i = 0; i < buttons.count(); i++ ) { 263 for ( unsigned int i = 0; i < buttons.count(); i++ ) {
272 if ( event->state() == QMouseEvent::LeftButton ) { 264 if ( event->state() == QMouseEvent::LeftButton ) {
273 // The test to see if the mouse click is inside the button or not 265 // The test to see if the mouse click is inside the button or not
274 bool isOnButton = isOverButton( event->pos() - upperLeftOfButtonMask, i ); 266 bool isOnButton = isOverButton( event->pos() - upperLeftOfButtonMask, i );
275 267
276 if ( isOnButton && !buttons[i].isHeld ) { 268 if ( isOnButton && !buttons[i].isHeld ) {
277 buttons[i].isHeld = TRUE; 269 buttons[i].isHeld = TRUE;
278 toggleButton(i); 270 toggleButton(i);
279 271
280 switch (i) { 272 switch (i) {
281 case VideoVolUp: 273 case VideoVolUp:
282 emit moreClicked(); 274 emit moreClicked();
283 return; 275 return;
284 case VideoVolDown: 276 case VideoVolDown:
285 emit lessClicked(); 277 emit lessClicked();
286 return; 278 return;
287 } 279 }
288 } else if ( !isOnButton && buttons[i].isHeld ) { 280 } else if ( !isOnButton && buttons[i].isHeld ) {
289 buttons[i].isHeld = FALSE; 281 buttons[i].isHeld = FALSE;
290 toggleButton(i); 282 toggleButton(i);
291 } 283 }
292 } else { 284 } else {
293 285
294 if ( buttons[i].isHeld ) { 286 if ( buttons[i].isHeld ) {
295 buttons[i].isHeld = FALSE; 287 buttons[i].isHeld = FALSE;
296 if ( buttons[i].type != ToggleButton ) { 288 if ( buttons[i].type != ToggleButton ) {
297 setToggleButton( i, FALSE ); 289 setToggleButton( i, FALSE );
298 } 290 }
diff --git a/noncore/multimedia/opieplayer2/videowidget.h b/noncore/multimedia/opieplayer2/videowidget.h
index fd301f9..aeb6429 100644
--- a/noncore/multimedia/opieplayer2/videowidget.h
+++ b/noncore/multimedia/opieplayer2/videowidget.h
@@ -71,53 +71,51 @@ public slots:
71 void makeVisible(); 71 void makeVisible();
72 void backToNormal(); 72 void backToNormal();
73 void setPosition( long ); 73 void setPosition( long );
74 74
75public: 75public:
76 virtual void setPlaying( bool b); 76 virtual void setPlaying( bool b);
77 virtual void setLength( long ); 77 virtual void setLength( long );
78 virtual void setDisplayType( MediaPlayerState::DisplayType displayType ); 78 virtual void setDisplayType( MediaPlayerState::DisplayType displayType );
79 79
80signals: 80signals:
81 void moreClicked(); 81 void moreClicked();
82 void lessClicked(); 82 void lessClicked();
83 void moreReleased(); 83 void moreReleased();
84 void lessReleased(); 84 void lessReleased();
85 void sliderMoved( long ); 85 void sliderMoved( long );
86 void videoResized ( const QSize &s ); 86 void videoResized ( const QSize &s );
87 87
88protected: 88protected:
89 89
90 void resizeEvent( QResizeEvent * ); 90 void resizeEvent( QResizeEvent * );
91 void paintEvent( QPaintEvent *pe ); 91 void paintEvent( QPaintEvent *pe );
92 void showEvent( QShowEvent *se ); 92 void showEvent( QShowEvent *se );
93 void mouseMoveEvent( QMouseEvent *event ); 93 void mouseMoveEvent( QMouseEvent *event );
94 void mousePressEvent( QMouseEvent *event ); 94 void mousePressEvent( QMouseEvent *event );
95 void mouseReleaseEvent( QMouseEvent *event ); 95 void mouseReleaseEvent( QMouseEvent *event );
96 void keyReleaseEvent( QKeyEvent *e); 96 void keyReleaseEvent( QKeyEvent *e);
97 97
98private: 98private:
99// Ticker songInfo; 99// Ticker songInfo;
100 QPixmap pixBg; 100 QPixmap pixBg;
101 QImage imgUp; 101 QImage imgUp;
102 QImage imgDn; 102 QImage imgDn;
103 QPixmap *buttonPixUp[7];
104 QPixmap *buttonPixDown[7];
105 QString skin; 103 QString skin;
106 104
107 105
108 virtual void paintButton( QPainter &p, int i ); 106 virtual void paintButton( QPainter &p, int i );
109 void setToggleButton( int, bool ); 107 void setToggleButton( int, bool );
110 108
111 QString backgroundPix; 109 QString backgroundPix;
112 QSlider *slider; 110 QSlider *slider;
113 QPixmap *pixmaps[3]; 111 QPixmap *pixmaps[3];
114 QImage *currentFrame; 112 QImage *currentFrame;
115 int scaledWidth; 113 int scaledWidth;
116 int scaledHeight; 114 int scaledHeight;
117 XineVideoWidget* videoFrame; 115 XineVideoWidget* videoFrame;
118}; 116};
119 117
120#endif // VIDEO_WIDGET_H 118#endif // VIDEO_WIDGET_H
121 119
122 120
123 121