Loading core/java/android/widget/Toolbar.java +2 −1 Original line number Diff line number Diff line Loading @@ -1339,7 +1339,8 @@ public class Toolbar extends ViewGroup { return getPaddingTop(); case Gravity.BOTTOM: return getPaddingBottom() - child.getMeasuredHeight() - lp.bottomMargin; return getHeight() - getPaddingBottom() - child.getMeasuredHeight() - lp.bottomMargin; default: case Gravity.CENTER_VERTICAL: Loading core/java/com/android/internal/app/ToolbarActionBar.java +3 −0 Original line number Diff line number Diff line Loading @@ -281,6 +281,9 @@ public class ToolbarActionBar extends ActionBar { @Override public void setNavigationMode(@NavigationMode int mode) { if (mode == ActionBar.NAVIGATION_MODE_TABS) { throw new IllegalArgumentException("Tabs not supported in this configuration"); } mDecorToolbar.setNavigationMode(mode); } Loading core/java/com/android/internal/widget/ActionBarView.java +1 −4 Original line number Diff line number Diff line Loading @@ -349,10 +349,7 @@ public class ActionBarView extends AbsActionBarView implements DecorToolbar { return mIncludeTabs; } public void setEmbeddedTabView(View view) { setEmbeddedTabView((ScrollingTabContainerView) view); } @Override public void setEmbeddedTabView(ScrollingTabContainerView tabs) { if (mTabScrollView != null) { removeView(mTabScrollView); Loading core/java/com/android/internal/widget/DecorToolbar.java +1 −1 Original line number Diff line number Diff line Loading @@ -71,7 +71,7 @@ public interface DecorToolbar { int getDisplayOptions(); void setDisplayOptions(int opts); void setEmbeddedTabView(View tabView); void setEmbeddedTabView(ScrollingTabContainerView tabView); boolean hasEmbeddedTabs(); boolean isTitleTruncated(); void setCollapsible(boolean collapsible); Loading core/java/com/android/internal/widget/ToolbarWidgetWrapper.java +25 −2 Original line number Diff line number Diff line Loading @@ -397,8 +397,19 @@ public class ToolbarWidgetWrapper implements DecorToolbar { } @Override public void setEmbeddedTabView(View tabView) { public void setEmbeddedTabView(ScrollingTabContainerView tabView) { if (mTabView != null && mTabView.getParent() == mToolbar) { mToolbar.removeView(mTabView); } mTabView = tabView; if (tabView != null && mNavigationMode == ActionBar.NAVIGATION_MODE_TABS) { mToolbar.addView(mTabView, 0); Toolbar.LayoutParams lp = (Toolbar.LayoutParams) mTabView.getLayoutParams(); lp.width = ViewGroup.LayoutParams.WRAP_CONTENT; lp.height = ViewGroup.LayoutParams.WRAP_CONTENT; lp.gravity = Gravity.START | Gravity.BOTTOM; tabView.setAllowCollapse(true); } } @Override Loading Loading @@ -436,6 +447,11 @@ public class ToolbarWidgetWrapper implements DecorToolbar { mToolbar.removeView(mSpinner); } break; case ActionBar.NAVIGATION_MODE_TABS: if (mTabView != null && mTabView.getParent() == mToolbar) { mToolbar.removeView(mTabView); } break; } mNavigationMode = mode; Loading @@ -448,7 +464,14 @@ public class ToolbarWidgetWrapper implements DecorToolbar { mToolbar.addView(mSpinner, 0); break; case ActionBar.NAVIGATION_MODE_TABS: throw new IllegalStateException("Tabs not supported in this configuration"); if (mTabView != null) { mToolbar.addView(mTabView, 0); Toolbar.LayoutParams lp = (Toolbar.LayoutParams) mTabView.getLayoutParams(); lp.width = ViewGroup.LayoutParams.WRAP_CONTENT; lp.height = ViewGroup.LayoutParams.WRAP_CONTENT; lp.gravity = Gravity.START | Gravity.BOTTOM; } break; default: throw new IllegalArgumentException("Invalid navigation mode " + mode); } Loading Loading
core/java/android/widget/Toolbar.java +2 −1 Original line number Diff line number Diff line Loading @@ -1339,7 +1339,8 @@ public class Toolbar extends ViewGroup { return getPaddingTop(); case Gravity.BOTTOM: return getPaddingBottom() - child.getMeasuredHeight() - lp.bottomMargin; return getHeight() - getPaddingBottom() - child.getMeasuredHeight() - lp.bottomMargin; default: case Gravity.CENTER_VERTICAL: Loading
core/java/com/android/internal/app/ToolbarActionBar.java +3 −0 Original line number Diff line number Diff line Loading @@ -281,6 +281,9 @@ public class ToolbarActionBar extends ActionBar { @Override public void setNavigationMode(@NavigationMode int mode) { if (mode == ActionBar.NAVIGATION_MODE_TABS) { throw new IllegalArgumentException("Tabs not supported in this configuration"); } mDecorToolbar.setNavigationMode(mode); } Loading
core/java/com/android/internal/widget/ActionBarView.java +1 −4 Original line number Diff line number Diff line Loading @@ -349,10 +349,7 @@ public class ActionBarView extends AbsActionBarView implements DecorToolbar { return mIncludeTabs; } public void setEmbeddedTabView(View view) { setEmbeddedTabView((ScrollingTabContainerView) view); } @Override public void setEmbeddedTabView(ScrollingTabContainerView tabs) { if (mTabScrollView != null) { removeView(mTabScrollView); Loading
core/java/com/android/internal/widget/DecorToolbar.java +1 −1 Original line number Diff line number Diff line Loading @@ -71,7 +71,7 @@ public interface DecorToolbar { int getDisplayOptions(); void setDisplayOptions(int opts); void setEmbeddedTabView(View tabView); void setEmbeddedTabView(ScrollingTabContainerView tabView); boolean hasEmbeddedTabs(); boolean isTitleTruncated(); void setCollapsible(boolean collapsible); Loading
core/java/com/android/internal/widget/ToolbarWidgetWrapper.java +25 −2 Original line number Diff line number Diff line Loading @@ -397,8 +397,19 @@ public class ToolbarWidgetWrapper implements DecorToolbar { } @Override public void setEmbeddedTabView(View tabView) { public void setEmbeddedTabView(ScrollingTabContainerView tabView) { if (mTabView != null && mTabView.getParent() == mToolbar) { mToolbar.removeView(mTabView); } mTabView = tabView; if (tabView != null && mNavigationMode == ActionBar.NAVIGATION_MODE_TABS) { mToolbar.addView(mTabView, 0); Toolbar.LayoutParams lp = (Toolbar.LayoutParams) mTabView.getLayoutParams(); lp.width = ViewGroup.LayoutParams.WRAP_CONTENT; lp.height = ViewGroup.LayoutParams.WRAP_CONTENT; lp.gravity = Gravity.START | Gravity.BOTTOM; tabView.setAllowCollapse(true); } } @Override Loading Loading @@ -436,6 +447,11 @@ public class ToolbarWidgetWrapper implements DecorToolbar { mToolbar.removeView(mSpinner); } break; case ActionBar.NAVIGATION_MODE_TABS: if (mTabView != null && mTabView.getParent() == mToolbar) { mToolbar.removeView(mTabView); } break; } mNavigationMode = mode; Loading @@ -448,7 +464,14 @@ public class ToolbarWidgetWrapper implements DecorToolbar { mToolbar.addView(mSpinner, 0); break; case ActionBar.NAVIGATION_MODE_TABS: throw new IllegalStateException("Tabs not supported in this configuration"); if (mTabView != null) { mToolbar.addView(mTabView, 0); Toolbar.LayoutParams lp = (Toolbar.LayoutParams) mTabView.getLayoutParams(); lp.width = ViewGroup.LayoutParams.WRAP_CONTENT; lp.height = ViewGroup.LayoutParams.WRAP_CONTENT; lp.gravity = Gravity.START | Gravity.BOTTOM; } break; default: throw new IllegalArgumentException("Invalid navigation mode " + mode); } Loading