自定义Tablayout的布局

对于Tablayout可能对于有实际开发经验的程序员来说并不会很陌生,但是很多使用者都停留在对Tablayout最基本的认识上.因为在开发中使用Tablayout最多的场景是结合ViewPager一起使用,这种用法我就不讲解了,今天重点讲解一下自定义Tablayout的布局,填充自定义的布局.

这里写代码片
 /**
     * 该方法是获取Tablayout布局View的方法,填充布局
     * @param position
     * @return
     */
 public View getTabView(int position) {
        View view = LayoutInflater.from(this).inflate(R.layout.headgoodlist, null);
        TextView txt_title = (TextView) view.findViewById(R.id.goodlist_tv);
        txt_title.setText(DownTitles.get(position));
        return view;
    } 
 /**

 * 通过该方法为,根据索引来Tablayout设置自定的布局View
 */
TabLayout.Tab tab = mTabLayout.newTab().setCustomView(getTabView(i));
mTabLayout.addTab(tab);
/**
 * 初始化Tablayout标题
 */
 TabLayout.Tab tab = mTablayout.newTab().setText(str);
 mTabLayout.addTab(tab);

如果你需要你的tablayout的点击事件一般情况可对tablayout设置 addOnTabSelectedListener(onTabSelectedListener)监听事件

TabLayout.OnTabSelectedListener {
    @Override
    public void onTabSelected(TabLayout.Tab tab) {
    //选择的回调
    }

    @Override
    public void onTabUnselected(TabLayout.Tab tab) {
    //没选择的回调
    }

    @Override
    public void onTabReselected(TabLayout.Tab tab) {
  //重复选择的回调
    }

如果需要对tablayout重设Tab点击事件.两种方法实现
1.如果你是要的是上面自定义的布局使用如下方法:**

 public View getTabView(int position) {
        View view = LayoutInflater.from(this).inflate(R.layout.headgoodlist, null);
        TextView txt_title = (TextView) view.findViewById(R.id.goodlist_tv);
        txt_title.setText(DownTitles.get(position));
        //就是对自己填充的布局设置监听事件
          view .setTag(i);
         view .setOnClickListener(mTabOnClickListener);
        return view;
    }
2.如果你是要的是tablayout原生的布局则使用如下方法
for (int i = 0; i < tabLayout.getTabCount(); i++) {
    TabLayout.Tab tab = tabLayout.getTabAt(i);
    if (tab != null) {
        tab.setCustomView(pagerAdapter.getTabView(i));
        if (tab.getCustomView() != null) {
            View tabView = (View) tab.getCustomView().getParent();
            tabView.setTag(i);
            tabView.setOnClickListener(mTabOnClickListener);
        }
    }
}

第一次使用MarkDown编写文章,有不足的请见谅,通过上面的代码就可自定义Tablayout的布局了,希望这篇文章对你的工作和学习上有所帮助谢谢!!!!!!!!!!!!!!!!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值