最近需要做一個app,需要用到tablayout實現頂部的滑動,用到了自定義item,不過沒有用到tabitem,貼出來供大家學習,先看圖吧,覺得滿意的繼續往下面看
具體代碼實現:
我直接貼啦,能說的不多
主布局: fragment_message.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
<?xml version= "1.0" encoding= "utf-8" ?> <LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:app= "http://schemas.android.com/apk/res-auto" android:orientation= "vertical" android:layout_width= "match_parent" android:layout_height= "match_parent" > <!-- app:tabIndicatorHeight= "1dp" 指示器高度 app:tabIndicatorColor= "@color/white" 指示器顏色 app:tabMode 默認是fixed:固定的,標簽很多時候會被擠壓,不能滑動。 scrollable 可滑動伸縮式的 --> <android.support.design.widget.TabLayout android:id= "@+id/fg_mg_tab" android:layout_gravity= "center" android:layout_width= "match_parent" android:layout_height= "@dimen/toolbar_height" android:background= "@color/colorPrimary" app:tabIndicatorHeight= "@dimen/common_dimension_2" app:tabMode= "fixed" android:fillViewport= "false" app:tabIndicatorColor= "@color/green1" app:tabTextAppearance= "@style/core_IconTabLayout" app:tabTextColor= "@color/white" /> <android.support.v4.view.ViewPager android:id= "@+id/fg_mg_viewpager" android:layout_width= "match_parent" android:layout_height= "match_parent" > </android.support.v4.view.ViewPager> </LinearLayout> |
item布局: item_table_msg.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<?xml version= "1.0" encoding= "utf-8" ?> <LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android" android:orientation= "horizontal" android:layout_width= "wrap_content" android:gravity= "center_vertical" android:layout_height= "wrap_content" > <ImageView android:id= "@+id/iv_msg_tab" android:src= "@drawable/ic_msg_find" android:scaleType= "centerInside" android:layout_width= "wrap_content" android:layout_height= "wrap_content" /> <TextView android:layout_marginLeft= "@dimen/common_dimension_2" android:id= "@+id/tv_msg_tab" android:textColor= "@color/white" android:text= "會話" android:textSize= "@dimen/SmallerTextSize" android:layout_width= "wrap_content" android:layout_height= "wrap_content" /> </LinearLayout> |
適配器:MessagePagerAdapter
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
public class MessagePagerAdapter extends FragmentPagerAdapter { private final List<Pair<BaseFragment,MsgTabBean>> mFragmentList = new ArrayList<>(); private Context mContext; public MessagePagerAdapter(Context mContext,FragmentManager fm) { super (fm); this .mContext = mContext; } public void addFlag(Pair<BaseFragment,MsgTabBean> msgTabBeanPair){ mFragmentList.add(msgTabBeanPair); } @Override public Fragment getItem( int position) { return mFragmentList.get(position).first; } @Override public int getCount() { return mFragmentList.size(); } public View getTabView( int position, ViewGroup mGroup){ View view; view = LayoutInflater.from(mContext).inflate(R.layout.view_table_msg,mGroup, false ); ImageView img = view.findViewById(R.id.iv_msg_tab); TextView tv = view.findViewById(R.id.tv_msg_tab); img.setImageResource(mFragmentList.get(position).second.getResId()); tv.setText(mFragmentList.get(position).second.getTitle()); return view; } } |
Fragment中進行設置:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
mMessagePagerAdapter = new MessagePagerAdapter(getActivity(),getActivity().getSupportFragmentManager()); mMessagePagerAdapter.addFlag( new Pair<>(MsgFragmentFactory.getInstance().getMsgCommListFragment(), new MsgTabBean( "通訊錄" ,R.drawable.ic_msg_comm_list))); mMessagePagerAdapter.addFlag( new Pair<>(MsgFragmentFactory.getInstance().getMsgCrowdFragment(), new MsgTabBean( "群聊" ,R.drawable.ic_msg_crowd))); mMessagePagerAdapter.addFlag( new Pair<>(MsgFragmentFactory.getInstance().getMsgConverFragment(), new MsgTabBean( "消息" ,R.drawable.ic_msg_conver))); mMessagePagerAdapter.addFlag( new Pair<>(MsgFragmentFactory.getInstance().getMsgFindFragment(), new MsgTabBean( "發現" ,R.drawable.ic_msg_find))); mFgMgViewpager.setAdapter(mMessagePagerAdapter); mFgMgTab.setupWithViewPager(mFgMgViewpager); for ( int index = 0 ;index<mMessagePagerAdapter.getCount();index++){ mFgMgTab.getTabAt(index).setCustomView(mMessagePagerAdapter.getTabView(index,mFgMgTab)); } mFgMgViewpager.setOffscreenPageLimit(mMessagePagerAdapter.getCount()); mFgMgViewpager.setCurrentItem( 3 ); } |
總結
以上所述是小編給大家介紹的Android 自定義View結合自定義TabLayout實現頂部標簽滑動效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:https://blog.csdn.net/crazyZhangxl/article/details/80106594