Android ViewPager + Fragment實現滑動頁面

来源:https://www.cnblogs.com/cloudfloating/archive/2018/06/06/9147143.html
-Advertisement-
Play Games

效果: PagerData類: PagerFragment類: PagerActivity: fragment_pager: activity_pager: ...


效果:

PagerData類:

 1 package com.cloud.viewpagerdemo;
 2 
 3 import java.io.Serializable;
 4 
 5 class PagerData implements Serializable {
 6 
 7     private int mImageResId;
 8     private String mContent;
 9 
10     PagerData(int imageResId, String content) {
11         mImageResId = imageResId;
12         mContent = content;
13     }
14 
15     public int getImageResId() {
16         return mImageResId;
17     }
18 
19     public void setImageResId(int imageResId) {
20         mImageResId = imageResId;
21     }
22 
23     public String getContent() {
24         return mContent;
25     }
26 
27     public void setContent(String content) {
28         mContent = content;
29     }
30 }

PagerFragment類:

 1 package com.cloud.viewpagerdemo;
 2 
 3 import android.graphics.Outline;
 4 import android.os.Bundle;
 5 import android.support.annotation.NonNull;
 6 import android.support.annotation.Nullable;
 7 import android.support.v4.app.Fragment;
 8 import android.view.LayoutInflater;
 9 import android.view.View;
10 import android.view.ViewGroup;
11 import android.view.ViewOutlineProvider;
12 import android.widget.ImageView;
13 import android.widget.TextView;
14 
15 public class PagerFragment extends Fragment {
16 
17     private static final String ARG_DATA = "data";
18 
19     private PagerData mData;
20 
21     private ImageView mImageView;
22     private TextView mContent;
23 
24     /**
25      * 通過靜態方法獲取Fragment實例,向Fragment傳參數
26      * @param data 數據
27      * @return Fragment
28      */
29     public static PagerFragment newInstance(PagerData data) {
30         PagerFragment fragment = new PagerFragment();
31 
32         //使用FragmentArguments傳遞參數
33         Bundle args = new Bundle();
34         args.putSerializable(ARG_DATA, data);
35         fragment.setArguments(args);
36         return fragment;
37     }
38 
39     @Override
40     public void onCreate(@Nullable Bundle savedInstanceState) {
41         super.onCreate(savedInstanceState);
42         mData = (PagerData) getArguments().getSerializable(ARG_DATA);
43     }
44 
45     @Nullable
46     @Override
47     public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container,
48                              @Nullable Bundle savedInstanceState) {
49         View view = inflater.inflate(R.layout.fragment_pager, container, false);
50 
51         //綁定控制項
52         mImageView = view.findViewById(R.id.image_view);
53         mContent = view.findViewById(R.id.text_content);
54 
55         //ImageView設置圓角
56         ViewOutlineProvider viewOutlineProvider = new ViewOutlineProvider() {
57             @Override
58             public void getOutline(View view, Outline outline) {
59                 outline.setRoundRect(0, 0, mImageView.getWidth(), mImageView.getHeight(), 16);
60             }
61         };
62 
63         mImageView.setOutlineProvider(viewOutlineProvider);
64         mImageView.setClipToOutline(true);
65         mImageView.setImageResource(mData.getImageResId());
66         mContent.setText(mData.getContent());
67 
68         return view;
69     }
70 }

PagerActivity:

 1 package com.cloud.viewpagerdemo;
 2 
 3 import android.support.v4.app.Fragment;
 4 import android.support.v4.app.FragmentManager;
 5 import android.support.v4.app.FragmentStatePagerAdapter;
 6 import android.support.v4.view.ViewPager;
 7 import android.support.v7.app.AppCompatActivity;
 8 import android.os.Bundle;
 9 import android.widget.TextView;
10 
11 import java.util.ArrayList;
12 import java.util.List;
13 
14 public class PagerActivity extends AppCompatActivity {
15 
16     private List<PagerData> mPagerData = new ArrayList<>();
17 
18     private ViewPager mViewPager;
19     private TextView mTextPage;
20 
21     private String page = "1 / 3";
22 
23     @Override
24     protected void onCreate(Bundle savedInstanceState) {
25         super.onCreate(savedInstanceState);
26         setContentView(R.layout.activity_pager);
27 
28         initData();
29 
30         FragmentManager fragmentManager = getSupportFragmentManager();
31 
32         mViewPager = findViewById(R.id.view_pager);
33         mTextPage = findViewById(R.id.text_page);
34         //設置ViewPager適配器
35         mViewPager.setAdapter(new FragmentStatePagerAdapter(fragmentManager) {
36             @Override
37             public Fragment getItem(int position) {
38                 return PagerFragment.newInstance(mPagerData.get(position));
39             }
40 
41             @Override
42             public int getCount() {
43                 return mPagerData.size();
44             }
45         });
46 
47         //監聽頁面改變
48         mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
49             @Override
50             public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
51 
52             }
53 
54             @Override
55             public void onPageSelected(int position) {
56                 //頁面選中
57                 page = String.valueOf(position + 1) + " / " + String.valueOf(mPagerData.size());
58                 mTextPage.setText(page);
59             }
60 
61             @Override
62             public void onPageScrollStateChanged(int state) {
63 
64             }
65         });
66         //設置緩存頁數
67         mViewPager.setOffscreenPageLimit(3);
68         //設置預設頁
69         mViewPager.setCurrentItem(0);
70 
71         mTextPage.setText(page);
72     }
73 
74     private void initData() {
75         //添加三項數據
76         mPagerData.add(new PagerData(R.drawable.img_0, "Photo by Adam Krowitz"));
77         mPagerData.add(new PagerData(R.drawable.img_1, "Photo by Samuel Ferrara"));
78         mPagerData.add(new PagerData(R.drawable.img_2, "Photo by Earth"));
79     }
80 }

fragment_pager:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <android.support.constraint.ConstraintLayout
 3     xmlns:android="http://schemas.android.com/apk/res/android"
 4     xmlns:app="http://schemas.android.com/apk/res-auto"
 5     xmlns:tools="http://schemas.android.com/tools"
 6     android:layout_width="match_parent"
 7     android:layout_height="match_parent">
 8 
 9     <LinearLayout
10         android:layout_width="match_parent"
11         android:layout_height="match_parent"
12         android:layout_marginBottom="32dp"
13         android:layout_marginEnd="16dp"
14         android:layout_marginStart="16dp"
15         android:layout_marginTop="16dp"
16         android:background="@drawable/pager_background"
17         android:elevation="4dp"
18         android:orientation="vertical"
19         app:layout_constraintBottom_toBottomOf="parent"
20         app:layout_constraintEnd_toEndOf="parent"
21         app:layout_constraintStart_toStartOf="parent"
22         app:layout_constraintTop_toTopOf="parent">
23 
24         <ImageView
25             android:id="@+id/image_view"
26             android:layout_width="match_parent"
27             android:layout_height="0dp"
28             android:layout_margin="8dp"
29             android:layout_weight="1"
30             android:contentDescription="@null"
31             android:scaleType="centerCrop" />
32 
33         <TextView
34             android:id="@+id/text_content"
35             android:layout_width="match_parent"
36             android:layout_height="125dp"
37             android:gravity="center"
38             android:padding="8dp"
39             android:textSize="18sp"
40             android:textColor="#000000"
41             tools:text="Content" />
42 
43     </LinearLayout>
44 
45 </android.support.constraint.ConstraintLayout>

activity_pager:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <android.support.constraint.ConstraintLayout
 3     xmlns:android="http://schemas.android.com/apk/res/android"
 4     xmlns:app="http://schemas.android.com/apk/res-auto"
 5     xmlns:tools="http://schemas.android.com/tools"
 6     android:layout_width="match_parent"
 7     android:layout_height="match_parent"
 8     tools:context=".PagerActivity">
 9 
10     <android.support.v7.widget.Toolbar
11         android:id="@+id/toolbar"
12         android:layout_width="match_parent"
13         android:layout_height="48dp"
14         android:background="@color/colorPrimary"
15         android:elevation="4dp"
16         app:layout_constraintEnd_toEndOf="parent"
17         app:layout_constraintStart_toStartOf="parent"
18         app:layout_constraintTop_toTopOf="parent">
19 
20         <TextView
21             android:layout_width="wrap_content"
22             android:layout_height="wrap_content"
23             android:layout_gravity="center"
24             android:textSize="18sp"
25             android:textColor="#FFFFFF"
26             android:text="@string/app_name" />
27 
28     </android.support.v7.widget.Toolbar>
29 
30     <android.support.v4.view.ViewPager
31         android:id="@+id/view_pager"
32         android:layout_width="0dp"
33         android:layout_height="0dp"
34         app:layout_constraintBottom_toBottomOf="parent"
35         app:layout_constraintEnd_toEndOf="parent"
36         app:layout_constraintStart_toStartOf="parent"
37         app:layout_constraintTop_toBottomOf="@+id/toolbar">
38 
39     </android.support.v4.view.ViewPager>
40 
41     <TextView
42         android:id="@+id/text_page"
43         android:layout_width="wrap_content"
44         android:layout_height="wrap_content"
45         android:layout_marginBottom="4dp"
46         app:layout_constraintBottom_toBottomOf="parent"
47         app:layout_constraintEnd_toEndOf="parent"
48         app:layout_constraintStart_toStartOf="@+id/toolbar"
49         tools:text="page" />
50 
51 </android.support.constraint.ConstraintLayout>

 


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

-Advertisement-
Play Games
更多相關文章
  • 第1章 初探大數據 本章將介紹為什麼要學習大數據、如何學好大數據、如何快速轉型大數據崗位、本項目實戰課程的內容安排、本項目實戰課程的前置內容介紹、開發環境介紹。同時為大家介紹項目中涉及的Hadoop、Hive相關的知識 第2章 Spark及其生態圈概述 Spark作為近幾年最火爆的大數據處理技術,是 ...
  • 實驗案例一:驗證索引的作用 1、首先創建一個數據量大的表,名稱為“學生表”,分別有三列,學號,姓名和班級,如下圖所示,學號為自動編號,班級為預設值“一班”。 2、向表中插入大量數據,數據越多,驗證索引的效果越好。 使用語句完成:While 1>0 Insert into 學生表(姓名) values ...
  • 數據中心是智慧保護區的信息倉庫,為整個信息化平臺的高效運營提供豐富的數據源,全面支撐保護區各項應用。數據中心主要是通過保護區基礎資料庫建設工程的實施,通過規範生物多樣性信息分類、採集存儲、處理、交換和服務的標準,建成基礎資料庫。按照統一標準、共建共用、互聯互通的原則,以高端、集約、安全為目標,加強林 ...
  • 佛曰:“不可說,說既是錯”,所以本篇也是錯! 技術人的世界是一塊凈土,也許世界並不該這麼複雜。 ——KK 這篇感悟也許帶著些許悲涼、無奈,也許又帶著激情滿滿,也許還透著辛酸。 技術男 很多人眼裡的技術宅是[傻傻的] [情商低的] [不愛說話的][邋遢的]....當然也有一些好詞 [踏實] [誠實] ...
  • Kafka中存在大量的延遲操作,比如延遲生產、延遲拉取以及延遲刪除等。Kafka並沒有使用JDK自帶的Timer或者DelayQueue來實現延遲的功能,而是基於時間輪自定義了一個用於實現延遲功能的定時器(SystemTimer)。JDK的Timer和DelayQueue插入和刪除操作的平均時間複雜 ...
  • today,i'll using the open source tool named "binlog2sql" which is release by danfengchao to do some flashback test. here's the github address:https:// ...
  • 隨機查詢,方法可以有很多種。比如,查詢出所有記錄,然後隨機從列表中取n條記錄。使用程式便可實現。可是程式實現必須查詢出所有符合條件的記錄(至少是所有符合條件的記錄id),然後再隨機取出n個id,查詢資料庫。但是效率畢竟沒有資料庫中直接查詢得快。下麵介紹mysql中怎樣隨機查詢n條記錄。 1.最簡單的 ...
  • since i've broken down the replication enviornment by "reset master;" yesterday.therefore,i'd like to reconfigure it again,there're several simple ste ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...