According to my tests on R5, a BScrollBar with a proportion of 0.0, the value
that it has when you never set it, uses the large step to figure out the proportion it should display. This fixes Pe's scroll bars to display the "correct" proportion. Of course the proportion is only correct if the large step indeed equals the page size. Fixes #1758. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@24838 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
a43222b925
commit
1158eeac58
@ -21,7 +21,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
//#define TRACE_SCROLLBAR
|
#define TRACE_SCROLLBAR
|
||||||
#ifdef TRACE_SCROLLBAR
|
#ifdef TRACE_SCROLLBAR
|
||||||
# define TRACE(x...) printf(x)
|
# define TRACE(x...) printf(x)
|
||||||
#else
|
#else
|
||||||
@ -445,15 +445,33 @@ BScrollBar::GetRange(float *min, float *max) const
|
|||||||
void
|
void
|
||||||
BScrollBar::SetSteps(float smallStep, float largeStep)
|
BScrollBar::SetSteps(float smallStep, float largeStep)
|
||||||
{
|
{
|
||||||
// Under R5, steps can be set only after being attached to a window, probably because
|
TRACE("BScrollBar(%s)::SetSteps(small=%.1f, large=%.1f)\n", Name(),
|
||||||
// the data is kept server-side. We'll just remove that limitation... :P
|
smallStep, largeStep);
|
||||||
|
|
||||||
// The BeBook also says that we need to specify an integer value even though the step
|
// Under R5, steps can be set only after being attached to a window,
|
||||||
// values are floats. For the moment, we'll just make sure that they are integers
|
// probably because the data is kept server-side. We'll just remove
|
||||||
fSmallStep = roundf(smallStep);
|
// that limitation... :P
|
||||||
fLargeStep = roundf(largeStep);
|
|
||||||
|
|
||||||
// TODO: test use of fractional values and make them work properly if they don't
|
// The BeBook also says that we need to specify an integer value even
|
||||||
|
// though the step values are floats. For the moment, we'll just make
|
||||||
|
// sure that they are integers
|
||||||
|
smallStep = roundf(smallStep);
|
||||||
|
largeStep = roundf(largeStep);
|
||||||
|
if (fSmallStep == smallStep && fLargeStep == largeStep)
|
||||||
|
return;
|
||||||
|
|
||||||
|
fSmallStep = smallStep;
|
||||||
|
fLargeStep = largeStep;
|
||||||
|
|
||||||
|
if (fProportion == 0.0) {
|
||||||
|
// special case, proportion is based on fLargeStep if it was never
|
||||||
|
// set, so it means we need to invalidate here
|
||||||
|
_UpdateThumbFrame();
|
||||||
|
Invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: test use of fractional values and make them work properly if
|
||||||
|
// they don't
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetSteps
|
// GetSteps
|
||||||
@ -1123,8 +1141,17 @@ BScrollBar::_UpdateThumbFrame()
|
|||||||
|
|
||||||
float thumbSize = minSize;
|
float thumbSize = minSize;
|
||||||
float proportion = fProportion;
|
float proportion = fProportion;
|
||||||
if (fMin == fMax || proportion > 1.0 || proportion < 0.0)
|
if (fMin >= fMax || proportion > 1.0 || proportion < 0.0)
|
||||||
proportion = 1.0;
|
proportion = 1.0;
|
||||||
|
if (proportion == 0.0) {
|
||||||
|
// Special case a proportion of 0.0, use the large step value
|
||||||
|
// in that case (NOTE: fMin == fMax already handled above)
|
||||||
|
// This calculation is based on the assumption that "large step"
|
||||||
|
// scrolls by one "page size".
|
||||||
|
proportion = fLargeStep / (2 * (fMax - fMin));
|
||||||
|
if (proportion > 1.0)
|
||||||
|
proportion = 1.0;
|
||||||
|
}
|
||||||
if (fPrivateData->fScrollBarInfo.proportional)
|
if (fPrivateData->fScrollBarInfo.proportional)
|
||||||
thumbSize += (maxSize - minSize) * proportion;
|
thumbSize += (maxSize - minSize) * proportion;
|
||||||
thumbSize = floorf(thumbSize + 0.5);
|
thumbSize = floorf(thumbSize + 0.5);
|
||||||
|
Loading…
Reference in New Issue
Block a user