将Tab栏居中的方法

原始tab:

居中后的tab(边缘效果是截图的问题):

改变方法如下:

找到Android SlidingTabLayout源代码,在Android SlidingTabLayout源代码中有一个方法:
private void populateTabStrip();

 1 private void populateTabStrip() {
 2         final PagerAdapter adapter = mViewPager.getAdapter();
 3         final View.OnClickListener tabClickListener = new TabClickListener();
 4 
 5         for (int i = 0; i < adapter.getCount(); i++) {
 6             View tabView = null;
 7             TextView tabTitleView = null;
 8 
 9             if (mTabViewLayoutId != 0) {
10                 // If there is a custom tab view layout id set, try and inflate
11                 // it
12                 tabView = LayoutInflater.from(getContext()).inflate(mTabViewLayoutId, mTabStrip, false);
13                 tabTitleView = (TextView) tabView.findViewById(mTabViewTextViewId);
14             }
15 
16             if (tabView == null) {
17                 tabView = createDefaultTabView(getContext());
18             }
19 
20             if (tabTitleView == null && TextView.class.isInstance(tabView)) {
21                 tabTitleView = (TextView) tabView;
22             }
23 
24             tabTitleView.setText(adapter.getPageTitle(i));
25             tabView.setOnClickListener(tabClickListener);
26             
27             mTabStrip.addView(tabView);
28         }
29     }

这是谷歌官方实现的Android SlidingTabLayout添加底部选项卡Tab的代码,如果为了实现前文所述的将Tab均分水平位置空间,则需要修改此方法,在此方法中添加如下代码:

1 LinearLayout.LayoutParams layoutParams= new LinearLayout.LayoutParams(0, LayoutParams.WRAP_CONTENT, 1.0f);
2             tabView.setLayoutParams(layoutParams);

这两段代码将tab view水平均分放置。

最终将private void populateTabStrip()改进成这样:

 1 private void populateTabStrip() {
 2         final PagerAdapter adapter = mViewPager.getAdapter();
 3         final View.OnClickListener tabClickListener = new TabClickListener();
 4 
 5         for (int i = 0; i < adapter.getCount(); i++) {
 6             View tabView = null;
 7             TextView tabTitleView = null;
 8 
 9             if (mTabViewLayoutId != 0) {
10                 // If there is a custom tab view layout id set, try and inflate
11                 // it
12                 tabView = LayoutInflater.from(getContext()).inflate(mTabViewLayoutId, mTabStrip, false);
13                 tabTitleView = (TextView) tabView.findViewById(mTabViewTextViewId);
14             }
15 
16             if (tabView == null) {
17                 tabView = createDefaultTabView(getContext());
18             }
19 
20             if (tabTitleView == null && TextView.class.isInstance(tabView)) {
21                 tabTitleView = (TextView) tabView;
22             }
23 
24             tabTitleView.setText(adapter.getPageTitle(i));
25             tabView.setOnClickListener(tabClickListener);
26 
27             //添加
28             LinearLayout.LayoutParams layoutParams= new LinearLayout.LayoutParams(0, LayoutParams.WRAP_CONTENT, 1.0f);
29             tabView.setLayoutParams(layoutParams);
30             //添加
31             
32             mTabStrip.addView(tabView);
33         }
34     }

 

posted on 2015-11-23 09:12  Z2  阅读(1616)  评论(0)    收藏  举报

导航