[Bug 115423] New: thumbnails view jumps to top when new photos are added

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

[Bug 115423] New: thumbnails view jumps to top when new photos are added

Bugzilla from wbsoft@xs4all.nl
------- 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=115423         
           Summary: thumbnails view jumps to top when new photos are added
           Product: digikam
           Version: 0.8.0-beta2
          Platform: unspecified
        OS/Version: Linux
            Status: NEW
          Severity: normal
          Priority: NOR
         Component: general
        AssignedTo: digikam-devel kde org
        ReportedBy: wbsoft xs4all nl


Version:           0.8.0-beta2 (using KDE 3.4.92 (beta2, >= 20051010), Gentoo)
Compiler:          gcc version 3.3.5-20050130 (Gentoo Linux 3.3.5.20050130-r1, ssp-3.3.5.20050130-1, pie-8.7.7.1)
OS:                Linux (i686) release 2.6.11-gentoo-r1

I use to look at the thumbnail view while photos are downloading, and click on them as they appear.

Since 0.8.0 however the thumbnail view jumps to the top each time a new photo is added at the bottom.

Which makes it difficult to do anything in the thumbnail view until all photos are downloaded.

It would be nice if the thumbnail view would not jump to the top when pictures are added.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Bugzilla from tomalbers@kde.nl
------- 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=115423         
tomalbers kde nl changed:

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

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Bugzilla from wbsoft@xs4all.nl
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         




------- Additional Comments From wbsoft xs4all nl  2006-02-04 23:16 -------
I should correct: the thumbnail view jumps to where the selected thumbnail cursor is (which changes by using the arrow keys or pgup/pgdn). When I scroll using the mouse(wheel) or scrollbar, the view is scrolled back to the cursor position as soon as an image is added.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Bugzilla from tomalbers@kde.nl
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         




------- Additional Comments From tomalbers kde nl  2006-02-04 23:30 -------
Then the question is if we should change that behaviour.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Gilles Caulier
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         




------- Additional Comments From caulier.gilles free fr  2006-02-05 00:21 -------
yes, i can reproduce it. I'm a  little bit irritated about (:=))) I  love checked the image in main interface during long download.

Just my  viewpoint

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

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Tung NGUYEN
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         




------- Additional Comments From ntung free fr  2006-02-06 13:01 -------
Tom,

I think you can close this bug report with WONTFIX.

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

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Bugzilla from wbsoft@xs4all.nl
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         




------- Additional Comments From wbsoft xs4all nl  2006-02-06 13:17 -------
Can't just the behaviour be changed so that adding a photo to the thumbnail view does not scroll the view at all (just like it was in the 0.6 and 0.7 series)? Just like in Konqueror when a file is created in a directory. The new file just appears and does not scroll or change the view in any way.
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel
Reply | Threaded
Open this post in threaded view
|

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Gilles Caulier
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         




------- Additional Comments From caulier.gilles free fr  2006-02-06 16:01 -------
I'm fully agree with Wilbert. It's a bug relevant of an ensure item visible of digiKam album item view. This is can (and must) be easily fixed...

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

[Digikam-devel] [Bug 115423] thumbnails view jumps to top when new photos are added

Marcel Wiesweg
In reply to this post by Bugzilla from wbsoft@xs4all.nl
------- 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=115423         
marcel.wiesweg gmx de changed:

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



------- Additional Comments From marcel.wiesweg gmx de  2006-04-23 21:45 -------
SVN commit 533143 by mwiesweg:

IconView:
- Store position of currently first visible item,
  and set this item again to be the first visible item
  after an update
- fine-tune findFirstVisibleItem a bit, optionally only use
  the first item of which the thumbnail (rather than part of the border)
  is visible, add overloaded convenience methods to find first item
  of current viewport

BUG: 115423



 M  +72 -19    iconview.cpp  
 M  +4 -2      iconview.h  


--- trunk/extragear/graphics/digikam/digikam/iconview.cpp #533142:533143
 @ -63,6 +63,7  @
         lastGroup      = 0;
         currItem       = 0;
         anchorItem     = 0;
+        firstVisibleItem = 0;
         clearing       = false;
         spacing        = 10;
 
 @ -99,6 +100,7  @
     IconItem*          toolTipItem;
     IconItem*          currItem;
     IconItem*          anchorItem;
+    IconItem*          firstVisibleItem; // store position for slotUpdate
     
     IconGroupItem*     firstGroup;
     IconGroupItem*     lastGroup;
 @ -393,6 +395,7  @
         d->lastGroup         = group;
     }
 
+    d->firstVisibleItem = findFirstVisibleItem();
     d->updateTimer->start(0, true);
 }
 
 @ -401,21 +404,28  @
     if (!group)
         return;
 
-    if (group == d->firstGroup)
+    // this is only to find an alternative visible item if all visible items
+    // are removed
+    IconGroupItem *alternativeVisibleGroup = 0;
+    d->firstVisibleItem = 0;
+
+    if (group == d->firstGroup)
     {
         d->firstGroup = d->firstGroup->m_next;
         if (d->firstGroup)
             d->firstGroup->m_prev = 0;
         else
             d->firstGroup = d->lastGroup = 0;
+        alternativeVisibleGroup = d->firstGroup;
     }
     else if (group == d->lastGroup)
     {
         d->lastGroup = d->lastGroup->m_prev;
         if ( d->lastGroup )
-    d->lastGroup->m_next = 0;
+            d->lastGroup->m_next = 0;
         else
             d->firstGroup = d->lastGroup = 0;
+        alternativeVisibleGroup = d->lastGroup->m_prev;
     }
     else
     {
 @ -426,11 +436,22  @
                 i->m_prev->m_next = i->m_next;
             if ( i->m_next )
                 i->m_next->m_prev = i->m_prev;
+
+            if (i->m_prev)
+                alternativeVisibleGroup = i->m_prev;
+            else
+                alternativeVisibleGroup = i->m_next;
         }
     }
 
     if (!d->clearing)
     {
+        d->firstVisibleItem = findFirstVisibleItem();
+        if (!d->firstVisibleItem && alternativeVisibleGroup)
+        {
+            // find an alternative visible item
+            d->firstVisibleItem = alternativeVisibleGroup->lastItem();
+        }
         d->updateTimer->start(0, true);
     }
 }
 @ -440,6 +461,7  @
     if (!item)
         return;
 
+    d->firstVisibleItem = findFirstVisibleItem();
     d->updateTimer->start(0, true);
 }
 
 @ -478,13 +500,17  @
     
     if (!d->clearing)
     {
+        d->firstVisibleItem = findFirstVisibleItem();
+        if (d->firstVisibleItem == item)
+            d->firstVisibleItem = d->currItem;
         d->updateTimer->start(0, true);
     }
 }
 
 void IconView::triggerUpdate()
 {
-    d->updateTimer->start(0, true);    
+    d->firstVisibleItem = findFirstVisibleItem();
+    d->updateTimer->start(0, true);
 }
 
 void IconView::sort()
 @ -534,7 +560,14  @
     }
     
     delete [] groups;
+}
 
+void IconView::slotUpdate()
+{
+    sort();
+    rearrangeItems();
+
+    // ensure there is a current item
     if (!d->currItem)
     {
         // set the currItem to first item
 @ -546,14 +579,20  @
     if (d->currItem)
     {
         d->currItem->setSelected(true, true);
+    }
+
+    // set first visible item if they where stored before update was triggered
+    if (d->firstVisibleItem)
+    {
+        ensureItemVisible(d->firstVisibleItem);
+        // reset to 0
+        d->firstVisibleItem = 0;
+    }
+    else
+    {
         ensureItemVisible(d->currItem);
     }
-}
 
-void IconView::slotUpdate()
-{
-    sort();
-    rearrangeItems();
     viewport()->update();
 }
 
 @ -1526,13 +1565,13  @
             {
                 QRect r( 0, d->currItem->y() + visibleHeight(),
                         contentsWidth(), visibleHeight() );
-                IconItem *ni = findFirstVisibleItem(r);
+                IconItem *ni = findFirstVisibleItem(r, false);
     
                 if (!ni)
                 {
                     r = QRect( 0, d->currItem->y() + itemRect().height(),
                               contentsWidth(), contentsHeight() );
-                    ni = findLastVisibleItem( r );
+                    ni = findLastVisibleItem(r, false);
                 }
     
                 if (ni)
 @ -1567,12 +1606,12  @
                 QRect r(0, d->currItem->y() - visibleHeight(),
                         contentsWidth(), visibleHeight() );
     
-                IconItem *ni = findFirstVisibleItem(r);
+                IconItem *ni = findFirstVisibleItem(r, false);
     
                 if (!ni)
                 {
                     r = QRect( 0, 0, contentsWidth(), d->currItem->y() );
-                    ni = findFirstVisibleItem( r );
+                    ni = findFirstVisibleItem(r, false);
                 }
     
                 if (ni)
 @ -1657,8 +1696,20  @
     }
 }
 
-IconItem* IconView::findFirstVisibleItem(const QRect& r) const
+IconItem* IconView::findFirstVisibleItem(bool useThumbnailRect) const
 {
+    QRect r(contentsX(), contentsY(), visibleWidth(), visibleHeight());
+    return findFirstVisibleItem(r, useThumbnailRect);
+}
+
+IconItem* IconView::findLastVisibleItem(bool useThumbnailRect) const
+{
+    QRect r(contentsX(), contentsY(), visibleWidth(), visibleHeight());
+    return findLastVisibleItem(r, useThumbnailRect);
+}
+
+IconItem* IconView::findFirstVisibleItem(const QRect& r, bool useThumbnailRect) const
+{
     IconViewPriv::ItemContainer *c = d->firstContainer;
     bool alreadyIntersected = false;
     IconItem* i = 0;
 @ -1671,8 +1722,10  @
                  it != c->items.end(); ++it)
             {
                 IconItem *item = *it;
-                
-                if ( r.intersects( item->rect() ) )
+
+                // if useThumbnailRect, we only check for the clickToOpenRect, which is the thumbnail,
+                // otherwise, we take the whole item rect
+                if ( r.intersects( useThumbnailRect ? item->clickToOpenRect() : item->rect() ) )
                 {
                     if ( !i )
                     {
 @ -1701,22 +1754,22  @
     return i;
 }
 
-IconItem* IconView::findLastVisibleItem(const QRect& r) const
+IconItem* IconView::findLastVisibleItem(const QRect& r, bool useThumbnailRect) const
 {
     IconViewPriv::ItemContainer *c = d->firstContainer;
     IconItem *i = 0;
     bool alreadyIntersected = false;
     for ( ; c; c = c->next )
     {
-        if ( c->rect.intersects( r ) )
+        if ( c->rect.intersects( r ) )
         {
             alreadyIntersected = true;
             for (QValueList<IconItem*>::iterator it = c->items.begin();
                  it != c->items.end(); ++it)
             {
                 IconItem *item = *it;
-                
-                if ( r.intersects( item->rect() ) )
+
+                if ( r.intersects( useThumbnailRect ? item->clickToOpenRect() : item->rect() ) )
                 {
                     if ( !i )
                     {
--- trunk/extragear/graphics/digikam/digikam/iconview.h #533142:533143
 @ -77,8 +77,10  @
     void takeItem(IconItem* item);
 
     void ensureItemVisible(IconItem *item);
-    IconItem* findFirstVisibleItem(const QRect& r) const;
-    IconItem* findLastVisibleItem(const QRect& r) const;
+    IconItem* findFirstVisibleItem(const QRect& r, bool useThumbnailRect = true) const;
+    IconItem* findLastVisibleItem(const QRect& r, bool useThumbnailRect = true) const;
+    IconItem* findFirstVisibleItem(bool useThumbnailRect = true) const;
+    IconItem* findLastVisibleItem(bool useThumbnailRect = true) const;
     
     virtual QRect itemRect() const;
     virtual QRect bannerRect() const;
_______________________________________________
Digikam-devel mailing list
[hidden email]
https://mail.kde.org/mailman/listinfo/digikam-devel