栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

TabHost+ViewPager+Fragment实现页面的滑动,android开发工具deve

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

TabHost+ViewPager+Fragment实现页面的滑动,android开发工具deve

android:id="@+id/viewpager"

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:layout_above="@+id/viewline"

ViewPager是用到android v4包下的内容,v4包下有很多内容,经常用到的Fragment类不是用系统给的类而是V4包的Fragment比较常用。 ViewPager 需要数据源和对应的适配器

List< view> 和 PagerAdapter; List< Fragment> FragmentPagerAdapter2种放进视图页的形式

这次我们用第二种,定义好适配器。

public class viewpageradapter extends FragmentPagerAdapter {

List list;

public viewpageradapter(FragmentManager fm,List list) {

super(fm);

this.list=list;

}

@Override

public Fragment getItem(int position) {

Object fragment= list.get(position);

return (Fragment) fragment;

}

@Override

public int getCount() {

return list.size();

}

}

初始化好数据源

private void addFragment() {

list.add(new testFragment());

list.add(new test_twofragment());

list.add(new test_threefragment());

}

然后实例化适配器,并用ViewPager建立适配器

viewpageradapter=new viewpageradapter(getSupportFragmentManager(),list);

viewPager.setAdapter(viewpageradapter);

这样ViewPager就做好了

之后定义三个Fragment类

public class testFragment extends android.support.v4.app.Fragment {

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view= inflater.inflate(R.layout.layout,container,false);

return view;

}

@Override

public void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

}

}

第二个frament

package com.example.administrator.okio;

import android.app.Fragment;

import android.os.Bundle;

import android.support.annotation.Nullable;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

public class test_twofragment extends android.support.v4.app.Fragment {

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view=inflater.inflate(R.layout.layouttwo,null);

return view;

}

}

第三个fragment

import android.os.Bundle;

import android.support.annotation.Nullable;

import android.support.v4.app.Fragment;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

public class test_threefragment extends Fragment {

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view=inflater.inflate(R.layout.layoutthree,null);

return view;

}

}

对应的布局都很简单,就一个TextView,就不一一粘贴了。

主界面的布局文件

android:id="@+id/tabhost"

xmlns:android=“http://schemas.android.com/apk/res/android”

android:layout_width=“match_parent”

android:layout_height=“match_parent”>

android:layout_width=“match_parent”

android:layout_height="match_paren

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

t">

android:id="@+id/viewpager"

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:layout_above="@+id/viewline"

android:id="@android:id/tabcontent"

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:visibility=“gone”>

android:id="@+id/viewline"

android:layout_width=“match_parent”

android:layout_height=“1dp”

android:background="#cccccc"

android:layout_above="@android:id/tabs"/>

android:id="@android:id/tabs"

android:layout_width=“match_parent”

android:layout_height=“60dp”

android:layout_alignParentBottom=“true”

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/643595.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号