[Digikam-devel] extragear/libs/libkipi/libkipi
Gilles Caulier
caulier.gilles at gmail.com
Sun Feb 24 19:19:46 GMT 2008
SVN commit 778856 by cgilles:
libkipi from trunk (KDE4) : image collection selector widget is not supported as well by the library. implementation is delegate to kipi host
application to be more adapted to the host model/view used to support image collection.
For digiKam, this is want mean than the new image collection selector support fully the album/tag treeview !
http://digikam3rdparty.free.fr/Screenshots/newkipiimagecollectionselectorwidgetKDE4.png
BUG: 117073
CCMAIL: digikam-devel at kde.org
CCMAIL: kde-imaging at kde.org
M +4 -4 CMakeLists.txt
M +6 -322 imagecollectionselector.cpp
M +5 -39 imagecollectionselector.h
M +1 -1 interface.cpp
M +5 -1 interface.h
--- trunk/extragear/libs/libkipi/libkipi/CMakeLists.txt #778855:778856
@@ -4,8 +4,8 @@
SET(kipi_LIB_SRCS pluginloader.cpp interface.cpp imagecollection.cpp
imagecollectionshared.cpp imageinfoshared.cpp plugin.cpp
- imageinfo.cpp batchprogressdialog.cpp uploadwidget.cpp
- imagedialog.cpp imagecollectionselector.cpp)
+ imageinfo.cpp batchprogressdialog.cpp uploadwidget.cpp imagedialog.cpp
+ imagecollectionselector.cpp)
KDE4_ADD_LIBRARY(kipi SHARED ${kipi_LIB_SRCS})
@@ -15,7 +15,7 @@
${KDE4_KFILE_LIBS}
${QT_QTGUI_LIBRARY}
${QT_QT3SUPPORT_LIBRARY}
- ${KDE4_KDE3SUPPORT_LIBS}
+ ${KDE4_KDE3SUPPORT_LIBS}
)
SET_TARGET_PROPERTIES(kipi PROPERTIES VERSION ${KIPI_LIB_SO_VERSION_STRING} SOVERSION ${KIPI_LIB_SO_CUR_VERSION})
@@ -24,6 +24,6 @@
INSTALL(FILES interface.h plugin.h pluginloader.h imageinfo.h imagecollection.h
imageinfoshared.h imagecollectionshared.h imagedialog.h uploadwidget.h
- batchprogressdialog.h imagecollectionselector.h
+ batchprogressdialog.h imagecollectionselector.h
${CMAKE_CURRENT_BINARY_DIR}/version.h libkipi_export.h
DESTINATION ${INCLUDE_INSTALL_DIR}/libkipi)
--- trunk/extragear/libs/libkipi/libkipi/imagecollectionselector.cpp #778855:778856
@@ -3,13 +3,10 @@
* This file is a part of kipi-plugins project
* http://www.kipi-plugins.org
*
- * Date : 2004-07-01
+ * Date : 2008-02-22
* Description : image collection selector
*
- * Copyright (C) 2004-2007 by Gilles Caulier <caulier dot gilles at gmail dot com>
- * Copyright (C) 2004-2005 by Renchi Raju <renchi.raju at kdemail.net>
- * Copyright (C) 2004-2005 by Jesper K. Pedersen <blackie at kde.org>
- * Copyright (C) 2004-2005 by Aurelien Gateau <aurelien dot gateau at free.fr>
+ * Copyright (C) 2008 by Gilles Caulier <caulier dot gilles at gmail dot com>
*
* This program is free software; you can redistribute it
* and/or modify it under the terms of the GNU General
@@ -23,339 +20,26 @@
*
* ============================================================ */
-// Qt includes.
-
-#include <QPushButton>
-#include <QList>
-#include <QLabel>
-#include <Q3VGroupBox>
-#include <QTimer>
-#include <QHBoxLayout>
-#include <Q3Header>
-#include <QLayout>
-
-// KDE includes.
-
-#include <kdialog.h>
-#include <k3listview.h>
-#include <k3buttonbox.h>
-#include <klocale.h>
-#include <kglobal.h>
-#include <kio/previewjob.h>
-
// Local includes.
-#include "interface.h"
#include "imagecollectionselector.h"
#include "imagecollectionselector.moc"
namespace KIPI
{
-class ImageCollectionItem : public Q3CheckListItem
-{
-public:
-
- ImageCollectionItem(ImageCollectionSelector* selector,
- Q3ListView* parent, ImageCollection collection)
- : Q3CheckListItem( parent, collection.name(), Q3CheckListItem::CheckBox),
- _imageCollection(collection), _selector(selector)
- {}
-
- ImageCollection imageCollection() const { return _imageCollection; }
-
-protected:
-
- virtual void stateChange(bool val)
- {
- Q3CheckListItem::stateChange(val);
- _selector->emitSelectionChanged();
- }
-
-private:
-
- ImageCollection _imageCollection;
- ImageCollectionSelector* _selector;
-};
-
-struct ImageCollectionSelector::Private
-{
- Interface* _interface;
- K3ListView* _list;
- QLabel* _thumbLabel;
- QLabel* _textLabel;
- Q3ListViewItem* _itemToSelect;
-};
-
-ImageCollectionSelector::ImageCollectionSelector(QWidget* parent, Interface* interface, const char* name)
+ImageCollectionSelector::ImageCollectionSelector(QWidget* parent)
: QWidget(parent)
{
- setObjectName(name);
- d = new Private;
- d->_interface=interface;
- d->_itemToSelect = 0;
-
- d->_list=new K3ListView(this);
- d->_list->setResizeMode( Q3ListView::LastColumn );
- d->_list->addColumn("");
- d->_list->header()->hide();
-
- connect(d->_list, SIGNAL(selectionChanged(Q3ListViewItem*)),
- SLOT(slotSelectionChanged(Q3ListViewItem*)));
-
- QHBoxLayout* mainLayout=new QHBoxLayout(this);
- mainLayout->setSpacing(KDialog::spacingHint());
- mainLayout->addWidget(d->_list);
-
- QVBoxLayout* rightLayout = new QVBoxLayout();
- mainLayout->addLayout(rightLayout);
-
- K3ButtonBox* box = new K3ButtonBox(this, Qt::Vertical);
- rightLayout->addWidget(box);
- QPushButton* selectAll=box->addButton(i18n("Select All"));
- QPushButton* invertSelection=box->addButton(i18n("Invert Selection"));
- QPushButton* selectNone=box->addButton(i18n("Select None"));
- box->layout();
-
- connect(selectAll, SIGNAL(clicked()),
- this, SLOT(slotSelectAll()) );
-
- connect(invertSelection, SIGNAL(clicked()),
- this, SLOT(slotInvertSelection()) );
-
- connect(selectNone, SIGNAL(clicked()),
- this, SLOT(slotSelectNone()) );
-
- rightLayout->addItem(new QSpacerItem(10, 20, QSizePolicy::Fixed, QSizePolicy::Expanding));
-
- Q3VGroupBox* rightBox = new Q3VGroupBox(this);
- rightBox->setInsideMargin(KDialog::marginHint());
- rightBox->setInsideSpacing(KDialog::spacingHint());
- rightLayout->addWidget(rightBox);
-
- if (interface->hasFeature(AlbumsUseFirstImagePreview))
- {
- d->_thumbLabel = new QLabel(rightBox);
- d->_thumbLabel->setFixedSize(QSize(128,128));
- d->_thumbLabel->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
- }
- else
- {
- d->_thumbLabel = 0;
- }
- d->_textLabel = new QLabel(rightBox);
-
- fillList();
- QTimer::singleShot(0, this, SLOT(slotInitialShow()));
}
ImageCollectionSelector::~ImageCollectionSelector()
{
- delete d;
}
-void ImageCollectionSelector::fillList()
+QList<ImageCollection> ImageCollectionSelector::selectedImageCollections() const
{
- QList<ImageCollection> collections = d->_interface->allAlbums();
- d->_list->clear();
- ImageCollection current = d->_interface->currentAlbum();
- bool currentWasInList = false;
-
- /* note: the extensive use of blocksignals is to prevent bombarding
- the plugin with too many selection changed signals. do not remove
- them */
-
- blockSignals(true);
- for( QList<ImageCollection>::Iterator it = collections.begin() ;
- it != collections.end() ; ++it )
- {
- ImageCollectionItem* item = new ImageCollectionItem( this, d->_list, *it);
- if (!currentWasInList && *it == current)
- {
- item->setOn(true);
- currentWasInList = true;
- if (!d->_itemToSelect)
- d->_itemToSelect = item;
- }
- }
-
- if (!currentWasInList)
- {
- slotSelectAll();
- d->_itemToSelect = d->_list->firstChild();
- }
- blockSignals(false);
+ return QList<ImageCollection>();
}
-
-void ImageCollectionSelector::emitSelectionChanged()
-{
- emit selectionChanged();
-}
-
-QList<ImageCollection> ImageCollectionSelector::selectedImageCollections() const
-{
- QList<ImageCollection> list;
-
- Q3ListViewItemIterator it( d->_list );
-
- for (; it.current(); ++it)
- {
- ImageCollectionItem *item = static_cast<ImageCollectionItem*>( it.current() );
-
- if (item->isOn())
- {
- list << item->imageCollection();
- }
- }
-
- return list;
-}
-
-void ImageCollectionSelector::slotSelectAll()
-{
- Q3ListViewItemIterator it( d->_list );
-
- /* note: the extensive use of blocksignals is to prevent bombarding
- the plugin with too many selection changed signals. do not remove
- them */
- blockSignals(true);
- for (; it.current(); ++it)
- {
- ImageCollectionItem *item = static_cast<ImageCollectionItem*>( it.current() );
- item->setOn(true);
- }
- blockSignals(false);
-
- emit selectionChanged();
-}
-
-void ImageCollectionSelector::slotInvertSelection()
-{
- Q3ListViewItemIterator it( d->_list );
-
- /* note: the extensive use of blocksignals is to prevent bombarding
- the plugin with too many selection changed signals. do not remove
- them */
- blockSignals(true);
- for (; it.current(); ++it)
- {
- ImageCollectionItem *item = static_cast<ImageCollectionItem*>( it.current() );
- item->setOn(!item->isOn());
- }
- blockSignals(false);
-
- emit selectionChanged();
-}
-
-void ImageCollectionSelector::slotSelectNone()
-{
- Q3ListViewItemIterator it( d->_list );
-
- /* note: the extensive use of blocksignals is to prevent bombarding
- the plugin with too many selection changed signals. do not remove
- them */
- blockSignals(true);
- for (; it.current(); ++it)
- {
- ImageCollectionItem *item = static_cast<ImageCollectionItem*>( it.current() );
- item->setOn(false);
- }
- blockSignals(false);
-
- emit selectionChanged();
-}
-
-void ImageCollectionSelector::slotSelectionChanged(Q3ListViewItem* listItem)
-{
- if (d->_thumbLabel)
- d->_thumbLabel->clear();
- d->_textLabel->clear();
-
- if (!listItem)
- return;
-
- ImageCollectionItem* imcollItem = static_cast<ImageCollectionItem*>(listItem);
-
- if (d->_thumbLabel)
- {
- KUrl::List images(imcollItem->imageCollection().images());
- if (!images.isEmpty())
- {
- KIO::PreviewJob* thumbJob = KIO::filePreview(images.first(), 128);
- connect( thumbJob, SIGNAL(gotPreview(const K3FileItem*, const QPixmap&)),
- SLOT(slotGotPreview(const K3FileItem* , const QPixmap&)));
- }
- }
-
- // Layout the ImageCollection information nicely
-
- QString cellBeg("<tr><td><nobr><font size=-1><i>");
- QString cellMid("</i></font></nobr></td><td><font size=-1>");
- QString cellEnd("</font></td></tr>");
-
- QString text("<table cellspacing=0 cellpadding=0>");
-
- // number of images
- text += cellBeg + i18n("Images:") +
- cellMid + QString::number(imcollItem->imageCollection().images().count()) +
- cellEnd;
-
- // Optional features -------------------------------------------------------
-
- // Album Comments
- if (d->_interface->hasFeature(AlbumsHaveComments))
- {
- // Limit the comments string to 20 char...
- QString comments = imcollItem->imageCollection().comment();
- if (!comments.isEmpty())
- {
- comments.truncate(20);
- comments.append("...");
- }
-
- text += cellBeg + i18n("Caption:") +
- cellMid + comments +
- cellEnd;
- }
-
- // Album Category
- if (d->_interface->hasFeature(AlbumsHaveCategory))
- {
- text += cellBeg + i18n("Category:") +
- cellMid + imcollItem->imageCollection().category() +
- cellEnd;
- }
-
- // Album Creation Date
- if (d->_interface->hasFeature(AlbumsHaveCreationDate))
- {
- QDate date(imcollItem->imageCollection().date());
- text += cellBeg + i18n("Date:") +
- cellMid + KGlobal::locale()->formatDate(date) +
- cellEnd;
- }
-
- text += "</table>";
-
- d->_textLabel->setText(text);
-
- emit selectionChanged();
-}
-
-void ImageCollectionSelector::slotGotPreview(const K3FileItem*, const QPixmap& pix)
-{
- d->_thumbLabel->setPixmap(pix);
-}
-
-void ImageCollectionSelector::slotInitialShow()
-{
- if (d->_itemToSelect)
- {
- d->_list->setSelected(d->_itemToSelect, true);
- d->_list->ensureItemVisible(d->_itemToSelect);
- d->_itemToSelect = 0;
- }
- emit selectionChanged();
-}
-
+
} // namespace KIPI
--- trunk/extragear/libs/libkipi/libkipi/imagecollectionselector.h #778855:778856
@@ -3,13 +3,10 @@
* This file is a part of kipi-plugins project
* http://www.kipi-plugins.org
*
- * Date : 2004-07-01
+ * Date : 2008-02-22
* Description : image collection selector
*
- * Copyright (C) 2004-2007 by Gilles Caulier <caulier dot gilles at gmail dot com>
- * Copyright (C) 2004-2005 by Renchi Raju <renchi.raju at kdemail.net>
- * Copyright (C) 2004-2005 by Jesper K. Pedersen <blackie at kde.org>
- * Copyright (C) 2004-2005 by Aurelien Gateau <aurelien dot gateau at free.fr>
+ * Copyright (C) 2008 by Gilles Caulier <caulier dot gilles at gmail dot com>
*
* This program is free software; you can redistribute it
* and/or modify it under the terms of the GNU General
@@ -30,57 +27,26 @@
#include <QtGui/QWidget>
#include <QtCore/QList>
-#include <QtGui/QPixmap>
// KIPI includes.
#include "imagecollection.h"
#include "libkipi_export.h"
-class Q3ListViewItem;
-class K3FileItem;
-
namespace KIPI
{
-class Interface;
-
class LIBKIPI_EXPORT ImageCollectionSelector : public QWidget
{
Q_OBJECT
- class Private;
-
public:
- ImageCollectionSelector(QWidget* parent, Interface*, const char* name=0);
- ~ImageCollectionSelector();
+ ImageCollectionSelector(QWidget *parent=0);
+ virtual ~ImageCollectionSelector();
- QList<ImageCollection> selectedImageCollections() const;
-
-Q_SIGNALS:
-
- void selectionChanged();
-
-private Q_SLOTS:
-
- void slotSelectAll();
- void slotInvertSelection();
- void slotSelectNone();
- void slotSelectionChanged(Q3ListViewItem* listItem);
- void slotGotPreview(const K3FileItem*, const QPixmap&);
- void slotInitialShow();
-
-private:
-
- void fillList();
- void emitSelectionChanged();
- friend class ImageCollectionItem;
-
-private:
-
- Private* d;
+ virtual QList<ImageCollection> selectedImageCollections() const;
};
} // namespace KIPI
--- trunk/extragear/libs/libkipi/libkipi/interface.cpp #778855:778856
@@ -6,7 +6,7 @@
* Date : 2004-02-01
* Description : main kipi host application interface .
*
- * Copyright (C) 2004-2007 by Gilles Caulier <caulier dot gilles at gmail dot com>
+ * Copyright (C) 2004-2008 by Gilles Caulier <caulier dot gilles at gmail dot com>
* Copyright (C) 2004-2005 by Renchi Raju <renchi.raju at kdemail.net>
* Copyright (C) 2004-2005 by Jesper K. Pedersen <blackie at kde.org>
* Copyright (C) 2004-2005 by Aurelien Gateau <aurelien dot gateau at free.fr>
--- trunk/extragear/libs/libkipi/libkipi/interface.h #778855:778856
@@ -6,7 +6,7 @@
* Date : 2004-02-01
* Description : main kipi host application interface .
*
- * Copyright (C) 2004-2007 by Gilles Caulier <caulier dot gilles at gmail dot com>
+ * Copyright (C) 2004-2008 by Gilles Caulier <caulier dot gilles at gmail dot com>
* Copyright (C) 2004-2005 by Renchi Raju <renchi.raju at kdemail.net>
* Copyright (C) 2004-2005 by Jesper K. Pedersen <blackie at kde.org>
* Copyright (C) 2004-2005 by Aurelien Gateau <aurelien dot gateau at free.fr>
@@ -31,6 +31,7 @@
// Qt includes.
#include <QPixmap>
+#include <QtGui/QWidget>
#include <QtCore/QString>
#include <QtCore/QObject>
#include <QtCore/QList>
@@ -43,6 +44,7 @@
// Local includes.
#include "imagecollection.h"
+#include "imagecollectionselector.h"
#include "imageinfo.h"
#include "libkipi_export.h"
@@ -92,6 +94,8 @@
virtual void thumbnail( const KUrl& url, int size );
virtual void thumbnails( const KUrl::List& list, int size );
+ virtual ImageCollectionSelector* selector(QWidget *parent)=0;
+
bool hasFeature( KIPI::Features feature );
static QString version();
More information about the Digikam-devel
mailing list