Commit 68efa6a3 authored by Hans Muller's avatar Hans Muller Committed by GitHub

Correct scrolling tabbar tab indicator size (#4723)

parent 05eef4a9
...@@ -683,6 +683,22 @@ class TabBarSelectionState<T> extends State<TabBarSelection<T>> { ...@@ -683,6 +683,22 @@ class TabBarSelectionState<T> extends State<TabBarSelection<T>> {
} }
} }
// Used when the user is dragging the TabBar or the TabBarView left or right.
// Dragging from the selected tab to the left varies t between 0.5 and 0.0.
// Dragging towards the tab on the right varies t between 0.5 and 1.0.
class _TabIndicatorTween extends Tween<Rect> {
_TabIndicatorTween({ Rect begin, this.middle, Rect end }) : super(begin: begin, end: end);
final Rect middle;
@override
Rect lerp(double t) {
return t <= 0.5
? Rect.lerp(begin, middle, t * 2.0)
: Rect.lerp(middle, end, (t - 0.5) * 2.0);
}
}
/// A widget that displays a horizontal row of tabs, one per label. /// A widget that displays a horizontal row of tabs, one per label.
/// ///
/// Requires one of its ancestors to be a [TabBarSelection] widget to enable /// Requires one of its ancestors to be a [TabBarSelection] widget to enable
...@@ -789,11 +805,22 @@ class _TabBarState<T> extends ScrollableState<TabBar<T>> implements TabBarSelect ...@@ -789,11 +805,22 @@ class _TabBarState<T> extends ScrollableState<TabBar<T>> implements TabBarSelect
// when it's under the tab on the right. // when it's under the tab on the right.
void _initIndicatorTweenForDrag() { void _initIndicatorTweenForDrag() {
assert(!_valueIsChanging); assert(!_valueIsChanging);
int index = _selection.index;
int beginIndex = math.max(0, index - 1);
int endIndex = math.min(config.labels.length - 1, index + 1);
if (beginIndex == index || endIndex == index) {
_indicatorTween = new RectTween( _indicatorTween = new RectTween(
begin: _tabIndicatorRect(math.max(0, _selection.index - 1)), begin: _tabIndicatorRect(beginIndex),
end: _tabIndicatorRect(math.min(config.labels.length - 1, _selection.index + 1)) end: _tabIndicatorRect(endIndex)
);
} else {
_indicatorTween = new _TabIndicatorTween(
begin: _tabIndicatorRect(beginIndex),
middle: _tabIndicatorRect(index),
end: _tabIndicatorRect(endIndex)
); );
} }
}
// Initialize _indicatorTween for animating the selected tab indicator from the // Initialize _indicatorTween for animating the selected tab indicator from the
// previously selected tab to the newly selected one. In this case // previously selected tab to the newly selected one. In this case
...@@ -869,7 +896,7 @@ class _TabBarState<T> extends ScrollableState<TabBar<T>> implements TabBarSelect ...@@ -869,7 +896,7 @@ class _TabBarState<T> extends ScrollableState<TabBar<T>> implements TabBarSelect
Size _tabBarSize; Size _tabBarSize;
List<double> _tabWidths; List<double> _tabWidths;
Rect _indicatorRect; Rect _indicatorRect;
RectTween _indicatorTween; Tween<Rect> _indicatorTween;
Rect _tabRect(int tabIndex) { Rect _tabRect(int tabIndex) {
assert(_tabBarSize != null); assert(_tabBarSize != null);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment