Android App在ViewPager中使用Fragment的實(shí)例講解
據(jù)說(shuō)Android最推薦的是在ViewPager中使用FragMent,即ViewPager中的頁(yè)面不像前面那樣用LayoutInflater直接從布局文件加載,而是一個(gè)個(gè)Fragment。注意這里的Fragment
是android.support.v4.view包里的Fragment,而不是android.app包里的Fragment。
使用v4包里的Fragment的Activity必須繼承自FragmentActivity。
其實(shí)使用Fragment與前面不使用Fragment非常類似:
第一步 在主布局文件里放一個(gè)ViewPager組件
第二步 為每個(gè)頁(yè)面建立布局文件,把界面寫(xiě)好
第三步 為每個(gè)頁(yè)面新建Fragment類,并加載布局文件中的界面
第四部 為ViewPager設(shè)定Adapter,只不過(guò)這里的Adapter不是PagerAdapter,而是換成
FragmentPagerAdapter,實(shí)現(xiàn)兩個(gè)方法:
getCount():返回頁(yè)面數(shù)目
getItem(position):返回position位置的Fragment。
下面來(lái)看一個(gè)ViewPager與Fragment實(shí)現(xiàn)頁(yè)面滑動(dòng)效果的例子:

首先繼承FragmentActivity,
為ViewPager提供展示所需的Fragment和FragmentPagerAdapter:
Fragment來(lái)指定頁(yè)面的布局以及功能
// fragment
private class MyFragment extends Fragment {
private String text;
private int color;
public MyFragment(String text, int color) {
this.text = text;
this.color = color;
}
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
TextView tv = new TextView(MainActivity.this);
tv.setBackgroundColor(color);
tv.setText(text);
return tv;
}
}
adapter指定該Viewpager有多少頁(yè)面以及那個(gè)位置需要顯示哪個(gè)頁(yè)面:
// adapter
private class MyAdapter extends FragmentPagerAdapter {
public MyAdapter(FragmentManager fm) {
super(fm);
}
@Override
public int getCount() {
return pages.size();
}
@Override
public Fragment getItem(int arg0) {
return pages.get(arg0);
}
}
設(shè)置OnPageChangeListener,指定頁(yè)面改變時(shí)需要做什么其他操作:
@Override
public void onPageScrollStateChanged(int arg0) {
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
LinearLayout.LayoutParams lp = (android.widget.LinearLayout.LayoutParams) tabline.getLayoutParams();
lp.leftMargin = (int) ((arg0 + arg1) * mTabLineWidth);
tabline.setLayoutParams(lp);
}
@Override
public void onPageSelected(int arg0) {
// set titles
for (int i = 0; i < titles.size(); i++) {
if (arg0 == i) {
titles.get(i).setSelected(true);
} else {
titles.get(i).setSelected(false);
}
}
}
完整的代碼:
package com.hzy.myviewpager;
import java.util.ArrayList;
import android.graphics.Color;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.DisplayMetrics;
import android.view.Display;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.LinearLayout;
import android.widget.TextView;
import com.hzy.myviewpager.R.id;
public class MainActivity extends FragmentActivity implements OnPageChangeListener, OnClickListener {
ViewPager pager = null;
View tabline = null;
private int mTabLineWidth;
// titles
TextView title1 = null;
TextView title2 = null;
TextView title3 = null;
ArrayList<TextView> titles = null;
ArrayList<Fragment> pages = null;
@Override
protected void onCreate(Bundle arg0) {
super.onCreate(arg0);
initView();
initTabline();
}
private void initView() {
setContentView(R.layout.activity_main);
pages = new ArrayList<Fragment>();
titles = new ArrayList<TextView>();
pager = (ViewPager) findViewById(id.main_viewpager);
title1 = (TextView) findViewById(id.main_tab1);
title2 = (TextView) findViewById(id.main_tab2);
title3 = (TextView) findViewById(id.main_tab3);
title1.setOnClickListener(this);
title2.setOnClickListener(this);
title3.setOnClickListener(this);
titles.add(title1);
titles.add(title2);
titles.add(title3);
// create new fragments
pages.add(new MyFragment("tab1", Color.BLUE));
pages.add(new MyFragment("tab2", Color.RED));
pages.add(new MyFragment("tab3", Color.CYAN));
// set adapter
pager.setAdapter(new MyAdapter(getSupportFragmentManager()));
pager.setOnPageChangeListener(this);
pager.setCurrentItem(0);
titles.get(0).setSelected(true);
}
// tablines
private void initTabline() {
tabline = findViewById(id.main_tab_line);
Display display = getWindow().getWindowManager().getDefaultDisplay();
DisplayMetrics outMetrics = new DisplayMetrics();
display.getMetrics(outMetrics);
mTabLineWidth = outMetrics.widthPixels / 3;
LayoutParams lp = tabline.getLayoutParams();
lp.width = mTabLineWidth;
tabline.setLayoutParams(lp);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case id.main_tab1:
pager.setCurrentItem(0, true);
break;
case id.main_tab2:
pager.setCurrentItem(1, true);
break;
case id.main_tab3:
pager.setCurrentItem(2, true);
break;
default:
break;
}
}
@Override
public void onPageScrollStateChanged(int arg0) {
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
LinearLayout.LayoutParams lp = (android.widget.LinearLayout.LayoutParams) tabline.getLayoutParams();
lp.leftMargin = (int) ((arg0 + arg1) * mTabLineWidth);
tabline.setLayoutParams(lp);
}
@Override
public void onPageSelected(int arg0) {
// set titles
for (int i = 0; i < titles.size(); i++) {
if (arg0 == i) {
titles.get(i).setSelected(true);
} else {
titles.get(i).setSelected(false);
}
}
}
// fragment
private class MyFragment extends Fragment {
private String text;
private int color;
public MyFragment(String text, int color) {
this.text = text;
this.color = color;
}
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
TextView tv = new TextView(MainActivity.this);
tv.setBackgroundColor(color);
tv.setText(text);
return tv;
}
}
// adapter
private class MyAdapter extends FragmentPagerAdapter {
public MyAdapter(FragmentManager fm) {
super(fm);
}
@Override
public int getCount() {
return pages.size();
}
@Override
public Fragment getItem(int arg0) {
return pages.get(arg0);
}
}
}
代碼中通過(guò)實(shí)現(xiàn)OnPageChangeListener接口手動(dòng)設(shè)置了頁(yè)面指示條的位置。
- android 中viewpager+fragment仿微信底部TAG完美漸變
- Android 開(kāi)發(fā)之BottomBar+ViewPager+Fragment實(shí)現(xiàn)炫酷的底部導(dǎo)航效果
- Android App中使用ViewPager+Fragment實(shí)現(xiàn)滑動(dòng)切換效果
- Android App中ViewPager與Fragment結(jié)合的一些問(wèn)題解決
- Android中ViewPager獲取當(dāng)前顯示的Fragment
- Android基于ViewPager Fragment實(shí)現(xiàn)選項(xiàng)卡
- Android中ViewPager實(shí)現(xiàn)滑動(dòng)指示條及與Fragment的配合
- Android實(shí)現(xiàn)Tab布局的4種方式(Fragment+TabPageIndicator+ViewPager)
- Android中ViewPager和Fragment的使用
- Android仿微信Viewpager-Fragment惰性加載(lazy-loading)
相關(guān)文章
Android沉浸式狀態(tài)欄實(shí)現(xiàn)
這篇文章主要介紹了Android沉浸式狀態(tài)欄實(shí)現(xiàn),即一體化狀態(tài)欄實(shí)現(xiàn),感興趣的小伙伴們可以參考一下2016-01-01
Android Activity啟動(dòng)模式之singleTask實(shí)例詳解
這篇文章主要介紹了Android Activity啟動(dòng)模式之singleTask,結(jié)合實(shí)例形式較為詳細(xì)的分析了singleTask模式的功能、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-01-01
Android編程獲取包名,版本信息及VersionName名稱的方法
這篇文章主要介紹了Android編程獲取包名,版本信息及VersionName名稱的方法,涉及Android包及版本相關(guān)操作函數(shù)使用技巧,需要的朋友可以參考下2016-10-10

