Bug fix for scrolling folder views.
An LLFolderView is added as child to LLScrollableContainerView, but also adds the LLScrollableContainerView to it's mScrollContainer. As a result, when scrolling inside a LLFolderView the event is passed to the mScrollContainer, which then passes it first on to it's children (see the "Bad UI design" remark in the code), causing an infinite loop. This patch breaks that loop for those objects that have a mScrollContainer: LLFolderView and LLContainerView.
This commit is contained in:
@@ -2068,6 +2068,12 @@ void LLFolderView::scrollToShowItem(LLFolderViewItem* item, const LLRect& constr
|
||||
}
|
||||
}
|
||||
|
||||
void LLFolderView::setScrollContainer(LLScrollableContainerView* parent)
|
||||
{
|
||||
mScrollContainer = parent;
|
||||
parent->setPassBackToChildren(false);
|
||||
}
|
||||
|
||||
LLRect LLFolderView::getVisibleRect()
|
||||
{
|
||||
S32 visible_height = mScrollContainer->getRect().getHeight();
|
||||
|
||||
Reference in New Issue
Block a user