Fragment实际开发中的使用
来源:互联网 发布:篮球 中华台北队 知乎 编辑:程序博客网 时间:2024/05/21 10:33
一、结合TabLayout实现Fragment的切换效果
①、添加依赖: compile 'com.android.support:design:23.2.0'(版本根据个人的api修改,本人是api 23)
Google在2015的IO大会上,给开发者们带来了全新的Android Design Support Library,里面包含了许多新控件,这些新控件有许多是把以前的一些第三方开源库官方化。
②、了解TabLayout(详细教程:TabLayout的使用)
作用:顶部的Tab布局
效果图:
使用:
添加布局到activity_main
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.newbiechen.usetablayout.MainActivity"> <!--添加TabLayout--> <android.support.design.widget.TabLayout android:id="@+id/tab_layout" android:layout_width="match_parent" android:layout_height="wrap_content"></android.support.design.widget.TabLayout></RelativeLayout>第二步:
public class MainActivity extends AppCompatActivity { private TabLayout mTabLayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mTabLayout = (TabLayout)findViewById(R.id.tab_layout); //添加TabLayout上的按钮 mTabLayout.addTab(mTabLayout.newTab().setTag("第一页")); mTabLayout.addTab(mTabLayout.newTab().setTag("第二页")); //添加点击事件 mTabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() { @Override public void onTabSelected(TabLayout.Tab tab) { //当tab被选中的时候 } @Override public void onTabUnselected(TabLayout.Tab tab) { //当tab由选中被释放的时候 } @Override public void onTabReselected(TabLayout.Tab tab) { //当tab再次被选中的时候 } }); }}③、结合ViewPager的使用
第一步:创建TabLayout
第二步:创建ViewPager,并设置ViewPager的Adapter
第三步:将ViewPager与TabLayout结合
第四步:设置TabLayout的点击事件
public class MainActivity extends AppCompatActivity { private static final String [] TITLE ={"第一页","第二页"}; private TabLayout mTabLayout; private ViewPager mViewPager; private FragmentAdapter mFragmentAdapter; private Fragment mFirstFragment; private Fragment mSecondFragment; private final List<Fragment> mFragmentList = new ArrayList<>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); initClick(); } private void initView(){ /** * 第一步:创建TabLayout */ mTabLayout = (TabLayout)findViewById(R.id.tab_layout); //添加TabLayout上的按钮 mTabLayout.addTab(mTabLayout.newTab().setText("第一页")); mTabLayout.addTab(mTabLayout.newTab().setText("第二页")); /** * 第二步创建Viewpager并配置ViewPager的内容 */ mViewPager = (ViewPager)findViewById(R.id.viewpager); initWidget(); //设置ViewPager setUpViewPager(); /** * 第三步:将ViewPager与TabLayout结合 */ //添加ViewPager到TabLayout mTabLayout.setupWithViewPager(mViewPager); } private void initWidget(){ mFirstFragment = new FirstFragment(); mSecondFragment = new SecondFragment(); } private void setUpViewPager(){ mFragmentList.add(mFirstFragment); mFragmentList.add(mSecondFragment); mFragmentAdapter = new FragmentAdapter(getSupportFragmentManager()); mViewPager.setAdapter(mFragmentAdapter); } private void initClick(){ /** * 第四步:设置tab的点击事件 */ //添加点击事件 mTabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() { @Override public void onTabSelected(TabLayout.Tab tab) { mViewPager.setCurrentItem(tab.getPosition()); } @Override public void onTabUnselected(TabLayout.Tab tab) { //当tab由选中被释放的时候 } @Override public void onTabReselected(TabLayout.Tab tab) { //当tab再次被选中的时候 } }); } class FragmentAdapter extends FragmentPagerAdapter{ public FragmentAdapter(FragmentManager fm) { super(fm); } @Override public Fragment getItem(int position) { return mFragmentList.get(position); } @Override public int getCount() { return mFragmentList.size(); } /** * 如果使用ViewPager,则tab的setText()将无效,需要重写ViewPager的getPageTitle() * 来设置按钮的text */ @Override public CharSequence getPageTitle(int position) { return TITLE[position]; } }}效果图:
二、结合FragmentTabHost实现底部按钮的切换效果
作用:菜单切换栏,效果与TabLayout类似
效果图:
第一步:设置图片的Drawerable,使其能够点击切换颜色,并且当切换到不同的icon上的时候恢复颜色
<selector xmlns:android="http://schemas.android.com/apk/res/android"> <!--当按下的时候实现的图片--> <item android:state_pressed="true" android:drawable="@mipmap/ic_nav_news_actived"/> <!--当被选中的时候选中的图片,选中其他图片时,select状态消失--> <item android:state_selected="true" android:drawable="@mipmap/ic_nav_news_actived"/> <!--正长情况显示的图片--> <item android:drawable="@mipmap/ic_nav_news_normal"/></selector>(其余四个是一样的,只是需要换下图片)
第二步:创建四个Fragment及其layout
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="综合" android:textSize="22sp"/></LinearLayout>
public class NewsFragment extends Fragment { @Nullable @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_news,container,false); return view; }}(其余一样)
第三步:创建枚举类,每个枚举类包含Fragment、图片、文字
public enum NavMenu { NEWS("综合",R.drawable.nav_news,NewsFragment.class), TWEET("动弹",R.drawable.nav_tweet, TweetFragment.class), DISCOVER("发现",R.drawable.nav_discover, DiscoverFragment.class), MY("我的",R.drawable.nav_my, PersonInfoFragment.class); private int id; private String name; private int drawableId; private Class<?> cls; private NavMenu(String name, int drawableId, Class<?> cls){ this.name = name; this.drawableId = drawableId; this.cls = cls; } public String getMenuName(){ return name; } public int getDrawableId(){ return drawableId; } public Class<?> getFragmentCls(){ return cls; }}
第四步:创建FragmentTabHost到layout
<android.support.v4.app.FragmentTabHost xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@android:id/tabhost"//使用的是android自带的id android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.newbiechen.usefragmenttabhost.MainActivity"> <LinearLayout android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <!--主显示区域--> <FrameLayout android:id="@android:id/tabcontent" <span style="font-family: Arial, Helvetica, sans-serif;">//使用的是android自带的id</span> android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"></FrameLayout> <!--零件区域--> <TabWidget android:id="@android:id/tabs" //使用的是android自带的id android:layout_width="match_parent" android:layout_height="?attr/actionBarSize"></TabWidget> </LinearLayout></android.support.v4.app.FragmentTabHost>
第五步:设置按钮的样式(View)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center"> <ImageView android:id="@+id/menu_iv_icon" android:layout_width="wrap_content" android:layout_height="wrap_content" /></RelativeLayout>
第六步:将按钮与Fragment关联,并加入FragmentTabHost
public class MainActivity extends AppCompatActivity { private FragmentTabHost mTabHost; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mTabHost = (FragmentTabHost) findViewById(android.R.id.tabhost); //与FrameLayout关联 mTabHost.setup(this,getSupportFragmentManager(),android.R.id.tabcontent); //设置间隔样式为null mTabHost.getTabWidget().setDividerDrawable(null); //遍历添加按钮,并让按钮与Framgent关联 for(NavMenu navMenu : NavMenu.values()){ //创建按钮 TabHost.TabSpec spec = mTabHost.newTabSpec(navMenu.getMenuName()) .setIndicator(setUpMenuView(navMenu.getDrawableId())); //按钮与Fragment关联 mTabHost.addTab(spec,navMenu.getFragmentCls(),null); } //设置监听器 mTabHost.setOnTabChangedListener(new TabHost.OnTabChangeListener() { @Override public void onTabChanged(String tabId) { } }); } /** * 按钮的样式设置 */ private View setUpMenuView(int drawableId){ View view = LayoutInflater.from(this).inflate( R.layout.nav_menu,null,false ); ImageView iv = (ImageView) view.findViewById(R.id.menu_iv_icon); iv.setImageResource(drawableId); return view; }}
0 0
- Fragment实际开发中的使用
- Fragment实际开发中的总结(一)
- Git 实际开发中的使用
- Git实际开发中的使用
- Fragment实际应用中的生命周期
- MVP模式在实际开发中的使用
- Imageloader图片加载在实际开发中的使用
- 实际开发git使用流程
- Android应用开发:LoaderManager在Activity/Fragment中的使用分析
- Fragment的实际开发中总结(二)
- Android中的Fragment使用
- Fragment中的toolbar使用
- thymeleaf中的fragment使用
- 实际开发中的一些技巧(更新中)
- UML在实际开发中的应用
- 实际开发过程中的公共函数库分享
- 多态实际开发中的用途
- meta标签,实际开发中的重要性
- Gson简单使用
- Android中actionbar使用及其适配所有版本
- 网址
- IP地址与子网掩码
- 数据结构——外部排序
- Fragment实际开发中的使用
- thinkphp 加载第三方类库
- CocoaPods安装库时出现问题:The dependency `OpenCV (~> 3.0.0)` is not used in any concrete target的解决
- 自定义View笔记-圆形控件View的绘制
- TabHost的使用
- 2016 ACM/ICPC Dalian Online-1006 Football Games
- 设计模式之-工厂模式
- 一些资源
- ubuntu中遇到的问题