[Bug 146083] New: bugs in drag and drop

classic Classic list List threaded Threaded
17 messages Options
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] New: bugs in drag and drop

Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
           Summary: bugs in drag and drop
           Product: digikam
           Version: unspecified
          Platform: Compiled Sources
        OS/Version: Linux
            Status: UNCONFIRMED
          Severity: normal
          Priority: NOR
         Component: Light Table
        AssignedTo: digikam-devel kde org
        ReportedBy: mikmach wp pl


Version:            (using KDE Devel)
Installed from:    Compiled sources

Strange(?) decisions in Light table.

1. Open LT with 4 images.
2. First image will be inserted in right panel. This is IMO first bug. First image should be inserted in left panel (as "master" image), second image in second panel.
3. Drag 2nd image into left panel. It will become BOTH "Master" image AND "Slave" - will be inserted automatically in right panel.
I understand what happens (you are setting Master and Slave to the same image) but it is not intuitive - took me about 5 minutes to grok what is going on...

Especially with default putting of image only in Slave panel. When user will put 2nd image into Master panel also automatically it will change contents of Slave panel.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From arnd.baecker web de  2007-07-13 20:02 -------
Created an attachment (id=21138)
 --> (http://bugs.kde.org/attachment.cgi?id=21138&action=view)
ensure visible items for both left and right panel

The attached patch addresses point 2. by putting the current
image into the left panel and the next (if it exists, or the very first)
as the right image.
The only thing which I did not succeed in is to make the currently
selected image of the thumb-bar visible (somehow the ensureItemVisible does
not work?).
Mikolaj, could you try this patch and see if it works for you
(there are different ways to populate and use the light-table, so it
is not unlikely, that one case slipped through).
Please also check point 3 of your post, if this problem is still true.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Bugzilla from mikmach@wp.pl
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From mikmach wp pl  2007-07-14 00:39 -------
> The attached patch addresses point 2. by putting the current
> image into the left panel and the next (if it exists, or the very first)
> as the right image.


Many, many thanks.

> The only thing which I did not succeed in is to make the currently
> selected image of the thumb-bar visible (somehow the ensureItemVisible
> does not work?).


Sorry, don't understand that.

> Mikolaj, could you try this patch and see if it works for you
> (there are different ways to populate and use the light-table, so it
> is not unlikely, that one case slipped through).
> Please also check point 3 of your post, if this problem is still true.


Problem here becomes even stranger: when dragging image N to the Master
position, image in Slave position is replaced with image N+1 (when N is
last image in thumb-bar N+1=1). IMO Slave image should be left
untouched.

One thing: when removing Master image its panel is left blank. IMO it is
not good solution. When someone is removing Master image from LT it is
usually because he found that Slave image is much better. I think Slave
image should be promoted to Master position and right panel should be
filled with next image.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

Re: [Bug 146083] bugs in drag and drop

Arnd Baecker
> > The only thing which I did not succeed in is to make the currently
> > selected image of the thumb-bar visible (somehow the ensureItemVisible
> > does not work?).
>
> Sorry, don't understand that.

It is a minor useability issue:
When you add new images the first and second will be placed
in left and right panel, but the item which is hightlighted in
the thumb-bar need not be visible (if there are sufficiently many
entries). I.e., I would like that the slider moves to the
position so that the hightlighted item is visible.
Normally this should work with ``ensureItemVisible'', but
it does not here ...

Problem A)
> Problem here becomes even stranger: when dragging image N to the Master
> position, image in Slave position is replaced with image N+1 (when N is
> last image in thumb-bar N+1=1). IMO Slave image should be left
> untouched.

Yes, I agree.

Problem B): Moreover, trying to replace the slave, it ends up
on both images!

Problem C):
> One thing: when removing Master image its panel is left blank. IMO it is
> not good solution. When someone is removing Master image from LT it is
> usually because he found that Slave image is much better. I think Slave
> image should be promoted to Master position and right panel should be
> filled with next image.

Makes perfect sense to me.


_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From arnd.baecker web de  2007-07-14 02:42 -------
> > The only thing which I did not succeed in is to make the currently
> > selected image of the thumb-bar visible (somehow the ensureItemVisible
> > does not work?).
>
> Sorry, don't understand that.


It is a minor useability issue:
When you add new images the first and second will be placed
in left and right panel, but the item which is hightlighted in
the thumb-bar need not be visible (if there are sufficiently many
entries). I.e., I would like that the slider moves to the
position so that the hightlighted item is visible.
Normally this should work with ``ensureItemVisible'', but
it does not here ...

Problem A)
> Problem here becomes even stranger: when dragging image N to the Master
> position, image in Slave position is replaced with image N+1 (when N is
> last image in thumb-bar N+1=1). IMO Slave image should be left
> untouched.


Yes, I agree.

Problem B): Moreover, trying to replace the slave, it ends up
on both images!

Problem C):
> One thing: when removing Master image its panel is left blank. IMO it is
> not good solution. When someone is removing Master image from LT it is
> usually because he found that Slave image is much better. I think Slave
> image should be promoted to Master position and right panel should be
> filled with next image.


Makes perfect sense to me.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
arnd.baecker web de changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
  Attachment #21138|0                           |1
        is obsolete|                            |



------- Additional Comments From arnd.baecker web de  2007-07-14 03:32 -------
Created an attachment (id=21142)
 --> (http://bugs.kde.org/attachment.cgi?id=21142&action=view)
patch which also addresses problem C)

This patch also tries to address problem C).
There are some corner cases, where it behaves non-optimal.

Warning: it may crash digikam (don't test it on an important image collection!)


Concerning problems A) and B) I have no idea what is causing this
behaviour (I don't see how my patch should be responsible, but
it has to be, because it is different from the behaviour without patch,
where fore example trying to replace the master leads to the same image
in both panels, while exchanging the slave works perfectly fine there ...)
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Bugzilla from mikmach@wp.pl
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From mikmach wp pl  2007-07-14 12:36 -------
> Problem B): Moreover, trying to replace the slave, it ends up
> on both images!

That is big turn off. While there is some (questionable IMO) logic
behind setting both images to Master it is unacceptable. :(
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Bugzilla from mikmach@wp.pl
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From mikmach wp pl  2007-07-14 12:39 -------
> This patch also tries to address problem C).
> There are some corner cases, where it behaves non-optimal.

Yes, works nicely for me. And yes, there are situations where new Slave
is strange. Here is my shot: it replaces slave with image next to old
Master. But usually this is image which was already "discarded" when
going from beginning image to image. New Slave should be get from image
next to new Master. This is all according to my comparison habits,
please comment if you (not only Arnd ;) have other experiences.
> Warning: it may crash digikam (don't test it on an important image
> collection!)

Works for me without crashes.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
arnd.baecker web de changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
  Attachment #21142|0                           |1
        is obsolete|                            |



------- Additional Comments From arnd.baecker web de  2007-07-15 13:18 -------
Created an attachment (id=21156)
 --> (http://bugs.kde.org/attachment.cgi?id=21156&action=view)
patch to address A) and B)

approach to C) is taken out at the moment - the logic
got too complicated and needs to be checked again.
Will tackle that later.
Concerning drag-and-drop (and adding via F6), with
this patch it  behaves pretty "logic" to me...
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Bugzilla from mikmach@wp.pl
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From mikmach wp pl  2007-07-15 15:46 -------
> ------- Created an attachment (id=21156)
 --> (http://bugs.kde.org/attachment.cgi?id=21156&action=view)

This patch takes care about core of bug report: no automagical replacing
of images + putting first two images of LT into panels. I am quite happy
with that and you can feel free to close this entry after applying patch
to SVN. For replacing of deleted images I will open another entry (Bug
147889).
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

Re: [Bug 146083] bugs in drag and drop

Arnd Baecker
Hi Mikolaj,

thanks a lot for testing!
Before the code is fine for inclusion,
some of the DWarning()'s have to be removed.
Also I need to think about whether the new
setLeftRightItems is necessary or can be integrated into
loadImageInfos.

Arnd

_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From arnd.baecker web de  2007-07-15 16:08 -------
Hi Mikolaj,

thanks a lot for testing!
Before the code is fine for inclusion,
some of the DWarning()'s have to be removed.
Also I need to think about whether the new
setLeftRightItems is necessary or can be integrated into
loadImageInfos.

Arnd
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
arnd.baecker web de changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
  Attachment #21156|0                           |1
        is obsolete|                            |



------- Additional Comments From arnd.baecker web de  2007-07-24 12:09 -------
Created an attachment (id=21234)
 --> (http://bugs.kde.org/attachment.cgi?id=21234&action=view)
patch to address A) and B), clean-up.

Cleaned up version of the patch. Looks ok from my side now.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Bugzilla from mikmach@wp.pl
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         




------- Additional Comments From mikmach wp pl  2007-07-24 20:30 -------
This patch solves A and B note however C is once again completely broken. When removing Master image it remains empty but Slave is replaced by image next to former Master. I understand Slave should be promoted to Master but it doesn't happen. It is removed from panels - of course remaining in thumbbar.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Arnd Baecker
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
arnd.baecker web de changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|UNCONFIRMED                 |RESOLVED
         Resolution|                            |FIXED



------- Additional Comments From arnd.baecker web de  2007-08-31 22:42 -------
SVN commit 707040 by abaecker:

ensure that left and right view of the lighttable are populated properly on F6
BUG: 146083
TODO:KDE4PORT


 M  +2 -0      digikam/albumiconview.cpp  
 M  +76 -9     utilities/lighttable/lighttablewindow.cpp  
 M  +2 -1      utilities/lighttable/lighttablewindow.h  


--- branches/extragear/kde3/graphics/digikam/digikam/albumiconview.cpp #707039:707040
 @ -1065,6 +1065,8  @
     ltview->raise();
     ltview->setFocus();
     ltview->loadImageInfos(list, current);
+    if (list.count()>1)
+        ltview->setLeftRightItems(list);
 }
 
 // ------------------------------------------------------------------------------
--- branches/extragear/kde3/graphics/digikam/utilities/lighttable/lighttablewindow.cpp #707039:707040
 @ -497,13 +497,26  @
                     false, true);
 }
 
+// Deal with items dropped onto the thumbbar (e.g. from the Album view)
 void LightTableWindow::slotThumbbarDroppedItems(const ImageInfoList& list)
 {
     loadImageInfos(list, 0);
+    if (list.count()>1)
+        setLeftRightItems(list);
 }
 
+
+// We get here either
+// - via F6 (from the albumview)
+//     a) digikamapp.cpp:  key_F6 leads to slotImageLightTable())
+//     b) digikamview.cpp: void DigikamView::slotImageLightTable()
+//          calls d->iconView->insertToLightTable(list, info);
+//     c) albumiconview.cpp: AlbumIconView::insertToLightTable
+//          calls ltview->loadImageInfos(list, current);
+// - via drag&drop, i.e. calls issued by the ...Dropped... routines
 void LightTableWindow::loadImageInfos(const ImageInfoList &list, ImageInfo *imageInfoCurrent)
 {
+
     ImageInfoList l = list;
 
     if (!imageInfoCurrent)
 @ -535,11 +548,7  @
         }
     }  
     d->barView->blockSignals(false);
-
-    LightTableBarItem *ltItem = dynamic_cast<LightTableBarItem*>(d->barView->findItemByInfo(imageInfoCurrent));
-    if (ltItem)
-        d->barView->setSelectedItem(ltItem);
-
+    
     // if window is iconified, show it
     if (isMinimized())
     {
 @ -722,30 +731,88  @
     d->previewView->checkForSelection(info);
 }    
 
+// Deal with one (or more) items dropped onto the left panel
 void LightTableWindow::slotLeftDroppedItems(const ImageInfoList& list)
 {
     ImageInfo *info = *(list.begin());
     loadImageInfos(list, info);
 
     // We will check if first item from list is already stored in thumbbar
-    // Note than thumbbar store all ImageInfo reference in memory for preview object.
+    // Note that the thumbbar stores all ImageInfo reference
+    // in memory for preview object.
     LightTableBarItem *item = d->barView->findItemByInfo(info);
-    if (item)
+    if (item)
+    {
         slotSetItemOnLeftPanel(item->info());
+        // One approach is to make this item the current one, via
+        //    d->barView->setSelectedItem(item);
+        // However, this is not good, because this also sets
+        // the right thumb to the same image.
+        // Therefore we use setLeftRightItems if there is more than
+        // one item in the list of dropped images.        
+    }
+    if (list.count()>1)
+        setLeftRightItems(list);
+
 }
 
+// Deal with one (or more) items dropped onto the right panel
 void LightTableWindow::slotRightDroppedItems(const ImageInfoList& list)
 {
     ImageInfo *info = *(list.begin());
     loadImageInfos(list, info);
+    if (list.count()>1)
+        setLeftRightItems(list);
 
     // We will check if first item from list is already stored in thumbbar
-    // Note than thumbbar store all ImageInfo reference in memory for preview object.
+    // Note that the thumbbar stores all ImageInfo reference
+    // in memory for preview object.
     LightTableBarItem *item = d->barView->findItemByInfo(info);
-    if (item)
+    if (item)
+    {
         slotSetItemOnRightPanel(item->info());
+        // Make this item the current one.
+        d->barView->setSelectedItem(item);
+    }
+
+    if (list.count()>1)
+        setLeftRightItems(list);
+
 }
 
+
+// Set the images for the left and right panel.
+void LightTableWindow::setLeftRightItems(const ImageInfoList &list)
+{
+    ImageInfoList l = list;
+
+    // Make sure that more than just one item is in the list.
+    if (l.count()<=1)
+        return;
+
+    ImageInfo *info = l.first();
+    LightTableBarItem *ltItem = dynamic_cast<LightTableBarItem*>(d->barView->findItemByInfo(info));
+
+    if (ltItem) {
+        // The first item is used for the left panel.
+        d->barView->setOnLeftPanel(info);
+        slotSetItemOnLeftPanel(info);
+
+        // The subsequent item is used for the right panel.
+        LightTableBarItem* next = dynamic_cast<LightTableBarItem*>(ltItem->next());
+        if (next)
+        {
+            d->barView->setOnRightPanel(next->info());
+            slotSetItemOnRightPanel(next->info());
+            d->barView->setSelectedItem(next);
+            // ensure that the selected item is visible
+            // FIXME: this does not work:
+            d->barView->ensureItemVisible(next);
+        }
+    }
+}
+
+
 void LightTableWindow::slotSetItemLeft()
 {
     if (d->barView->currentItemImageInfo())
--- branches/extragear/kde3/graphics/digikam/utilities/lighttable/lighttablewindow.h #707039:707040
 @ -58,6 +58,7  @
     static bool              lightTableWindowCreated();
 
     void loadImageInfos(const ImageInfoList &list, ImageInfo *imageInfoCurrent);
+    void setLeftRightItems(const ImageInfoList &list);
 
 signals:
 
 @ -100,7 +101,7  @
     void slotSetItemOnRightPanel(ImageInfo*);
     void slotLeftDroppedItems(const ImageInfoList&);
     void slotRightDroppedItems(const ImageInfoList&);
-
+    
     void slotLeftPanelLeftButtonClicked();
     void slotRightPanelLeftButtonClicked();
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Gilles Caulier-4
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
caulier.gilles gmail com changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|RESOLVED                    |UNCONFIRMED
         Resolution|FIXED                       |



------- Additional Comments From caulier.gilles gmail com  2007-09-01 17:32 -------
Arnd,

please, do not close this file until i have backported the code in KDE4. Use CCBUGS in this case, not BUG. Thanks in advance

Gilles
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Bug 146083] bugs in drag and drop

Gilles Caulier-4
In reply to this post by Bugzilla from mikmach@wp.pl
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
         
http://bugs.kde.org/show_bug.cgi?id=146083         
caulier.gilles gmail com changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|UNCONFIRMED                 |RESOLVED
         Resolution|                            |FIXED



------- Additional Comments From caulier.gilles gmail com  2007-09-04 16:07 -------
SVN commit 708316 by cgilles:

digiKam from trunk (KDE4) : backport commits #707040 from KDE3 branch
BUG: 146083


 M  +2 -0      digikam/albumiconview.cpp  
 M  +6 -0      project/project.kdevelop  
 M  +69 -8     utilities/lighttable/lighttablewindow.cpp  
 M  +1 -0      utilities/lighttable/lighttablewindow.h  


--- trunk/extragear/graphics/digikam/digikam/albumiconview.cpp #708315:708316
 @ -1057,6 +1057,8  @
     ltview->raise();
     ltview->setFocus();
     ltview->loadImageInfos(list, current);
+    if (list.count()>1)
+        ltview->setLeftRightItems(list);
 }
 
 // ------------------------------------------------------------------------------
--- trunk/extragear/graphics/digikam/project/project.kdevelop #708315:708316
 @ -150,6 +150,12  @
     <projectname>project</projectname>
     <projectname>project</projectname>
     <projectname>project</projectname>
+    <projectname>project</projectname>
+    <projectname>project</projectname>
+    <projectname>project</projectname>
+    <projectname>project</projectname>
+    <projectname>project</projectname>
+    <projectname>project</projectname>
   </general>
   <kdevfileview>
     <groups>
--- trunk/extragear/graphics/digikam/utilities/lighttable/lighttablewindow.cpp #708315:708316
 @ -497,11 +497,22  @
     createGUI("lighttablewindowui.rc");
 }
 
+// Deal with items dropped onto the thumbbar (e.g. from the Album view)
 void LightTableWindow::slotThumbbarDroppedItems(const ImageInfoList& list)
 {
     loadImageInfos(list, ImageInfo());
+    if (list.count()>1)
+        setLeftRightItems(list);
 }
 
+// We get here either
+// - via F6 (from the albumview)
+//     a) digikamapp.cpp:  key_F6 leads to slotImageLightTable())
+//     b) digikamview.cpp: void DigikamView::slotImageLightTable()
+//          calls d->iconView->insertToLightTable(list, info);
+//     c) albumiconview.cpp: AlbumIconView::insertToLightTable
+//          calls ltview->loadImageInfos(list, current);
+// - via drag&drop, i.e. calls issued by the ...Dropped... routines
 void LightTableWindow::loadImageInfos(const ImageInfoList &list, const ImageInfo &givenImageInfoCurrent)
 {
     ImageInfoList l = list;
 @ -537,10 +548,6  @
     }
     d->barView->blockSignals(false);
 
-    LightTableBarItem *ltItem = dynamic_cast<LightTableBarItem*>(d->barView->findItemByInfo(imageInfoCurrent));
-    if (ltItem)
-        d->barView->setSelectedItem(ltItem);
-
     // if window is iconified, show it
     if (isMinimized())
     {
 @ -723,30 +730,84  @
     d->previewView->checkForSelection(info);
 }
 
+// Deal with one (or more) items dropped onto the left panel
 void LightTableWindow::slotLeftDroppedItems(const ImageInfoList& list)
 {
     ImageInfo info = list.first();
     loadImageInfos(list, info);
 
     // We will check if first item from list is already stored in thumbbar
-    // Note than thumbbar store all ImageInfo reference in memory for preview object.
+    // Note that the thumbbar stores all ImageInfo reference
+    // in memory for preview object.
     LightTableBarItem *item = d->barView->findItemByInfo(info);
-    if (item)
+    if (item)
+    {
         slotSetItemOnLeftPanel(item->info());
+        // One approach is to make this item the current one, via
+        //    d->barView->setSelectedItem(item);
+        // However, this is not good, because this also sets
+        // the right thumb to the same image.
+        // Therefore we use setLeftRightItems if there is more than
+        // one item in the list of dropped images.
+    }
+    if (list.count()>1)
+        setLeftRightItems(list);
 }
 
+// Deal with one (or more) items dropped onto the right panel
 void LightTableWindow::slotRightDroppedItems(const ImageInfoList& list)
 {
     ImageInfo info = list.first();
     loadImageInfos(list, info);
+    if (list.count()>1)
+        setLeftRightItems(list);
 
     // We will check if first item from list is already stored in thumbbar
-    // Note than thumbbar store all ImageInfo reference in memory for preview object.
+    // Note that the thumbbar stores all ImageInfo reference
+    // in memory for preview object.
     LightTableBarItem *item = d->barView->findItemByInfo(info);
-    if (item)
+    if (item)
+    {
         slotSetItemOnRightPanel(item->info());
+        // Make this item the current one.
+        d->barView->setSelectedItem(item);
+    }
+    if (list.count()>1)
+        setLeftRightItems(list);
 }
 
+// Set the images for the left and right panel.
+void LightTableWindow::setLeftRightItems(const ImageInfoList &list)
+{
+    ImageInfoList l = list;
+
+    // Make sure that more than just one item is in the list.
+    if (l.count()<=1)
+        return;
+
+    ImageInfo info            = l.first();
+    LightTableBarItem *ltItem = dynamic_cast<LightTableBarItem*>(d->barView->findItemByInfo(info));
+
+    if (ltItem)
+    {
+        // The first item is used for the left panel.
+        d->barView->setOnLeftPanel(info);
+        slotSetItemOnLeftPanel(info);
+
+        // The subsequent item is used for the right panel.
+        LightTableBarItem* next = dynamic_cast<LightTableBarItem*>(ltItem->next());
+        if (next)
+        {
+            d->barView->setOnRightPanel(next->info());
+            slotSetItemOnRightPanel(next->info());
+            d->barView->setSelectedItem(next);
+            // ensure that the selected item is visible
+            // FIXME: this does not work:
+            d->barView->ensureItemVisible(next);
+        }
+    }
+}
+
 void LightTableWindow::slotSetItemLeft()
 {
     if (!d->barView->currentItemImageInfo().isNull())
--- trunk/extragear/graphics/digikam/utilities/lighttable/lighttablewindow.h #708315:708316
 @ -58,6 +58,7  @
     static bool              lightTableWindowCreated();
 
     void loadImageInfos(const ImageInfoList &list, const ImageInfo &imageInfoCurrent);
+    void setLeftRightItems(const ImageInfoList &list);
 
 signals:
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel