android---------TabLayout 的基础应用=====横向滑动菜单
2018-02-25 18:28
603 查看
gradle中添加依赖*compile'com.android.support:design:26+'/*** 1--写tablayout* 2--- 写viewPager* 3-- 写viewPagerAdapter* 4-- 让TabLayout和Viewpager关联;*/
布局文件代码
<?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"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context="com.bwie.tablayoutdemo2.MainActivity"><android.support.design.widget.TabLayoutandroid:id="@+id/tabLayout"android:layout_width="match_parent"android:layout_height="wrap_content" /><android.support.v4.view.ViewPagerandroid:id="@+id/viewPager"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1" /></LinearLayout>
--------------------------
MainActivity代码, 注意FragmentPagerAdapt中要重写getPageTitle方法;
package com.bwie.tablayoutdemo2;import android.os.Bundle;import android.support.design.widget.TabLayout;import android.support.v4.app.Fragment;import android.support.v4.app.FragmentManager;import android.support.v4.app.FragmentPagerAdapter;import android.support.v4.view.ViewPager;import android.support.v7.app.AppCompatActivity;import java.util.ArrayList;/*** 1--tablayout* 2--- viewPager* 3--viewPagerAdapter* 4-- 让TabLayout和Viewpager关联;*/public class MainActivity extends AppCompatActivity {private TabLayout tabLayout;private ViewPager viewPager;ArrayList<Fragment> fragmentList = new ArrayList<Fragment>();ArrayList<String> titleList = new ArrayList<String>();@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);tabLayout = (TabLayout) findViewById(R.id.tabLayout);viewPager = (ViewPager) findViewById(R.id.viewPager);initData();//ctrl+p 提示参数的快捷键MPagerAdapter mPagerAdapter = new MPagerAdapter(getSupportFragmentManager());viewPager.setAdapter(mPagerAdapter);//设置TabLayout的模式tabLayout.setTabMode(TabLayout.MODE_FIXED);//让tablayout和Viewpager关联;tabLayout.setupWithViewPager(viewPager);}private void initData() {for (int i = 0; i <4 ; i++) {fragmentList.add(new BlankFragment());titleList.add("爱因斯坦" +i);}}class MPagerAdapter extends FragmentPagerAdapter{public MPagerAdapter(FragmentManager fm) {super(fm);}@Overridepublic Fragment getItem(int position) {return fragmentList.get(position);}@Overridepublic int getCount() {return fragmentList.size();}//需要重写个返回标题的方法;@Overridepublic CharSequence getPageTitle(int position) {return titleList.get(position);}}}
------------------------------------------
Fragment代码,Fragment用的都是V4包里的;
public class BlankFragment extends Fragment {@Nullable@Overridepublic View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {TextView textView = new TextView(getActivity());double random = Math.random();textView.setText("xxxxxxxxxxx"+random);return textView;}}
相关文章推荐
- Android 使用TabLayout、ViewPager和Fragment实现顶部菜单可滑动切换
- 横向滑动菜单+TabLayout+ViewPager
- Android中应用TabLayout实现顶部Tab小菜单加滑动效果
- TabLayout横向滑动菜单code
- TabLayout+ViewPager(横向滑动菜单)
- 顶部横向滑动菜单(和TabLayout一样)
- 横向菜单滑动选择viewpager+tablayout+fragment
- TabLayout(单独横向滑动菜单)
- 横向滑动菜单Tablayout和viewpager小圆点结合滑动仿今日头条
- TabLayout横向滑动菜单
- tablayout横向滑动菜单
- Android横向滑动导航TabLayout
- Android 5.x新增控件之--TabLayout实现左右滑动导航菜单
- 横向滑动菜单Tablayout,点击选项给下面的viewpager中的fragment传值
- 使用XTablayout实现横向滑动菜单,可以设置文字下面导航栏的宽度
- Android中横向滑动(TabLayout+ViewPager)的实现
- TabLayout横向滑动菜单code
- TabLayout+ViewPager+Fragment简单实现横向滑动菜单
- TabLayout横向滑动菜单
- Android Design Support Library(一)用TabLayout实现类似网易选项卡动态滑动效果