Android中使用ViewPager實現屏幕頁面切換和頁面切換效果

来源:http://www.cnblogs.com/panhouye/archive/2016/12/01/6123950.html
-Advertisement-
Play Games

之前關於如何實現屏幕頁面切換,寫過一篇博文《Android中使用ViewFlipper實現屏幕切換》,相比ViewFlipper,ViewPager更適用複雜的視圖切換,而且Viewpager有自己的adapter,這也讓其適應複雜對象,實現數據的動態載入。 ViewPager是谷歌官方給我們提供的 ...


之前關於如何實現屏幕頁面切換,寫過一篇博文《Android中使用ViewFlipper實現屏幕切換》,相比ViewFlipper,ViewPager更適用複雜的視圖切換,而且Viewpager有自己的adapter,這也讓其適應複雜對象,實現數據的動態載入。

ViewPager是谷歌官方給我們提供的一個相容低版本安卓設備的軟體包,裡面包囊了只有在安卓3.0以上可以使用的api。而viewpager就是其中之一,利用它,我們可以做很多事情,從最簡單的導航,到頁面菜單等等。

下麵我們就展示下ViewPager可以實現的兩種簡單效果:

第一種:屏幕的頁面的切換(與ViewFlipper的實現效果類似)

實現效果如下(4張視圖(layout)):

第一步:在layout佈局文件裡加入主佈局文件viewpager_layout.xml

 

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:orientation="vertical" android:layout_width="match_parent"
 4     android:layout_height="match_parent">
 5     <android.support.v4.view.ViewPager
 6         android:layout_width="match_parent"
 7         android:layout_height="match_parent"
 8         android:layout_gravity="center"
 9         android:gravity="center"
10         android:id="@+id/vp">
11         <android.support.v4.view.PagerTabStrip
12             android:layout_width="match_parent"
13             android:layout_height="wrap_content"
14             android:id="@+id/tap">
15         </android.support.v4.view.PagerTabStrip>
16     </android.support.v4.view.ViewPager>
17 </LinearLayout>

 

註意事項:    

<1、這裡ViewPager和PagerTabStrip都要把包名寫全了,不然會ClassNotFound

<2、API中說:在佈局xml把PagerTabStrip當做ViewPager的一個子標簽來用,不能拿出來,不然還是會報錯   

<3、在PagerTabStrip標簽中可以用屬性android:layout_gravity=TOP|BOTTOM來指定title的位置

<4、如果要顯示出PagerTabStrip某一頁的title,需要在ViewPager的adapter中實現getPageTitle(int)

第二步:在layout中建立要展示切換的視圖文件(示例中共四個layout1/2/3/4.xml,這裡寫一個典型):

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     xmlns:app="http://schemas.android.com/apk/res-auto"
 4     android:orientation="vertical" android:layout_width="match_parent"
 5     android:layout_height="match_parent">
 6     <ImageView
 7         android:layout_width="match_parent"
 8         android:layout_height="match_parent"
 9         android:src="@mipmap/a1"
10         android:scaleType="centerCrop"
11         android:id="@+id/iv1" />
12 </LinearLayout>

第三步:Java中Activity的實現代碼ViewPagerDemo.java(這裡未設置pagerTabStrip的屬性):

在Activity里實例化ViewPager組件,並設置它的Adapter(就是PagerAdapter,方法與ListView一樣的)

實現一個PagerAdapter,覆蓋以下方法:

instantiateItem(ViewGroup, int)//用來實例化頁卡

destroyItem(ViewGroup, int, Object)//刪除頁卡

getCount() //返回頁卡的數量

isViewFromObject(View, Object)//判斷兩個對象是否相等

getPageTitle(int position)//設置標簽顯示的標題

設置指示標簽的屬性

pagerTabStrip.setTabIndicatorColor();//指示器的顏色

pagerTabStrip.setBackgroundColor();//背影色

pagerTabStrip.setTextColor(Color.WHITE);//字體顏色

 1 import android.os.Bundle;
 2 import android.support.annotation.Nullable;
 3 import android.support.v4.view.PagerAdapter;
 4 import android.support.v4.view.ViewPager;
 5 import android.support.v7.app.AppCompatActivity;
 6 import android.view.View;
 7 import android.view.ViewGroup;
 8 import java.util.ArrayList;
 9 /**
10  * Created by panchengjia on 2016/12/1.
11  */
12 public class ViewPagerDemo extends AppCompatActivity {
13     private ViewPager vp;
14     //聲明存儲ViewPager下子視圖的集合
15     ArrayList<View> views = new ArrayList<>();
16     //顯示效果中每個視圖的標題
17     String[] titles={"一號美女","二號美女","三號美女","四號美女"};
18     @Override
19     protected void onCreate(@Nullable Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.viewpager_layout);
22         vp= (ViewPager) findViewById(R.id.vp);
23         initView();//調用初始化視圖方法
24         vp.setAdapter(new MyAdapter());//設置適配器
25 }
26 //初始化視圖的方法(通過佈局填充器獲取用於滑動的視圖並存入對應的的集合)
27     private void initView() {
28         View v1 = getLayoutInflater().inflate(R.layout.layout1,null);
29         View v2 = getLayoutInflater().inflate(R.layout.layout2,null);
30         View v3 = getLayoutInflater().inflate(R.layout.layout3,null);
31         View v4 = getLayoutInflater().inflate(R.layout.layout4,null);
32         views.add(v1);
33         views.add(v2);
34         views.add(v3);
35         views.add(v4);
36     }
37     class MyAdapter extends PagerAdapter{
38         @Override
39         public int getCount() {
40             return views.size();
41         }
42         @Override
43         public boolean isViewFromObject(View view, Object object) {
44             return view==object;
45         }
46         //重寫銷毀滑動視圖佈局(將子視圖移出視圖存儲集合(ViewGroup))
47         @Override
48         public void destroyItem(ViewGroup container, int position, Object object) {
49             container.removeView(views.get(position));
50         }
51         //重寫初始化滑動視圖佈局(從視圖集合中取出對應視圖,添加到ViewGroup)
52         @Override
53         public Object instantiateItem(ViewGroup container, int position) {
54             View v =views.get(position);
55             container.addView(v);
56             return v;
57         }
58         @Override
59         public CharSequence getPageTitle(int position) {
60             return titles[position];
61         }
62     }
63 }

第二種:頁面輪播效果視圖(程式首次啟動的引導頁實現)

實現效果如下(3張視圖滑動引導):

開始代碼前註釋:1、本次未實現迴圈輪播效果;2、導航原點資源圖片註解:default_holo為未選中狀態,touched_holo為選中後實心狀態。(也可自己用Shape繪製)

 

第一步:在layout佈局文件裡加入主佈局文件viewpager_layout.xml

 

主佈局為FrameLayout,在ViewPager(這裡因為存在導航原點,不設置PagerTabStrip)上嵌套包含3個導航原點(由滑動視圖數量決定)的linearLayout佈局(本次設置該佈局位於底部):

 

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <FrameLayout
 3     xmlns:android="http://schemas.android.com/apk/res/android"
 4     xmlns:tools="http://schemas.android.com/tools"
 5     android:id="@+id/activity_main"
 6     android:layout_width="match_parent"
 7     android:layout_height="match_parent"
 8     tools:context="com.example.administrator.myapplication11.MainActivity">
 9     <android.support.v4.view.ViewPager
10         android:layout_width="match_parent"
11         android:layout_height="match_parent"
12         android:id="@+id/vp">
13     </android.support.v4.view.ViewPager>
14     <LinearLayout
15         android:id="@+id/point_layout"
16         android:layout_width="match_parent"
17         android:layout_height="wrap_content"
18         android:layout_gravity="bottom"
19         android:orientation="horizontal">
20         <ImageView
21             android:layout_width="0dp"
22             android:layout_height="wrap_content"
23             android:layout_weight="1"
24             android:src="@mipmap/default_holo"/>
25         <ImageView
26             android:layout_width="0dp"
27             android:layout_height="wrap_content"
28             android:layout_weight="1"
29             android:src="@mipmap/default_holo" />
30         <ImageView
31             android:layout_width="0dp"
32             android:layout_height="wrap_content"
33             android:layout_weight="1"
34             android:src="@mipmap/default_holo"
35             android:id="@+id/imageView" />
36     </LinearLayout>
37 </FrameLayout>

 

第二步:Layout中用於滑動切換的視圖(示例中共三個layout1/2/3.xml,這裡寫一個典型)與第一種相同

 

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:orientation="vertical" android:layout_width="match_parent"
 4     android:layout_height="match_parent">
 5     <ImageView
 6         android:layout_width="match_parent"
 7         android:layout_height="match_parent"
 8         android:scaleType="centerCrop"
 9         android:src="@mipmap/genie"/>
10 </LinearLayout>

 

第三步:Java中Activity的實現代碼MainActivity.java

 

通過實現OnPageChangeListener介面實現在視圖切換時導航原點狀態的變化),其中關於OnPageChangeListener中方法的詳細解釋,請參考博文

 

ViewPager的setOnPageChangeListener方法詳解這裡不做贅述:

 

 1 import android.support.v4.view.PagerAdapter;
 2 import android.support.v4.view.ViewPager;
 3 import android.support.v7.app.AppCompatActivity;
 4 import android.os.Bundle;
 5 import android.view.View;
 6 import android.view.ViewGroup;
 7 import android.widget.ImageView;
 8 import android.widget.LinearLayout;
 9 import java.util.ArrayList;
10 /**
11  * Created by panchengjia on 2016/11/30.
12  */
13 public class MainActivity extends AppCompatActivity implements ViewPager.OnPageChangeListener{
14     private ViewPager vp;
15     private LinearLayout point_layout;
16     ArrayList<View> views =new ArrayList<>();
17     //實例化存儲imageView(導航原點)的集合
18     ArrayList<ImageView> imageViews = new ArrayList<>();
19     int currImage;//記錄當前頁(導航原點)
20     @Override
21     protected void onCreate(Bundle savedInstanceState) {
22         super.onCreate(savedInstanceState);
23         setContentView(R.layout.activity_main);
24         vp= (ViewPager) findViewById(R.id.vp);
25         initView();//調用初始化視圖方法
26         initPoint();//調用初始化導航原點的方法
27         vp.addOnPageChangeListener(this);
28         vp.setAdapter(new MyAdapter());
29     }
30     /*將point_layout中包含的imageView(導航原點)添加到imageViewS集合中
31      *並設置layout1(第一視圖)的導航原點(對應集合0下標)的圖片
32      * 為touched_holo(觸摸狀態的圖片)
33      */
34     private void initPoint() {
35         point_layout= (LinearLayout) findViewById(R.id.point_layout);
36         int counnt = point_layout.getChildCount();//獲取point數量
37         for (int i=0;i<counnt;i++){
38             imageViews.add((ImageView) point_layout.getChildAt(i));
39         }
40         imageViews.get(0).setImageResource(R.mipmap.touched_holo);
41     }
42     private void initView() {
43         View v1=getLayoutInflater().inflate(R.layout.layout1,null);
44         View v2=getLayoutInflater().inflate(R.layout.layout2,null);
45         View v3=getLayoutInflater().inflate(R.layout.layout3,null);
46         views.add(v1);
47         views.add(v2);
48         views.add(v3);
49     }
50     //OnPageChangeListener的方法,這裡不做具體實現
51     @Override
52     public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
53 
54     }
55     //設置滑動到對應位置的視圖後,導航原點的不同狀態(圖片)
56     @Override
57 public void onPageSelected(int position) {
58         ImageView preView = imageViews.get(currImage);
59         preView.setImageResource(R.mipmap.default_holo);
60         ImageView currView = imageViews.get(position);
61         currView.setImageResource(R.mipmap.touched_holo);
62         currImage = position;
63     }
64     //OnPageChangeListener的方法,這裡不做具體實現
65     @Override
66     public void onPageScrollStateChanged(int state) {
67 
68     }
69     class MyAdapter extends PagerAdapter {
70         @Override
71         public int getCount() {
72             return views.size();
73         }
74         @Override
75         public boolean isViewFromObject(View view, Object object) {
76             return view==object;
77         }
78         @Override
79         public void destroyItem(ViewGroup container, int position, Object object) {
80             container.removeView(views.get(position));
81         }
82         @Override
83         public Object instantiateItem(ViewGroup container, int position) {
84             View v = views.get(position);
85             container.addView(v);
86             return v;
87         }
88     }
89 }

 

至此,本次的ViewPager實現示例所需代碼已完成,當然這隻是ViewPager最簡單的功能,後續還會更新一些ViewPager的高級用法,歡迎小伙伴們繼續支持。

當然篇幅所限,這隻是ViewPager最最簡單的功能,
作者: 去吧皮卡丘
鏈接:http://www.imooc.com/article/2580
來源:慕課網 當然篇幅所限,這隻是ViewPager最最簡單的功能,
作者: 去吧皮卡丘
鏈接:http://www.imooc.com/article/2580
來源:慕課網當然這隻是ViewPager最簡單的功能,後續還會更新一些ViewPager的高級用法,歡迎小伙伴們繼續支持。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 閱讀目錄 前言 明確業務細節 建模 實現 結語 一、前言 上一篇我們已經確立的購買上下文和銷售上下文的交互方式,傳送門在此:http://www.cnblogs.com/Zachary-Fan/p/DDD_6.html,本篇我們來實現售價上下文的具體細節。 二、明確業務細節 電商市場越來越成熟,競爭 ...
  • 前面寫過了使用ViewFlipper和ViewPager實現屏幕中視圖切換的效果(ViewPager未實現輪播)附鏈接: Android中使用ViewFlipper實現屏幕切換 Android中使用ViewPager實現屏幕頁面切換和頁面切換效果 今天我們在換一種實現方式ImageViewSwitc ...
  • 活動的啟動模式對我們來說是個新的概念,在實際項目中我們會根據活動的需求為每個活動指定恰當的啟動模式。共分為四種分別是:standard,singletop,singletast,singleinstance,可以在androidMainfest.xml中進得指定,android:launchMode... ...
  • 當運行下一個活動時,上一個活動被K掉了,當我們返回上一個活動時,系統會重啟create一個活動,問題來了我們之前在保存的數據怎麼辦?onSaveInstanceState可以用這個方法來進行保存,鍵值對[ke,"value"],其實和Intent一樣,也是通過這樣保存。 ...
  • 今天碰到了在XML中應用以內部類形式定義的自定義view,結果遇到了一些坑。雖然通過看了一些前輩寫的文章解決了這個問題,但是我看到的幾篇都沒有完整說清楚why,於是決定做這個總結。 使用自定義內部類view的規則 本文主要是總結why,所以先把XML佈局文件中引用內部類的自定義view的做法擺出來, ...
  • 三級緩存的提出就是為了提升用戶體驗。當我們第一次打開應用獲取圖片時,先到網路去下載圖片,然後依次存入記憶體緩存,磁碟緩存,當我們再一次需要用到剛纔下載的這張圖片時,就不需要再重覆的到網路上去下載,直接可以從記憶體緩存和磁碟緩存中找,由於記憶體緩存速度較快,我們優先到記憶體緩存中尋找該圖片,如果找到則運用,如 ...
  • 最近解決了一個Android APP的bug,發現APP在被後臺清理後,會自動重啟。現象很奇怪,有的手機(HTC)後臺清理後,程式會再次重啟,而有的手機(小米)則不會。猜想可能是小米手機內部做了處理,當執行後臺清理後,對應的APP不會再重啟了。 Debug後發現,APP內部有一個Service,在S ...
  • 散列表的具體實現就不多做介紹了,就是一個數組,每個下標存儲的是碰撞的元素的鏈表頭指針,如下圖所示: 下麵直接研究對用鏈接法散列的分析: 給定一個能存放n個元素的、具有m個槽位的散列表T,定義T的裝載因數α為n/m,即一個鏈中平均存儲的元素數。 用鏈接法散列的最壞情況性能很差:所有的n個關鍵字都散列到 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...