Commit 90b6e3dc authored by Srikanth Raju's avatar Srikanth Raju

Qt/ML: Pictureflow should work with VLCModel

parent 64646d3c
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
*/ */
#include "pictureflow.hpp" #include "pictureflow.hpp"
#include "components/playlist/ml_model.hpp"
// detect Qt version // detect Qt version
#if QT_VERSION < 0x040300 #if QT_VERSION < 0x040300
...@@ -144,7 +145,7 @@ public: ...@@ -144,7 +145,7 @@ public:
PFreal offsetX; PFreal offsetX;
PFreal offsetY; PFreal offsetY;
PLModel *model; VLCModel *model;
SlideInfo centerSlide; SlideInfo centerSlide;
QVector<SlideInfo> leftSlides; QVector<SlideInfo> leftSlides;
QVector<SlideInfo> rightSlides; QVector<SlideInfo> rightSlides;
...@@ -596,8 +597,8 @@ static QImage* prepareSurface(const QImage* slideImage, int w, int h, QRgb bgcol ...@@ -596,8 +597,8 @@ static QImage* prepareSurface(const QImage* slideImage, int w, int h, QRgb bgcol
imagePainter.setBrush( QBrush( Qt::lightGray ) ); imagePainter.setBrush( QBrush( Qt::lightGray ) );
imagePainter.setPen( QColor( Qt::lightGray ) ); imagePainter.setPen( QColor( Qt::lightGray ) );
QFontMetrics fm = imagePainter.fontMetrics(); QFontMetrics fm = imagePainter.fontMetrics();
imagePainter.drawText( 0, img.height()+ 13, PLModel::getMeta( index, COLUMN_TITLE ) ); imagePainter.drawText( 0, img.height()+ 13, VLCModel::getMeta( index, COLUMN_TITLE ) );
imagePainter.drawText( 0, img.height()+ 13 + fm.xHeight()*2, PLModel::getMeta( index, COLUMN_ARTIST ) ); imagePainter.drawText( 0, img.height()+ 13 + fm.xHeight()*2, VLCModel::getMeta( index, COLUMN_ARTIST ) );
/* /*
for (int x = 0; x < w; x++) for (int x = 0; x < w; x++)
for (int y = 0; y < h; y++) for (int y = 0; y < h; y++)
...@@ -614,7 +615,7 @@ QImage* PictureFlowSoftwareRenderer::surface(QModelIndex index) ...@@ -614,7 +615,7 @@ QImage* PictureFlowSoftwareRenderer::surface(QModelIndex index)
if (!state || !index.isValid()) if (!state || !index.isValid())
return 0; return 0;
QImage* img = new QImage(PLModel::getArtPixmap( index, QImage* img = new QImage(VLCModel::getArtPixmap( index,
QSize( state->slideWidth, state->slideHeight ) ).toImage()); QSize( state->slideWidth, state->slideHeight ) ).toImage());
QImage* sr = prepareSurface(img, state->slideWidth, state->slideHeight, bgcolor, state->reflectionEffect, index ); QImage* sr = prepareSurface(img, state->slideWidth, state->slideHeight, bgcolor, state->reflectionEffect, index );
...@@ -633,13 +634,33 @@ QRect PictureFlowSoftwareRenderer::renderSlide(const SlideInfo &slide, int col1, ...@@ -633,13 +634,33 @@ QRect PictureFlowSoftwareRenderer::renderSlide(const SlideInfo &slide, int col1,
QModelIndex index; QModelIndex index;
index = state->model->index( slide.slideIndex, 0, state->model->currentIndex().parent() ); QString artURL;
PLModel* plm = dynamic_cast<PLModel*>( state->model );
#ifdef MEDIA_LIBRARY
MLModel* mlm = dynamic_cast<MLModel*>( state->model );
#endif
if( plm != 0 )
{
index = ((PLModel*)state->model)->index( slide.slideIndex, 0, state->model->currentIndex().parent() );
if( !index.isValid() ) if( !index.isValid() )
return QRect(); return QRect();
PLItem *item = static_cast<PLItem*>( index.internalPointer() ); PLItem *item = static_cast<PLItem*>( index.internalPointer() );
artURL = InputManager::decodeArtURL( item->inputItem() );
}
#ifdef MEDIA_LIBRARY
else if( mlm != 0 )
{
index = ((MLModel*)state->model)->index( slide.slideIndex, 0, QModelIndex() );
if( !index.isValid() )
return QRect();
QString key = QString("%1%2%3%4").arg(PLModel::getMeta( index, COLUMN_TITLE )).arg( PLModel::getMeta( index, COLUMN_ARTIST ) ).arg(index.data( PLModel::IsCurrentRole ).toBool() ).arg( InputManager::decodeArtURL( item->inputItem() ) ); MLItem *item = static_cast<MLItem*>( index.internalPointer() );
artURL = qfu( item->getMedia()->psz_cover );
}
#endif
QString key = QString("%1%2%3%4").arg(VLCModel::getMeta( index, COLUMN_TITLE )).arg( VLCModel::getMeta( index, COLUMN_ARTIST ) ).arg(index.data( VLCModel::IsCurrentRole ).toBool() ).arg( artURL );
QImage* src; QImage* src;
if( cache.contains( key ) ) if( cache.contains( key ) )
...@@ -796,7 +817,7 @@ public: ...@@ -796,7 +817,7 @@ public:
}; };
PictureFlow::PictureFlow(QWidget* parent, PLModel* _p_model): QWidget(parent) PictureFlow::PictureFlow(QWidget* parent, VLCModel* _p_model): QWidget(parent)
{ {
d = new PictureFlowPrivate; d = new PictureFlowPrivate;
d->state = new PictureFlowState; d->state = new PictureFlowState;
......
...@@ -63,7 +63,7 @@ public: ...@@ -63,7 +63,7 @@ public:
/*! /*!
Creates a new PictureFlow widget. Creates a new PictureFlow widget.
*/ */
PictureFlow(QWidget* parent = 0, PLModel *model = 0); PictureFlow(QWidget* parent = 0, VLCModel *model = 0);
/*! /*!
Destroys the widget. Destroys the widget.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment