Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能
1. 效果圖,本功能用了ViewFlipper和GestureDetector (手勢檢測器)兩個關(guān)鍵技術(shù)點(diǎn):
2. 先寫好布局文件,這里用到了ViewFlipper類,用于切換視圖,畢竟ViewFlipper見得少,先介紹一下。
在xml布局中的方法介紹:
android:autoStart: 設(shè)置自動加載下一個View
android:flipInterval:設(shè)置View之間切換的時間間隔
android:inAnimation: 設(shè)置切換View的進(jìn)入動畫
android:outAnimation:設(shè)置切換View的退出動畫
當(dāng)然同樣的在代碼中也可以設(shè)置:
isFlipping: 判斷View切換是否正在進(jìn)行
setFilpInterval:設(shè)置View之間切換的時間間隔
startFlipping: 開始View的切換,而且會循環(huán)進(jìn)行
stopFlipping: 停止View的切換
setOutAnimation:設(shè)置切換View的退出動畫
setInAnimation: 設(shè)置切換View的進(jìn)入動畫
showNext: 顯示ViewFlipper里的下一個View
showPrevious: 顯示ViewFlipper里的上一個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="開始自動翻頁" /> <Button android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:onClick="stop" android:text="停止自動翻頁" /> </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)自動翻轉(zhuǎn)時添加,值為每頁翻轉(zhuǎn)的時間 </LinearLayout>
3. 接下來是代碼部分,首頁介紹一下GestureDetector :
GestureDetector.OnGestureListener里包含的事件處理方法如下:
➢boolean onDown(MotionEvent e):當(dāng)觸碰事件按下時觸發(fā)該方法。
➢boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY):當(dāng)用戶手指在觸摸屏_上“拖過”時觸發(fā)該方法。其中velocityX、velocityY 代表“拖過”動作在橫向、縱向,上的速度。
➢abstract void onL ongPress(MotionEvente):當(dāng)用戶手指在屏幕上長按時觸發(fā)該方法。
➢boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY):當(dāng)用戶手指在屏幕上“滾動”時觸發(fā)該方法。
➢void onShowPress(MotionEvent e):當(dāng)用戶手指在觸摸屏上按下,而且還未移動和松開時觸發(fā)該方法。
➢boolean onSingleTapUp(MotionEvent e): 用戶手指在觸摸屏上的輕擊事件將會觸發(fā)該方法。
*使用Android的手勢檢測只需兩個步驟。
➊創(chuàng)建一個GestureDetector 對象。創(chuàng)建該對象時必須實(shí)現(xiàn)一個GestureDetector.OnGestureListener監(jiān)聽器實(shí)例。
❷為應(yīng)用程序的Activity (偶爾也可為特定組件)的TouchEvent事件綁定監(jiān)聽器(對應(yīng)gestureDetector = new GestureDetector(this, this);),在事件處理中指定把Activity (或特定組件),上的TouchEvent事件交給GestureDetector處理。(對應(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)手勢檢測器接口 GestureDetector gestureDetector; //定義手勢檢測器 ViewFlipper viewFlipper; // Animation[] animations=new Animation[4]; //注釋的部分為添加動畫效果 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)滑動時停止自動翻轉(zhuǎn) if (e1.getX()-e2.getX()>distance){ //當(dāng)從右向左滑動時 // viewFlipper.setInAnimation(animations[0]); // viewFlipper.setOutAnimation(animations[1]); viewFlipper.showPrevious(); //返回上一張視圖 return true; }if (e2.getX()-e1.getX()>distance){ //當(dāng)從左向右滑動時 // 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(); //開始自動翻轉(zhuǎn),與flipInterval配套使用,缺一不可 } public void stop(View view) { viewFlipper.stopFlipping(); //停止自動翻轉(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) { } }
簡單的翻頁效果已經(jīng)完成了
總結(jié)
以上所述是小編給大家介紹的Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對我們網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
上一篇:Android實(shí)現(xiàn)沉浸式狀態(tài)欄功能
欄 目:Android
下一篇:android 使用okhttp可能引發(fā)OOM的一個點(diǎn)
本文標(biāo)題:Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能
本文地址:http://mengdiqiu.com.cn/a1/Android/9161.html
您可能感興趣的文章
- 01-10Android自定義View之繪制圓形頭像功能
- 01-10Android實(shí)現(xiàn)雙擊返回鍵退出應(yīng)用實(shí)現(xiàn)方法詳解
- 01-10android實(shí)現(xiàn)記住用戶名和密碼以及自動登錄
- 01-10android實(shí)現(xiàn)簡單計算器功能
- 01-10Android 友盟第三方登錄與分享的實(shí)現(xiàn)代碼
- 01-10C++自定義API函數(shù)實(shí)現(xiàn)大數(shù)相乘算法
- 01-10如何給Flutter界面切換實(shí)現(xiàn)點(diǎn)特效
- 01-10android實(shí)現(xiàn)指紋識別功能
- 01-10Emoji表情在Android JNI中的兼容性問題詳解
- 01-10Android實(shí)現(xiàn)圓形漸變加載進(jìn)度條


閱讀排行
本欄相關(guān)
- 01-10Android自定義View之繪制圓形頭像功能
- 01-10Android實(shí)現(xiàn)雙擊返回鍵退出應(yīng)用實(shí)現(xiàn)方
- 01-10android實(shí)現(xiàn)簡單計算器功能
- 01-10android實(shí)現(xiàn)記住用戶名和密碼以及自動
- 01-10C++自定義API函數(shù)實(shí)現(xiàn)大數(shù)相乘算法
- 01-10Android 友盟第三方登錄與分享的實(shí)現(xiàn)代
- 01-10android實(shí)現(xiàn)指紋識別功能
- 01-10如何給Flutter界面切換實(shí)現(xiàn)點(diǎn)特效
- 01-10Android實(shí)現(xiàn)圓形漸變加載進(jìn)度條
- 01-10Emoji表情在Android JNI中的兼容性問題詳
隨機(jī)閱讀
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10delphi制作wav文件的方法
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子