Unverified Commit 4b6e5744 authored by Jason Simmons's avatar Jason Simmons Committed by GitHub

Use unselected styles for the tabs adjacent to the selected tab (#17397)

Fixes https://github.com/flutter/flutter/issues/16169
parent 768fca8b
...@@ -151,12 +151,12 @@ class _TabStyle extends AnimatedWidget { ...@@ -151,12 +151,12 @@ class _TabStyle extends AnimatedWidget {
final ThemeData themeData = Theme.of(context); final ThemeData themeData = Theme.of(context);
final TextStyle defaultStyle = labelStyle ?? themeData.primaryTextTheme.body2; final TextStyle defaultStyle = labelStyle ?? themeData.primaryTextTheme.body2;
final TextStyle defaultUnselectedStyle = unselectedLabelStyle ?? labelStyle ?? themeData.primaryTextTheme.body2; final TextStyle defaultUnselectedStyle = unselectedLabelStyle ?? labelStyle ?? themeData.primaryTextTheme.body2;
final Animation<double> animation = listenable;
final TextStyle textStyle = selected final TextStyle textStyle = selected
? defaultStyle ? TextStyle.lerp(defaultStyle, defaultUnselectedStyle, animation.value)
: defaultUnselectedStyle; : TextStyle.lerp(defaultUnselectedStyle, defaultStyle, animation.value);
final Color selectedColor = labelColor ?? themeData.primaryTextTheme.body2.color; final Color selectedColor = labelColor ?? themeData.primaryTextTheme.body2.color;
final Color unselectedColor = unselectedLabelColor ?? selectedColor.withAlpha(0xB2); // 70% alpha final Color unselectedColor = unselectedLabelColor ?? selectedColor.withAlpha(0xB2); // 70% alpha
final Animation<double> animation = listenable;
final Color color = selected final Color color = selected
? Color.lerp(selectedColor, unselectedColor, animation.value) ? Color.lerp(selectedColor, unselectedColor, animation.value)
: Color.lerp(unselectedColor, selectedColor, animation.value); : Color.lerp(unselectedColor, selectedColor, animation.value);
...@@ -919,13 +919,13 @@ class _TabBarState extends State<TabBar> { ...@@ -919,13 +919,13 @@ class _TabBarState extends State<TabBar> {
wrappedTabs[tabIndex] = _buildStyledTab(wrappedTabs[tabIndex], true, centerAnimation); wrappedTabs[tabIndex] = _buildStyledTab(wrappedTabs[tabIndex], true, centerAnimation);
if (_currentIndex > 0) { if (_currentIndex > 0) {
final int tabIndex = _currentIndex - 1; final int tabIndex = _currentIndex - 1;
final Animation<double> previousAnimation = new _DragAnimation(_controller, tabIndex); final Animation<double> previousAnimation = new ReverseAnimation(new _DragAnimation(_controller, tabIndex));
wrappedTabs[tabIndex] = _buildStyledTab(wrappedTabs[tabIndex], true, previousAnimation); wrappedTabs[tabIndex] = _buildStyledTab(wrappedTabs[tabIndex], false, previousAnimation);
} }
if (_currentIndex < widget.tabs.length - 1) { if (_currentIndex < widget.tabs.length - 1) {
final int tabIndex = _currentIndex + 1; final int tabIndex = _currentIndex + 1;
final Animation<double> nextAnimation = new _DragAnimation(_controller, tabIndex); final Animation<double> nextAnimation = new ReverseAnimation(new _DragAnimation(_controller, tabIndex));
wrappedTabs[tabIndex] = _buildStyledTab(wrappedTabs[tabIndex], true, nextAnimation); wrappedTabs[tabIndex] = _buildStyledTab(wrappedTabs[tabIndex], false, nextAnimation);
} }
} }
} }
......
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