自定义TabLayout item 布局

adapter

public class TabViewPagerAdapter extends FragmentPagerAdapter {


    private List<String> mTabList;
    private List<Fragment> mListFragment;
    private Context mContext;

    public TabViewPagerAdapter(FragmentManager fm,
                               @NonNull Context context,
                               @NonNull List<Fragment> listFragment) {
        super(fm);
        checkNotNull(context);
        mContext = context;
        mListFragment = checkNotNull(listFragment);
        mTabList = new ArrayList<>();
        mTabList.add(context.getResources().getString(R.string.system_msg_icon));
        mTabList.add(context.getResources().getString(R.string.activity_msg_icon));
        mTabList.add(context.getResources().getString(R.string.scene_msg_icon));
    }

    @Override
    public Fragment getItem(int position) {
        return mListFragment.get(position);
    }

    @Override
    public int getCount() {
        return mListFragment.size();
    }

    /**
     * 初始化布局显示
     */
    public View getTabView(int position) {
        Typeface customFont = Typeface.createFromAsset(mContext.getAssets(), "Netfits-Android.ttf");
        View inflate = LayoutInflater.from(mContext).inflate(R.layout.tab_layout, null);
        TextView mMsgTypeTextView = (TextView) inflate.findViewById(R.id.msg_type);
        mMsgTypeTextView.setTypeface(customFont);
        mMsgTypeTextView.setText(mTabList.get(position));
        return inflate;
    }
}



activity

private void initUiView() {

        AppCompatActivity msgCenterFrg = (AppCompatActivity) getActivity();
        msgCenterFrg.setSupportActionBar(mMsgCenterToolBar);
        ActionBar supportActionBar = msgCenterFrg.getSupportActionBar();
        if (supportActionBar != null) {
            supportActionBar.setDisplayHomeAsUpEnabled(true);
            supportActionBar.setDisplayShowTitleEnabled(false);
            mMsgCenterToolBar.setBackgroundColor(getActivity().getResources().getColor(R.color.msg_system_bg_color));
            mMsgCenterToolBar.setTitle(getActivity().getResources().getString(R.string.message_page_tool_bar));
            mMsgCenterToolBar.setTitleTextColor(getActivity().getResources().getColor(R.color.white));
            mMsgCenterToolBar.setNavigationOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                   // back 
                }
            });
        }
        List<Fragment> mListFragment = new ArrayList<>();
        mScenesMsgFragment = new ScenesMsgFragment();
        mActivityMsgFragment = new ActivityMsgFragment();
        mSystemMsgFragment = new SystemMsgFragment();
        // 顺序固定,不可更改
        mListFragment.add(mScenesMsgFragment);// 场景推荐
        mListFragment.add(mActivityMsgFragment); // 活动通知
        mListFragment.add(mSystemMsgFragment); // 系统通知
        mMsgCenterTableLayout.setTabMode(TabLayout.MODE_FIXED);
        mMsgCenterTableLayout.setBackgroundColor(getActivity().getResources().getColor(R.color.msg_system_bg_color));
        mTabViewPagerAdapter = new TabViewPagerAdapter(getFragmentManager(), getActivity(), mListFragment);
        mMsgCenterViewPager.setAdapter(mTabViewPagerAdapter);
        mMsgCenterTableLayout.setupWithViewPager(mMsgCenterViewPager);
        for (int i = 0; i < mMsgCenterTableLayout.getTabCount(); i++) {
            TabLayout.Tab tabAt = mMsgCenterTableLayout.getTabAt(i);
            if (tabAt != null) {
                tabAt.setCustomView(mTabViewPagerAdapter.getTabView(i));
            }
        }

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 首先看一下最终要实现的效果: 一般我们使用TabLayout都默认文字布局,比较单一。为了能灵活应对产品的各种需求...
    MrAllRight_Liu阅读 10,245评论 2 17
  • 导言: 很多人都喜欢使用安卓的listview进行列表式的展示,然而列表项的内容往往不是一个单一的textview...
    修罗的小熊阅读 16,218评论 2 3
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,143评论 25 709
  • 今天来分享下做导航栏的另外一种方法,导航栏可以放在顶部,也可以放在底部,之前分享过一片底部导航栏的实现方式一行代码...
    juexingzhe阅读 770评论 0 9
  • 再次打开简书,发现一不小心差不多一年就这样过去了。又是一年秋,又是一个雨天,想来雨天和书写是很配的😜去年的迷茫如今...
    懒小仙阅读 239评论 0 1