Android?ViewPager?+?Fragment實(shí)現(xiàn)滑動(dòng)頁(yè)面效果
效果:

PagerData類(lèi):
package com.cloud.viewpagerdemo;
import java.io.Serializable;
class PagerData implements Serializable {
private int mImageResId;
private String mContent;
PagerData(int imageResId, String content) {
mImageResId = imageResId;
mContent = content;
}
public int getImageResId() {
return mImageResId;
}
public void setImageResId(int imageResId) {
mImageResId = imageResId;
}
public String getContent() {
return mContent;
}
public void setContent(String content) {
mContent = content;
}
}PagerFragment類(lèi):
package com.cloud.viewpagerdemo;
import android.graphics.Outline;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewOutlineProvider;
import android.widget.ImageView;
import android.widget.TextView;
public class PagerFragment extends Fragment {
private static final String ARG_DATA = "data";
private PagerData mData;
private ImageView mImageView;
private TextView mContent;
/**
* 通過(guò)靜態(tài)方法獲取Fragment實(shí)例,向Fragment傳參數(shù)
* @param data 數(shù)據(jù)
* @return Fragment
*/
public static PagerFragment newInstance(PagerData data) {
PagerFragment fragment = new PagerFragment();
//使用FragmentArguments傳遞參數(shù)
Bundle args = new Bundle();
args.putSerializable(ARG_DATA, data);
fragment.setArguments(args);
return fragment;
}
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mData = (PagerData) getArguments().getSerializable(ARG_DATA);
}
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container,
@Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_pager, container, false);
//綁定控件
mImageView = view.findViewById(R.id.image_view);
mContent = view.findViewById(R.id.text_content);
//ImageView設(shè)置圓角
ViewOutlineProvider viewOutlineProvider = new ViewOutlineProvider() {
@Override
public void getOutline(View view, Outline outline) {
outline.setRoundRect(0, 0, mImageView.getWidth(), mImageView.getHeight(), 16);
}
};
mImageView.setOutlineProvider(viewOutlineProvider);
mImageView.setClipToOutline(true);
mImageView.setImageResource(mData.getImageResId());
mContent.setText(mData.getContent());
return view;
}
}PagerActivity:
package com.cloud.viewpagerdemo;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
public class PagerActivity extends AppCompatActivity {
private List<PagerData> mPagerData = new ArrayList<>();
private ViewPager mViewPager;
private TextView mTextPage;
private String page = "1 / 3";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_pager);
initData();
FragmentManager fragmentManager = getSupportFragmentManager();
mViewPager = findViewById(R.id.view_pager);
mTextPage = findViewById(R.id.text_page);
//設(shè)置ViewPager適配器
mViewPager.setAdapter(new FragmentStatePagerAdapter(fragmentManager) {
@Override
public Fragment getItem(int position) {
return PagerFragment.newInstance(mPagerData.get(position));
}
@Override
public int getCount() {
return mPagerData.size();
}
});
//監(jiān)聽(tīng)頁(yè)面改變
mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
//頁(yè)面選中
page = String.valueOf(position + 1) + " / " + String.valueOf(mPagerData.size());
mTextPage.setText(page);
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
//設(shè)置緩存頁(yè)數(shù)
mViewPager.setOffscreenPageLimit(3);
//設(shè)置默認(rèn)頁(yè)
mViewPager.setCurrentItem(0);
mTextPage.setText(page);
}
private void initData() {
//添加三項(xiàng)數(shù)據(jù)
mPagerData.add(new PagerData(R.drawable.img_0, "Photo by Adam Krowitz"));
mPagerData.add(new PagerData(R.drawable.img_1, "Photo by Samuel Ferrara"));
mPagerData.add(new PagerData(R.drawable.img_2, "Photo by Earth"));
}
}fragment_pager:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginBottom="32dp"
android:layout_marginEnd="16dp"
android:layout_marginStart="16dp"
android:layout_marginTop="16dp"
android:background="@drawable/pager_background"
android:elevation="4dp"
android:orientation="vertical"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<ImageView
android:id="@+id/image_view"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_margin="8dp"
android:layout_weight="1"
android:contentDescription="@null"
android:scaleType="centerCrop" />
<TextView
android:id="@+id/text_content"
android:layout_width="match_parent"
android:layout_height="125dp"
android:gravity="center"
android:padding="8dp"
android:textSize="18sp"
android:textColor="#000000"
tools:text="Content" />
</LinearLayout>
</android.support.constraint.ConstraintLayout>activity_pager:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".PagerActivity">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="48dp"
android:background="@color/colorPrimary"
android:elevation="4dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:textSize="18sp"
android:textColor="#FFFFFF"
android:text="@string/app_name" />
</android.support.v7.widget.Toolbar>
<android.support.v4.view.ViewPager
android:id="@+id/view_pager"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/toolbar">
</android.support.v4.view.ViewPager>
<TextView
android:id="@+id/text_page"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="4dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/toolbar"
tools:text="page" />
</android.support.constraint.ConstraintLayout>總結(jié)
以上所述是小編給大家介紹的Android ViewPager + Fragment實(shí)現(xiàn)滑動(dòng)頁(yè)面效果,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Android實(shí)現(xiàn)系統(tǒng)打印功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)系統(tǒng)打印功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
Android動(dòng)態(tài)更新Menu菜單的實(shí)現(xiàn)過(guò)程
菜單是用戶界面中最常見(jiàn)的元素之一,使用非常頻繁,下面這篇文章主要給大家介紹了關(guān)于Android動(dòng)態(tài)更新Menu菜單的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
Android實(shí)戰(zhàn)打飛機(jī)游戲之無(wú)限循環(huán)的背景圖(2)
這篇文章主要為大家詳細(xì)介紹了Android實(shí)戰(zhàn)打飛機(jī)游戲之無(wú)限循環(huán)的背景圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07
Android實(shí)現(xiàn)文件上傳和下載倒計(jì)時(shí)功能的圓形進(jìn)度條
這篇文章主要介紹了Android實(shí)現(xiàn)文件上傳和下載倒計(jì)時(shí)功能的圓形進(jìn)度條,需要的朋友可以參考下2017-09-09
Android常用三方庫(kù)混淆規(guī)則整理(小結(jié))
這篇文章主要介紹了Android常用三方庫(kù)混淆規(guī)則整理(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
Android Studio升級(jí)3.6 Build窗口出現(xiàn)中文亂碼問(wèn)題解決方法
這篇文章主要介紹了Android Studio升級(jí)3.6 Build窗口出現(xiàn)中文亂碼問(wèn)題解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
android判斷一個(gè)Activity是否處于棧頂?shù)膶?shí)例
下面小編就為大家分享一篇android判斷一個(gè)Activity是否處于棧頂?shù)膶?shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
android studio 3.4配置Android -jni 開(kāi)發(fā)基礎(chǔ)的教程詳解
這篇文章主要介紹了android studio 3.4配置Android -jni 開(kāi)發(fā)基礎(chǔ),本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09

