Android應(yīng)用中利用ViewPager實(shí)現(xiàn)多頁面滑動切換效果示例
1、添加android support包
因?yàn)樯厦娴膸讉€類都是在android support包中才提供,我們先添加包。
在Eclipse->Window->Android SDK Manager,選擇列表中Extras->Android Support Library進(jìn)行安裝。下載完后在android-sdk\extras\android\support目錄下,這里我們選擇v4版本,進(jìn)入v4目錄,拷貝其中的android-support-v4.jar文件到工程的libs目錄(若沒有新建)下即可,編譯時ADT會自動將其導(dǎo)入項(xiàng)目中。
2、新建ViewPager的layout,內(nèi)容如下
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <android.support.v4.view.ViewPager android:id="@+id/viewPager" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" > <android.support.v4.view.PagerTabStrip android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="top" /> </android.support.v4.view.ViewPager> </LinearLayout>
ViewPager用來管理layout并可以左右滑動顯示各個頁面數(shù)據(jù),PagerTabStrip用來顯示頁面title,android:layout_gravity="top"表示title在頂部,可設(shè)置bottom等。
3、新建FragmentActivity頁面
FragmentActivity頁面含有ViewPager元素,可以用來顯示Fragment,定義如下:
public class ViewPagerDemo extends FragmentActivity { /** 頁面list **/ List<Fragment> fragmentList = new ArrayList<Fragment>(); /** 頁面title list **/ List<String> titleList = new ArrayList<String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.view_pager_demo); ViewPager vp = (ViewPager)findViewById(R.id.viewPager); fragmentList.add(new ViewPagerFragment1("頁面1")); fragmentList.add(new ViewPagerFragment1("頁面2")); fragmentList.add(new ViewPagerFragment1("頁面3")); titleList.add("title 1 "); titleList.add("title 2 "); titleList.add("title 3 "); vp.setAdapter(new myPagerAdapter(getSupportFragmentManager(), fragmentList, titleList)); } /** * 定義適配器 */ class myPagerAdapter extends FragmentPagerAdapter { private List<Fragment> fragmentList; private List<String> titleList; public myPagerAdapter(FragmentManager fm, List<Fragment> fragmentList, List<String> titleList){ super(fm); this.fragmentList = fragmentList; this.titleList = titleList; } /** * 得到每個頁面 */ @Override public Fragment getItem(int arg0) { return (fragmentList == null || fragmentList.size() == 0) ? null : fragmentList.get(arg0); } /** * 每個頁面的title */ @Override public CharSequence getPageTitle(int position) { return (titleList.size() > position) ? titleList.get(position) : ""; } /** * 頁面的總個數(shù) */ @Override public int getCount() { return fragmentList == null ? 0 : fragmentList.size(); } } }
其中的myPagerAdapter集成自ragmentPagerAdapter,為ViewPager提供數(shù)據(jù)源。
onCreate函數(shù)得到ViewPager實(shí)例并設(shè)置數(shù)據(jù)源,getSupportFragmentManager表示得到Fragment管理器。ViewPagerFragment1表示具體的頁面,見下面介紹。
4、新建Fragment頁面
Fragment頁面即為左右滑動需要顯示的頁面,新建類集成Fragment,并重寫onCreateView函數(shù)即可。onCreateView函數(shù)相當(dāng)于Activity的onCreate函數(shù)。如下:
public class ViewPagerFragment1 extends Fragment { private String text; private TextView tv = null; public ViewPagerFragment1(String text){ super(); this.text = text; } /** * 覆蓋此函數(shù),先通過inflater inflate函數(shù)得到view最后返回 */ @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View v = inflater.inflate(R.layout.view_pager_fragment_demo1, container, false); tv = (TextView)v.findViewById(R.id.viewPagerText); tv.setText(text); return v; } }
5、示例工程代碼:
package cn.trinea.android.demo; import java.util.ArrayList; import java.util.List; import android.os.Bundle; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; import android.support.v4.view.ViewPager; public class ViewPagerDemo extends BaseFragmentActivity { private static int TOTAL_COUNT = 3; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState, R.layout.view_pager_demo); ViewPager vp = (ViewPager)findViewById(R.id.view_pager); List<Fragment> fragmentList = new ArrayList<Fragment>(); List<String> titleList = new ArrayList<String>(); for (int i = 0; i < TOTAL_COUNT; i++) { ViewPagerFragment viewPagerFragment1 = new ViewPagerFragment(); Bundle bundle = new Bundle(); bundle.putInt("upImageId", 0); bundle.putString("text", "Page " + i); viewPagerFragment1.setArguments(bundle); titleList.add("title " + i); fragmentList.add(viewPagerFragment1); } vp.setAdapter(new myPagerAdapter(getSupportFragmentManager(), fragmentList, titleList)); } class myPagerAdapter extends FragmentPagerAdapter { private List<Fragment> fragmentList; private List<String> titleList; public myPagerAdapter(FragmentManager fm, List<Fragment> fragmentList, List<String> titleList) { super(fm); this.fragmentList = fragmentList; this.titleList = titleList; } @Override public Fragment getItem(int arg0) { return (fragmentList == null || fragmentList.size() == 0) ? null : fragmentList.get(arg0); } @Override public CharSequence getPageTitle(int position) { return (titleList.size() > position) ? titleList.get(position) : ""; } @Override public int getCount() { return fragmentList == null ? 0 : fragmentList.size(); } } }
簡單效果如下:
- Android如何使用ViewPager2實(shí)現(xiàn)頁面滑動切換效果
- Android HorizontalScrollView滑動與ViewPager切換案例詳解
- Android使用TabLayou+fragment+viewpager實(shí)現(xiàn)滑動切換頁面效果
- Android ViewPager撤消左右滑動切換功能實(shí)現(xiàn)代碼
- Android開發(fā)之使用ViewPager實(shí)現(xiàn)圖片左右滑動切換效果
- Android中的ViewPager視圖滑動切換類的入門實(shí)例教程
- Android App中使用ViewPager+Fragment實(shí)現(xiàn)滑動切換效果
- Android編程實(shí)現(xiàn)ViewPager多頁面滑動切換及動畫效果的方法
- Android實(shí)現(xiàn)界面左右滑動切換功能
- Android開發(fā)之ViewPager實(shí)現(xiàn)滑動切換頁面
相關(guān)文章
Flutter?webview與網(wǎng)頁通訊交互實(shí)現(xiàn)
最近要在Flutter項(xiàng)目的基礎(chǔ)上加一個實(shí)時定位的功能,下面這篇文章主要給大家介紹了關(guān)于Flutter?webview與網(wǎng)頁通訊交互實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04Android為按鈕控件綁定事件的五種實(shí)現(xiàn)方式
本篇文章主要是介紹了Android為按鈕控件綁定事件的五種實(shí)現(xiàn)方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2016-11-11Android實(shí)現(xiàn)顯示和隱藏密碼功能的示例代碼
在前端中我們知道用javascript就可以可以很容易實(shí)現(xiàn)密碼的顯示與隱藏,本文將大家詳細(xì)介紹Android是如何實(shí)現(xiàn)顯示和隱藏密碼功能的,需要的可以參考一下2022-06-06Android中如何實(shí)現(xiàn)清空搜索框的文字
本文主要介紹Android中實(shí)現(xiàn)清空搜索框的文字的方法。項(xiàng)目中的有關(guān)搜索的地方,加上清空文字的功能,目的是為了增加用戶體驗(yàn),使用戶刪除文本更加快捷。需要的朋友一起來看下吧2016-12-12Android面向切面基于AOP實(shí)現(xiàn)登錄攔截的場景示例
這篇文章主要為大家介紹了Android面向切面基于AOP實(shí)現(xiàn)登錄攔截的場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08