Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動(dòng)翻轉(zhuǎn)功能
1. 效果圖,本功能用了ViewFlipper和GestureDetector (手勢(shì)檢測(cè)器)兩個(gè)關(guān)鍵技術(shù)點(diǎn):

2. 先寫好布局文件,這里用到了ViewFlipper類,用于切換視圖,畢竟ViewFlipper見得少,先介紹一下。
在xml布局中的方法介紹:
android:autoStart: 設(shè)置自動(dòng)加載下一個(gè)View
android:flipInterval:設(shè)置View之間切換的時(shí)間間隔
android:inAnimation: 設(shè)置切換View的進(jìn)入動(dòng)畫
android:outAnimation:設(shè)置切換View的退出動(dòng)畫
當(dāng)然同樣的在代碼中也可以設(shè)置:
isFlipping: 判斷View切換是否正在進(jìn)行
setFilpInterval:設(shè)置View之間切換的時(shí)間間隔
startFlipping: 開始View的切換,而且會(huì)循環(huán)進(jìn)行
stopFlipping: 停止View的切換
setOutAnimation:設(shè)置切換View的退出動(dòng)畫
setInAnimation: 設(shè)置切換View的進(jìn)入動(dòng)畫
showNext: 顯示ViewFlipper里的下一個(gè)View
showPrevious: 顯示ViewFlipper里的上一個(gè)View
<?xml version="1.0" encoding="utf-8"?> <LinearLayout 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" android:orientation="vertical" tools:context=".slide.Main2Activity"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content"> <Button android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:onClick="start" android:text="開始自動(dòng)翻頁" /> <Button android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:onClick="stop" android:text="停止自動(dòng)翻頁" /> </LinearLayout> <ViewFlipper android:id="@+id/activity_main2_vf" android:layout_width="match_parent" android:layout_height="match_parent" android:flipInterval="1500"></ViewFlipper> //flipInterval 實(shí)現(xiàn)自動(dòng)翻轉(zhuǎn)時(shí)添加,值為每頁翻轉(zhuǎn)的時(shí)間 </LinearLayout>
3. 接下來是代碼部分,首頁介紹一下GestureDetector :
GestureDetector.OnGestureListener里包含的事件處理方法如下:
➢boolean onDown(MotionEvent e):當(dāng)觸碰事件按下時(shí)觸發(fā)該方法。
➢boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY):當(dāng)用戶手指在觸摸屏_上“拖過”時(shí)觸發(fā)該方法。其中velocityX、velocityY 代表“拖過”動(dòng)作在橫向、縱向,上的速度。
➢abstract void onL ongPress(MotionEvente):當(dāng)用戶手指在屏幕上長按時(shí)觸發(fā)該方法。
➢boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY):當(dāng)用戶手指在屏幕上“滾動(dòng)”時(shí)觸發(fā)該方法。
➢void onShowPress(MotionEvent e):當(dāng)用戶手指在觸摸屏上按下,而且還未移動(dòng)和松開時(shí)觸發(fā)該方法。
➢boolean onSingleTapUp(MotionEvent e): 用戶手指在觸摸屏上的輕擊事件將會(huì)觸發(fā)該方法。
*使用Android的手勢(shì)檢測(cè)只需兩個(gè)步驟。
➊創(chuàng)建一個(gè)GestureDetector 對(duì)象。創(chuàng)建該對(duì)象時(shí)必須實(shí)現(xiàn)一個(gè)GestureDetector.OnGestureListener監(jiān)聽器實(shí)例。
❷為應(yīng)用程序的Activity (偶爾也可為特定組件)的TouchEvent事件綁定監(jiān)聽器(對(duì)應(yīng)gestureDetector = new GestureDetector(this, this);),在事件處理中指定把Activity (或特定組件),上的TouchEvent事件交給GestureDetector處理。(對(duì)應(yīng)return gestureDetector.onTouchEvent(event);)*
package com.example.mygesture.slide;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.ViewFlipper;
import com.example.mygesture.R;
public class Main2Activity extends AppCompatActivity implements GestureDetector.OnGestureListener { //實(shí)現(xiàn)手勢(shì)檢測(cè)器接口
GestureDetector gestureDetector; //定義手勢(shì)檢測(cè)器
ViewFlipper viewFlipper;
// Animation[] animations=new Animation[4]; //注釋的部分為添加動(dòng)畫效果
int distance=50;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
init();
}
private void init() {
gestureDetector = new GestureDetector(this, this);//實(shí)例化GestureDetector
viewFlipper=findViewById(R.id.activity_main2_vf);
viewFlipper.addView(addImageView(R.drawable.q1));//添加圖片
viewFlipper.addView(addImageView(R.drawable.q2));
viewFlipper.addView(addImageView(R.drawable.q3));
viewFlipper.addView(addImageView(R.drawable.q4));
// animations[0]=AnimationUtils.loadAnimation(this,R.anim.left_in);
// animations[1]=AnimationUtils.loadAnimation(this,R.anim.left_out);
// animations[2]=AnimationUtils.loadAnimation(this,R.anim.right_in);
// animations[3]=AnimationUtils.loadAnimation(this,R.anim.right_out);
}
private View addImageView(int resId) {
ImageView imageView=new ImageView(this);
imageView.setImageResource(resId);
imageView.setScaleType(ImageView.ScaleType.CENTER);
return imageView;
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
viewFlipper.stopFlipping(); //當(dāng)滑動(dòng)時(shí)停止自動(dòng)翻轉(zhuǎn)
if (e1.getX()-e2.getX()>distance){ //當(dāng)從右向左滑動(dòng)時(shí)
// viewFlipper.setInAnimation(animations[0]);
// viewFlipper.setOutAnimation(animations[1]);
viewFlipper.showPrevious(); //返回上一張視圖
return true;
}if (e2.getX()-e1.getX()>distance){ //當(dāng)從左向右滑動(dòng)時(shí)
// viewFlipper.setInAnimation(animations[2]);
// viewFlipper.setOutAnimation(animations[3]);
viewFlipper.showNext(); //切換下一張視圖
return true;
}
return false;
}
@Override
public boolean onTouchEvent(MotionEvent event) {
return gestureDetector.onTouchEvent(event); //綁定觸摸事件
}
public void start(View view) {
viewFlipper.startFlipping(); //開始自動(dòng)翻轉(zhuǎn),與flipInterval配套使用,缺一不可
}
public void stop(View view) {
viewFlipper.stopFlipping(); //停止自動(dòng)翻轉(zhuǎn)
}
@Override
public boolean onDown(MotionEvent e) {
return false;
}
@Override
public void onShowPress(MotionEvent e) {
}
@Override
public boolean onSingleTapUp(MotionEvent e) {
return false;
}
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
return false;
}
@Override
public void onLongPress(MotionEvent e) {
}
}
簡(jiǎn)單的翻頁效果已經(jīng)完成了
總結(jié)
以上所述是小編給大家介紹的Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動(dòng)翻轉(zhuǎn)功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- Android實(shí)現(xiàn)卡片翻轉(zhuǎn)動(dòng)畫
- Android實(shí)現(xiàn)文字翻轉(zhuǎn)動(dòng)畫的效果
- Android利用Camera實(shí)現(xiàn)中軸3D卡牌翻轉(zhuǎn)效果
- Android實(shí)現(xiàn)圖片反轉(zhuǎn)、翻轉(zhuǎn)、旋轉(zhuǎn)、放大和縮小
- Android實(shí)現(xiàn)Flip翻轉(zhuǎn)動(dòng)畫效果
- Android動(dòng)畫之3D翻轉(zhuǎn)效果實(shí)現(xiàn)函數(shù)分析
- Android圖片翻轉(zhuǎn)動(dòng)畫簡(jiǎn)易實(shí)現(xiàn)代碼
相關(guān)文章
Android?實(shí)例代碼帶你掌握FrameLayout
FrameLayout是Android開發(fā)中非常常見的布局組件,并且它不單單是一個(gè)幀布局組件,可以用它實(shí)現(xiàn)多種功能,感興趣的朋友一起來看看吧2022-03-03
Android實(shí)現(xiàn)簡(jiǎn)單加法計(jì)算器
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡(jiǎn)單加法計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
Android自定義圓環(huán)倒計(jì)時(shí)控件
這篇文章主要為大家詳細(xì)介紹了Android自定義圓環(huán)倒計(jì)時(shí)控件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
Android實(shí)現(xiàn)屏幕截圖并保存截圖到指定文件
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)屏幕截圖并保存截取圖片到指定文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10
Android使用NumberPicker實(shí)現(xiàn)滑輪日期選擇器
這篇文章主要為大家介紹了如何使用Android中的NumberPicker控件,以一種簡(jiǎn)單而直觀的方式實(shí)現(xiàn)滑輪式的日期選擇器,需要的小伙伴可以參考一下2023-06-06
Kotlin語言使用BroadcastReceiver示例介紹
Android開發(fā)的四大組件分別是:活動(dòng)(activity),用于表現(xiàn)功能;服務(wù)(service),后臺(tái)運(yùn)行服務(wù),不提供界面呈現(xiàn);廣播接受者(Broadcast Receive),勇于接收廣播;內(nèi)容提供者(Content Provider),支持多個(gè)應(yīng)用中存儲(chǔ)和讀取數(shù)據(jù),相當(dāng)于數(shù)據(jù)庫,本篇著重介紹廣播組件2022-09-09

