Worked much on the Medialib.

This commit is contained in:
Tobias Rundstrom 2006-03-06 00:34:28 -03:00
parent 28f9bd246b
commit b7d5afc0ca
18 changed files with 737 additions and 155 deletions

105
MediaAlbumList.cpp Normal file
View file

@ -0,0 +1,105 @@
#include "XMMSHandler.h"
#include "MediaAlbumList.h"
#include "qtmd5.h"
#include <QDir>
MediaAlbumList::MediaAlbumList (QWidget *parent, const QString &name) :
MedialibList (parent, name)
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
connect (xmmsh, SIGNAL (medialibResponse (uint, QList<QHash<QString, QString> >)),
this, SLOT (queryCallback (uint, QList<QHash<QString, QString> >)));
refresh ();
}
void
MediaAlbumList::refresh (void)
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
m_cid = xmmsh->medialibQuery ("select distinct ifnull(nullif(ifnull(nullif(ifnull(m3.value,0),1),'Various Artists'),0),m1.value) as artist, ifnull(m2.value,'[unknown]') as album, m4.value as art from Media m1 left join Media m2 on m1.id = m2.id and m2.key='album' left join Media m3 on m1.id = m3.id and m3.key='compilation' left join Media m4 on m4.id = m1.id and m4.key='album_front_small' where m1.key='artist' order by artist, album");
}
QStringList
MediaAlbumList::mimeTypes () const
{
QStringList types;
types << "application/mlib.album";
return types;
}
QMimeData *
MediaAlbumList::mimeData(const QList<QListWidgetItem*> items) const
{
QMimeData *mimeData = new QMimeData();
QByteArray encodedData;
MedialibListItem *it = dynamic_cast<MedialibListItem *> (currentItem ());
QDataStream stream(&encodedData, QIODevice::WriteOnly);
stream << it->getArtist ();
stream << it->getAlbum ();
mimeData->setData("application/mlib.album", encodedData);
return mimeData;
}
void
MediaAlbumList::queryCallback (uint id, QList<QHash<QString, QString> >l)
{
if (m_cid != id)
return;
clear ();
qDebug ("in query callback album");
for (int i = 0; i < l.count (); i++) {
QHash<QString, QString> h(l.value (i));
MedialibListItem *item = new MedialibListItem (h.value("artist"), h.value("album"), this);
item->setFont (m_font);
item->setTextAlignment (Qt::AlignVCenter);
if (m_noicon) {
continue;
}
item->setIcon (QIcon (":noalbum.png"));
item->setSizeHint (iconSize () + QSize (2, 2));
if (h.contains ("art")) {
QString name = qtMD5 ((h.value("artist").toLower()+"-"+h.value("album").toLower()).toUtf8());
QString fname (QDir::homePath () +"/.xmms2/clients/generic/art/"+name+"-small.jpg");
if (!QFile::exists (fname)) {
QUrl url (h.value("art"));
QFile *file = new QFile ("/tmp/"+name+"-small.jpg");
file->open(QIODevice::WriteOnly);
item->setFile (file);
m_win->addRequest (url, item);
} else {
QIcon ico (fname);
item->setIcon (ico);
}
}
}
}

24
MediaAlbumList.h Normal file
View file

@ -0,0 +1,24 @@
#ifndef __MEDIAALBUMLIST_H__
#define __MEDIAALBUMLIST_H__
class MediaAlbumList;
#include "Medialib.h"
class MediaAlbumList : public MedialibList
{
Q_OBJECT
public:
MediaAlbumList (QWidget *parent, const QString &name);
~MediaAlbumList () {}
QStringList mimeTypes (void) const;
void refresh (void);
public slots:
void queryCallback (uint, QList<QHash<QString, QString> >);
QMimeData *mimeData(const QList<QListWidgetItem*> items) const;
};
#endif

102
MediaArtistList.cpp Normal file
View file

@ -0,0 +1,102 @@
#include "XMMSHandler.h"
#include "MediaArtistList.h"
#include "qtmd5.h"
#include <QDir>
MediaArtistList::MediaArtistList (QWidget *parent, const QString &name) :
MedialibList (parent, name)
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
connect (xmmsh, SIGNAL (medialibResponse (uint, QList<QHash<QString, QString> >)),
this, SLOT (queryCallback (uint, QList<QHash<QString, QString> >)));
refresh ();
}
void
MediaArtistList::refresh (void)
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
m_cid = xmmsh->medialibQuery ("select distinct ifnull(nullif(ifnull(nullif(ifnull(m2.value,0),1),'Various Artists'),0),m1.value) as artist, m3.value as art from Media m1 left join Media m2 on m1.id = m2.id and m2.key='compilation' left join Media m3 on m3.id = m1.id and m3.key='artist_art_small' where m1.key='artist' order by artist");
}
QStringList
MediaArtistList::mimeTypes () const
{
QStringList types;
types << "application/mlib.artist";
return types;
}
QMimeData *
MediaArtistList::mimeData(const QList<QListWidgetItem*> items) const
{
QMimeData *mimeData = new QMimeData();
QByteArray encodedData;
MedialibListItem *it = dynamic_cast<MedialibListItem *> (currentItem ());
QDataStream stream(&encodedData, QIODevice::WriteOnly);
stream << it->getArtist ();
mimeData->setData("application/mlib.artist", encodedData);
return mimeData;
}
void
MediaArtistList::queryCallback (uint id, QList<QHash<QString, QString> >l)
{
if (m_cid != id)
return;
clear ();
qDebug ("in query callback artist");
for (int i = 0; i < l.count (); i++) {
QHash<QString, QString> h(l.value (i));
MedialibListItem *item = new MedialibListItem (h.value("artist"), this);
item->setFont (m_font);
item->setTextAlignment (Qt::AlignVCenter);
if (m_noicon) {
continue;
}
item->setIcon (QIcon (":noartist.png"));
item->setSizeHint (iconSize () + QSize (5, 5));
if (h.contains ("art")) {
QString name = qtMD5 ((h.value("artist").toLower()).toUtf8());
QString fname (QDir::homePath () +"/.xmms2/clients/generic/art/"+name+"-small.jpg");
if (!QFile::exists (fname)) {
QUrl url (h.value("art"));
QFile *file = new QFile ("/tmp/"+name+"-small.jpg");
file->open(QIODevice::WriteOnly);
item->setFile (file);
m_win->addRequest (url, item);
} else {
QIcon ico (fname);
item->setIcon (ico);
}
}
}
}

24
MediaArtistList.h Normal file
View file

@ -0,0 +1,24 @@
#ifndef __MEDIAARTISTLIST_H__
#define __MEDIAARTISTLIST_H__
class MediaArtistList;
#include "Medialib.h"
class MediaArtistList : public MedialibList
{
Q_OBJECT
public:
MediaArtistList (QWidget *parent, const QString &name);
~MediaArtistList () {}
QStringList mimeTypes (void) const;
void refresh (void);
public slots:
void queryCallback (uint, QList<QHash<QString, QString> >);
QMimeData *mimeData(const QList<QListWidgetItem*> items) const;
};
#endif

100
MediaSongList.cpp Normal file
View file

@ -0,0 +1,100 @@
#include "XMMSHandler.h"
#include "MediaSongList.h"
#include "qtmd5.h"
#include <QDir>
MediaSongList::MediaSongList (QWidget *parent, const QString &name) :
MedialibList (parent, name)
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
connect (xmmsh, SIGNAL (medialibResponse (uint, QList<QHash<QString, QString> >)),
this, SLOT (queryCallback (uint, QList<QHash<QString, QString> >)));
refresh ();
}
void
MediaSongList::refresh (void)
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
m_cid = xmmsh->medialibQuery ("select distinct ifnull(m1.value,'[unknown]') as artist, ifnull(m2.value,'[unknown]') as album, ifnull(m5.value,m6.value) as song, ifnull(m7.value,-1) as tracknr, m4.value as art from Media m1 left join Media m2 on m1.id = m2.id and m2.key='album' left join Media m4 on m4.id = m1.id and m4.key='album_front_small' left join Media m5 on m1.id = m5.id and m5.key='title' left join Media m6 on m1.id = m6.id and m6.key='url' left join Media m7 on m1.id = m7.id and m7.key='tracknr' where m1.key='artist' order by artist, album, tracknr, song");
}
QStringList
MediaSongList::mimeTypes () const
{
QStringList types;
types << "application/mlib.song";
return types;
}
QMimeData *
MediaSongList::mimeData(const QList<QListWidgetItem*> items) const
{
QMimeData *mimeData = new QMimeData();
QByteArray encodedData;
MedialibListItem *it = dynamic_cast<MedialibListItem *> (currentItem ());
QDataStream stream(&encodedData, QIODevice::WriteOnly);
stream << it->getArtist ();
stream << it->getAlbum ();
stream << it->getSong ();
mimeData->setData("application/mlib.song", encodedData);
return mimeData;
}
void
MediaSongList::queryCallback (uint id, QList<QHash<QString, QString> >l)
{
if (m_cid != id)
return;
qDebug ("in query callback song");
clear ();
m_win->setBusy (false);
m_win->setStatusText ("idle");
for (int i = 0; i < l.count (); i++) {
QHash<QString, QString> h(l.value (i));
MedialibListItem *item = new MedialibListItem (h.value("artist"),
h.value("album"),
h.value("song"),
this);
item->setFont (m_font);
item->setTextAlignment (Qt::AlignVCenter);
if (m_noicon) {
continue;
}
item->setIcon (QIcon (":nosong.png"));
item->setSizeHint (iconSize () + QSize (2, 2));
if (h.contains ("art")) {
QString name = qtMD5 ((h.value("artist").toLower()+"-"+h.value("album").toLower()).toUtf8());
QString fname (QDir::homePath () +"/.xmms2/clients/generic/art/"+name+"-small.jpg");
if (QFile::exists (fname)) {
QIcon ico (fname);
item->setIcon (ico);
}
}
}
}

23
MediaSongList.h Normal file
View file

@ -0,0 +1,23 @@
#ifndef __MEDIASONGLIST_H__
#define __MEDIASONGLIST_H__
class MediaSongList;
#include "Medialib.h"
class MediaSongList : public MedialibList
{
Q_OBJECT
public:
MediaSongList (QWidget *parent, const QString &name);
~MediaSongList () {}
QStringList mimeTypes (void) const;
void refresh (void);
public slots:
void queryCallback (uint, QList<QHash<QString, QString> >);
QMimeData *mimeData(const QList<QListWidgetItem*> items) const;
};
#endif

View file

@ -8,6 +8,10 @@
#include <QSettings>
#include "qtmd5.h"
#include "MediaArtistList.h"
#include "MediaAlbumList.h"
#include "MediaSongList.h"
MedialibWindow::MedialibWindow (QWidget *parent) : QMainWindow (parent)
{
#ifndef _WIN32
@ -15,6 +19,8 @@ MedialibWindow::MedialibWindow (QWidget *parent) : QMainWindow (parent)
#endif
setWindowTitle ("Promoe - Medialib Window");
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
QSettings s;
s.beginGroup ("medialib");
@ -43,11 +49,36 @@ MedialibWindow::MedialibWindow (QWidget *parent) : QMainWindow (parent)
m_status->setFrameStyle (QFrame::NoFrame);
statusBar ()->addPermanentWidget (m_status, 2);
m_list = new MedialibList (this);
m_tab->addTab (new QWidget (), tr ("Artists"));
m_tab->addTab (m_list, tr ("Albums"));
m_tab->addTab (new QWidget (), tr ("Songs"));
/*** Init views ***/
QDir dir (QDir::homePath ()+"/.xmms2/clients/generic/art/");
if (!dir.exists()) {
dir.mkpath (dir.path ());
}
m_http = new QHttp (this);
connect (m_http, SIGNAL (requestFinished (int, bool)), this,
SLOT (httpDone (int, bool)));
/*** artist ***/
m_artist = new MediaArtistList (this, "artist");
m_tab->addTab (m_artist, tr ("Artists"));
connect (m_search, SIGNAL (textEdited (QString)),
m_artist, SLOT (search (QString)));
/*** album ***/
m_album = new MediaAlbumList (this, "album");
m_tab->addTab (m_album, tr ("Albums"));
connect (m_search, SIGNAL (textEdited (QString)),
m_album, SLOT (search (QString)));
/*** song ***/
m_song = new MediaSongList (this, "song");
m_tab->addTab (m_song, tr ("Songs"));
connect (m_search, SIGNAL (textEdited (QString)),
m_song, SLOT (search (QString)));
/*** set active view from config ***/
for (int i = 0; i < m_tab->count() ; i++) {
if (s.value("selected").toString () == m_tab->tabText (i)) {
m_tab->setCurrentIndex (i);
@ -57,60 +88,46 @@ MedialibWindow::MedialibWindow (QWidget *parent) : QMainWindow (parent)
s.endGroup ();
connect (m_search, SIGNAL (textEdited (QString)), m_list, SLOT (search (QString)));
}
setBusy (true);
setStatusText ("Loading medialib");
MedialibList::MedialibList (QWidget *parent) : QListWidget ()
{
XMMSHandler *xmmsh = XMMSHandler::getInstance ();
m_http = new QHttp (this);
m_httpmap = new QHash<int, MedialibListItem *>;
m_win = dynamic_cast<MedialibWindow*> (parent);
setIconSize (QSize (85, 85));
setDragEnabled (true);
QDir dir (QDir::homePath ()+"/.xmms2/clients/generic/art/");
if (!dir.exists()) {
dir.mkpath (dir.path ());
}
xmmsh->medialibQuery ("select distinct ifnull(nullif(ifnull(nullif(ifnull(m3.value,0),1),'Various Artists'),0),m1.value) as artist, ifnull(m2.value,'[unknown]') as album, m4.value as image from Media m1 left join Media m2 on m1.id = m2.id and m2.key='album' left join Media m3 on m1.id = m3.id and m3.key='compilation' left join Media m4 on m4.id = m1.id and m4.key='album_front_small' where m1.key='artist' order by artist, album");
connect (xmmsh, SIGNAL (medialibResponse (QList<QHash<QString, QString> >)),
this, SLOT (queryCallback (QList<QHash<QString, QString> >)));
connect (m_http, SIGNAL (requestFinished (int, bool)), this,
SLOT (httpDone (int, bool)));
m_win->setBusy (true);
m_win->setStatusText ("Loading album view");
connect (xmmsh, SIGNAL (settingsSaved ()), this, SLOT (settingsSaved ()));
}
void
MedialibList::search (QString s)
MedialibWindow::settingsSaved ()
{
if (s.length () > 0) {
for (int i = 0; i < count (); i++) {
MedialibListItem *it = dynamic_cast<MedialibListItem*> (item (i));
if (!it->text().contains (s, Qt::CaseInsensitive)) {
setItemHidden (it, true);
} else if (isItemHidden (it)) {
setItemHidden (it, false);
}
}
m_artist->setSizes();
m_album->setSizes();
m_song->setSizes();
} else {
for (int i = 0; i < count (); i++) {
MedialibListItem *it = dynamic_cast<MedialibListItem*> (item (i));
setItemHidden (it, false);
}
}
setBusy (true);
setStatusText ("Refreshing medialib");
m_artist->refresh();
m_album->refresh();
m_song->refresh();
update ();
}
void
MedialibList::httpDone (int id, bool error)
MedialibWindow::addRequest (QUrl url, MedialibListItem *item)
{
m_http->setHost (url.host (), url.port () != 1 ? url.port () : 80);
if (!url.userName().isEmpty()) {
m_http->setUser (url.userName(), url.password());
}
int id = m_http->get (url.path (), item->getFile ());
m_httpmap->insert (id, item);
qDebug ("add request %s (%d)", qPrintable (url.path ()), id);
}
void
MedialibWindow::httpDone (int id, bool error)
{
if (error) {
qWarning ("error!");
@ -137,11 +154,11 @@ MedialibList::httpDone (int id, bool error)
delete f;
m_httpmap->remove (id);
if (m_httpmap->count () == 0) {
m_win->setBusy (false);
m_win->setStatusText ("idle");
setBusy (false);
setStatusText ("idle");
} else {
m_win->setBusy (m_httpmap->count ());
m_win->setStatusText ("Got art for: " + it->text());
setBusy (m_httpmap->count ());
setStatusText ("Got art for: " + it->text());
}
}
@ -149,84 +166,67 @@ MedialibList::httpDone (int id, bool error)
}
QStringList
MedialibList::mimeTypes () const
MedialibList::MedialibList (QWidget *parent, const QString &name) : QListWidget ()
{
QStringList types;
types << "application/mlib.album";
return types;
m_win = dynamic_cast<MedialibWindow*> (parent);
setDragEnabled (true);
m_name = name;
setSizes ();
}
QMimeData *
MedialibList::mimeData(const QList<QListWidgetItem*> items) const
{
QMimeData *mimeData = new QMimeData();
QByteArray encodedData;
MedialibListItem *it = dynamic_cast<MedialibListItem *> (currentItem ());
QDataStream stream(&encodedData, QIODevice::WriteOnly);
stream << it->getArtist ();
stream << it->getAlbum ();
mimeData->setData("application/mlib.album", encodedData);
return mimeData;
}
void
MedialibList::queryCallback (QList<QHash<QString, QString> >l)
MedialibList::setSizes (void)
{
QFont font;
font.setPixelSize (14);
m_win->setBusy (false);
m_win->setStatusText ("idle");
for (int i = 0; i < l.count (); i++) {
QHash<QString, QString> h(l.value (i));
MedialibListItem *item = new MedialibListItem (h.value("artist"), h.value("album"), this);
item->setSizeHint (QSize (90, 90));
item->setIcon (QIcon (":nocover.png"));
item->setFont (font);
item->setTextAlignment (Qt::AlignVCenter);
if (h.contains ("image")) {
QString name = qtMD5 ((h.value("artist").toLower()+"-"+h.value("album").toLower()).toUtf8());
QString fname (QDir::homePath () +"/.xmms2/clients/generic/art/"+name+"-small.jpg");
if (!QFile::exists (fname)) {
QUrl url (h.value("image"));
m_http->setHost (url.host(), url.port() != -1 ? url.port() : 80);
if (!url.userName().isEmpty()) {
m_http->setUser (url.userName(), url.password());
}
QFile *file = new QFile ("/tmp/"+name+"-small.jpg");
file->open(QIODevice::WriteOnly);
item->setFile (file);
int id = m_http->get (url.path(), file);
m_httpmap->insert (id, item);
} else {
QIcon ico (fname);
item->setIcon (ico);
}
}
QSettings s;
s.beginGroup ("medialib_"+m_name);
if (!s.contains ("size")) {
s.setValue ("size", tr ("Large"));
}
QString size = s.value("size").toString ();
m_noicon = false;
if (m_httpmap->count() > 0) {
m_win->setBusy (0, m_httpmap->count ());
m_win->setStatusText ("Loading album art");
if (size == tr ("Small")) {
setIconSize (QSize (42, 42));
m_font.setPixelSize (10);
} else if (size == tr ("Large")) {
setIconSize (QSize (85, 85));
m_font.setPixelSize (14);
} else if (size == tr ("None")) {
setIconSize (QSize (10, 10));
m_noicon = true;
m_font.setPixelSize (10);
}
}
void
MedialibList::search (const QString &s)
{
if (s.length () > 0) {
for (int i = 0; i < count (); i++) {
MedialibListItem *it = dynamic_cast<MedialibListItem*> (item (i));
if (!it->text().contains (s, Qt::CaseInsensitive)) {
setItemHidden (it, true);
} else if (isItemHidden (it)) {
setItemHidden (it, false);
}
}
} else {
for (int i = 0; i < count (); i++) {
MedialibListItem *it = dynamic_cast<MedialibListItem*> (item (i));
setItemHidden (it, false);
}
}
}

View file

@ -13,48 +13,75 @@
#include <QLabel>
#include <QHttp>
#include <QFile>
#include <QUrl>
class MedialibWindow;
class MedialibListItem : public QListWidgetItem
{
public:
MedialibListItem (QString artist, QString album, QListWidget *parent) :
MedialibListItem (const QString &artist, const QString &album,
const QString &song, QListWidget *parent) :
QListWidgetItem (artist + " - " + song, parent) {
m_artist = artist;
m_album = album;
m_song = song;
}
MedialibListItem (const QString &artist, const QString &album,
QListWidget *parent) :
QListWidgetItem (artist + " - " + album, parent) {
m_artist = artist;
m_album = album;
}
MedialibListItem (const QString &artist, QListWidget *parent) :
QListWidgetItem (artist, parent) {
m_artist = artist;
}
~MedialibListItem () {}
void setFile (QFile *f) { m_file = f; }
QFile *getFile (void) { return m_file; }
QString getArtist (void) { return m_artist; }
QString getAlbum (void) { return m_album; }
QString getSong (void) { return m_song; }
private:
QFile *m_file;
QString m_artist;
QString m_album;
QString m_song;
};
class MedialibList : public QListWidget
{
Q_OBJECT
public:
MedialibList (QWidget *parent);
MedialibList (QWidget *parent, const QString &name);
~MedialibList () {}
QStringList mimeTypes (void) const;
void setSizes (void);
void refresh (void) {}
/*
QStringList mimeTypes (void) const {};
*/
public slots:
void queryCallback (QList<QHash<QString, QString> >);
void httpDone (int, bool);
void search (QString);
QMimeData *mimeData(const QList<QListWidgetItem*> items) const;
/*
void queryCallback (uint, QList<QHash<QString, QString> >) {};
QMimeData *mimeData(const QList<QListWidgetItem*> items) const {};
*/
void search (const QString &);
protected:
uint m_cid;
QFont m_font;
MedialibWindow *m_win;
bool m_noicon;
private:
QHash<int, MedialibListItem*> *m_httpmap;
QHttp *m_http;
MedialibWindow *m_win;
int m_httpr;
QString m_name;
};
@ -74,17 +101,26 @@ class MedialibWindow : public QMainWindow
m_progress->reset ();
}
}
void setBusy (int min, int max) {
m_progress->setMaximum (max);
m_progress->setMinimum (min);
}
void setBusy (int cur) {
m_progress->setValue (cur);
}
void setStatusText (QString s) {
m_status->setText (s);
}
void addRequest (QUrl url, MedialibListItem *item);
public slots:
void httpDone (int, bool);
void settingsSaved (void);
private:
QWidget *m_dummy;
QTabWidget *m_tab;
@ -92,7 +128,12 @@ class MedialibWindow : public QMainWindow
QVBoxLayout *m_vbox;
QProgressBar *m_progress;
QLabel *m_status;
MedialibList *m_list;
MedialibList *m_artist;
MedialibList *m_album;
MedialibList *m_song;
QHash<int, MedialibListItem*> *m_httpmap;
QHttp *m_http;
};
#endif

View file

@ -343,7 +343,7 @@ PlaylistList::mouseMoveEvent (QMouseEvent *event)
m_items->removeAt (i);
m_selected->clear ();
Qt::DropAction drop = m_drag->start ();
m_drag->start ();
}
}
@ -353,23 +353,10 @@ PlaylistList::dragEnterEvent (QDragEnterEvent *event)
{
if (event->mimeData()->hasFormat("application/mlib.album") ||
event->mimeData()->hasFormat("application/mlib.artist") ||
event->mimeData()->hasFormat("application/mlib.song") ||
event->mimeData()->hasFormat("application/playlist.move"))
event->acceptProposedAction();
/*
const QMimeData *md = event->mimeData ();
QByteArray encodedData = md->data("application/mlib.album");
QDataStream stream(&encodedData, QIODevice::ReadOnly);
QString artist;
QString album;
stream >> artist;
stream >> album;
qDebug ("korv %s - %s", qPrintable (artist),
qPrintable (album));
event->accept ();
*/
}
void
@ -427,6 +414,41 @@ PlaylistList::dropEvent (QDropEvent *event)
xmmsh->medialibQueryAdd (query);
event->acceptProposedAction ();
} else if (event->mimeData()->hasFormat("application/mlib.artist")) {
const QMimeData *md = event->mimeData ();
QByteArray encodedData = md->data("application/mlib.artist");
QDataStream stream(&encodedData, QIODevice::ReadOnly);
QString artist;
stream >> artist;
QString query;
if (artist == "Various Artists") {
query.sprintf ("select m1.id as id, m2.value as album, ifnull(m3.value,-1) as tracknr from Media m1 left join Media m2 on m1.id = m2.id and m2.key='album' left join Media m3 on m1.id = m3.id and m3.key='tracknr' where m1.key='compilation' and m1.value=1 order by album, tracknr;");
} else {
query.sprintf ("select m1.id as id, m2.value as album, ifnull(m3.value,-1) as tracknr from Media m1 left join Media m2 on m1.id = m2.id and m2.key='album' left join Media m3 on m1.id = m3.id and m3.key='tracknr' where m1.key='artist' and m1.value='%s' order by album, tracknr", artist.toUtf8 ().data ());
}
xmmsh->medialibQueryAdd (query);
event->acceptProposedAction ();
} else if (event->mimeData()->hasFormat("application/mlib.song")) {
const QMimeData *md = event->mimeData ();
QByteArray encodedData = md->data("application/mlib.song");
QDataStream stream(&encodedData, QIODevice::ReadOnly);
QString artist;
QString album;
QString song;
stream >> artist;
stream >> album;
stream >> song;
QString query;
query.sprintf ("select m1.id as id, ifnull(m1.value, '[unknown]') as artist, ifnull(m2.value,'[unknown]') as album, ifnull(m4.value,m5.value) as song from Media m1 left join Media m2 on m1.id = m2.id and m2.key='album' left join Media m4 on m1.id = m4.id and m4.key='title' left join Media m5 on m1.id = m5.id and m5.key='url' where m1.key='artist' and artist='%s' and album='%s' and song='%s'", artist.toUtf8 ().data (), album.toUtf8 ().data (), song.toUtf8 ().data ());
xmmsh->medialibQueryAdd (query);
event->acceptProposedAction ();
}
m_bar = -2;

View file

@ -61,6 +61,18 @@ SettingsTabMedialib::SettingsTabMedialib (QWidget *parent) : QWidget (parent)
{
QSettings s;
if (!s.contains ("medialib_artist/size")) {
s.setValue ("medialib_artist/size", tr ("Large"));
}
if (!s.contains ("medialib_album/size")) {
s.setValue ("medialib_album/size", tr ("Large"));
}
if (!s.contains ("medialib_song/size")) {
s.setValue ("medialib_song/size", tr ("Large"));
}
s.beginGroup("medialib");
QWidget *dummy = new QWidget (this);
@ -87,7 +99,121 @@ SettingsTabMedialib::SettingsTabMedialib (QWidget *parent) : QWidget (parent)
h->addWidget (m_selected);
QLabel *l = new QLabel (tr ("Selected tab on startup"), c);
h->addWidget (l, 1);
s.endGroup ();
c = new QWidget (dummy);
h = new QHBoxLayout (c);
vbox->addWidget (c, 1);
s.beginGroup ("medialib_artist");
l = new QLabel (tr ("Artist view"), c);
QFrame *f = new QFrame (c);
f->setFrameStyle (QFrame::HLine | QFrame::Raised);
h->addWidget (l);
h->addWidget (f, 1);
c = new QWidget (dummy);
h = new QHBoxLayout (c);
vbox->addWidget (c, 1);
m_artistsize = new QComboBox (c);
m_artistsize->addItem (tr ("None"));
m_artistsize->addItem (tr ("Small"));
m_artistsize->addItem (tr ("Large"));
m_artistsize->setEditable (false);
curr = s.value ("size").toString ();
for (int i = 0; i < m_artistsize->count(); i++) {
if (m_artistsize->itemText (i) == curr) {
m_artistsize->setCurrentIndex (i);
break;
}
}
h->addWidget (m_artistsize);
l = new QLabel (tr ("Size of media art icon"), c);
h->addWidget (l, 1);
s.endGroup ();
c = new QWidget (dummy);
h = new QHBoxLayout (c);
vbox->addWidget (c, 1);
s.beginGroup ("medialib_album");
l = new QLabel (tr ("Album view"), c);
f = new QFrame (c);
f->setFrameStyle (QFrame::HLine | QFrame::Raised);
h->addWidget (l);
h->addWidget (f, 1);
c = new QWidget (dummy);
h = new QHBoxLayout (c);
vbox->addWidget (c, 1);
m_albumsize = new QComboBox (c);
m_albumsize->addItem (tr ("None"));
m_albumsize->addItem (tr ("Small"));
m_albumsize->addItem (tr ("Large"));
m_albumsize->setEditable (false);
curr = s.value ("size").toString ();
for (int i = 0; i < m_artistsize->count(); i++) {
if (m_albumsize->itemText (i) == curr) {
m_albumsize->setCurrentIndex (i);
break;
}
}
h->addWidget (m_albumsize);
l = new QLabel (tr ("Size of media art icon"), c);
h->addWidget (l, 1);
s.endGroup ();
c = new QWidget (dummy);
h = new QHBoxLayout (c);
vbox->addWidget (c, 1);
s.beginGroup ("medialib_song");
l = new QLabel (tr ("Song view"), c);
f = new QFrame (c);
f->setFrameStyle (QFrame::HLine | QFrame::Raised);
h->addWidget (l);
h->addWidget (f, 1);
c = new QWidget (dummy);
h = new QHBoxLayout (c);
vbox->addWidget (c, 1);
m_songsize = new QComboBox (c);
m_songsize->addItem (tr ("None"));
m_songsize->addItem (tr ("Small"));
m_songsize->addItem (tr ("Large"));
m_songsize->setEditable (false);
curr = s.value ("size").toString ();
for (int i = 0; i < m_artistsize->count(); i++) {
if (m_songsize->itemText (i) == curr) {
m_songsize->setCurrentIndex (i);
break;
}
}
h->addWidget (m_songsize);
l = new QLabel (tr ("Size of media art icon"), c);
h->addWidget (l, 1);
s.endGroup ();
@ -99,6 +225,9 @@ SettingsTabMedialib::saveSettings ()
{
QSettings s;
s.setValue ("medialib/selected", m_selected->currentText ());
s.setValue ("medialib_artist/size", m_artistsize->currentText ());
s.setValue ("medialib_album/size", m_albumsize->currentText ());
s.setValue ("medialib_song/size", m_songsize->currentText ());
}
SettingsTabPlaylist::SettingsTabPlaylist (QWidget *parent) : QWidget (parent)

View file

@ -20,6 +20,9 @@ class SettingsTabMedialib : public QWidget {
private:
QComboBox *m_selected;
QComboBox *m_artistsize;
QComboBox *m_albumsize;
QComboBox *m_songsize;
};
class SettingsTabPlaylist : public QWidget {

View file

@ -261,11 +261,12 @@ XMMSHandler::PropDictToQHash (XMMSResultDict *res)
return h;
}
void
uint
XMMSHandler::medialibQuery (QString q)
{
XMMSResultDictList *r = m_xmmsc->medialib_select (q.toUtf8 ());
r->connect (sigc::mem_fun (this, &XMMSHandler::medialib_select));
return r->getCID ();
}
void
@ -278,7 +279,7 @@ XMMSHandler::medialib_select (XMMSResultDictList *res)
l.append (h);
}
emit medialibResponse (l);
emit medialibResponse (res->getCID (), l);
}
void

View file

@ -31,7 +31,7 @@ class XMMSHandler : public QObject, public sigc::trackable {
void playlistClear (void);
void playlistRemove (uint pos) { delete m_xmmsc->playlist_remove (pos); }
void playlistMove (uint pos, uint newpos) { delete m_xmmsc->playlist_move (pos, newpos); }
void medialibQuery (QString);
uint medialibQuery (QString);
void medialibQueryAdd (QString q) { delete m_xmmsc->medialib_add_to_playlist (q.toUtf8 ()); }
const XMMSClient *getXMMS () { return m_xmmsc; }
@ -63,7 +63,7 @@ class XMMSHandler : public QObject, public sigc::trackable {
void playlistList (QList<uint>);
void currentID (uint);
void playlistChanged (QHash<QString, QString>);
void medialibResponse (QList<QHash<QString, QString> >);
void medialibResponse (uint, QList<QHash<QString, QString> >);
private:
XmmsQT4 *m_qt4;

BIN
noalbum.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.2 KiB

BIN
noartist.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.2 KiB

BIN
nosong.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.2 KiB

View file

@ -20,7 +20,10 @@ SOURCES += XmmsQT4.cpp \
PlaylistShade.cpp \
Medialib.cpp \
qtmd5.cpp \
SettingsWindow.cpp
SettingsWindow.cpp \
MediaArtistList.cpp \
MediaAlbumList.cpp \
MediaSongList.cpp
HEADERS += XmmsQT4.h \
PixWidget.h \
@ -44,7 +47,10 @@ HEADERS += XmmsQT4.h \
PlaylistShade.h \
Medialib.h \
qtmd5.h \
SettingsWindow.h
SettingsWindow.h \
MediaArtistList.h \
MediaAlbumList.h \
MediaSongList.h
RESOURCES = promoe.qrc

View file

@ -1,7 +1,9 @@
<!DOCTYPE RCC><RCC version="1.0">
<qresource>
<file>icon.png</file>
<file>nocover.png</file>
<file>noartist.png</file>
<file>nosong.png</file>
<file>noalbum.png</file>
<file>CleanAMP/Eq_ex.png</file>
<file>CleanAMP/GENEX.png</file>
<file>CleanAMP/Gen.png</file>