您好,登錄后才能下訂單哦!
本篇文章為大家展示了Android中怎么實(shí)現(xiàn)頁面翻轉(zhuǎn)功能,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
android:autoStart: 設(shè)置自動加載下一個Viewandroid:flipInterval:設(shè)置View之間切換的時(shí)間間隔android:inAnimation: 設(shè)置切換View的進(jìn)入動畫android:outAnimation:設(shè)置切換View的退出動畫
當(dāng)然同樣的在代碼中也可以設(shè)置:
isFlipping: 判斷View切換是否正在進(jìn)行setFilpInterval:設(shè)置View之間切換的時(shí)間間隔startFlipping: 開始View的切換,而且會循環(huán)進(jìn)行stopFlipping: 停止View的切換setOutAnimation:設(shè)置切換View的退出動畫setInAnimation: 設(shè)置切換View的進(jìn)入動畫showNext: 顯示ViewFlipper里的下一個ViewshowPrevious: 顯示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)時(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 代表“拖過”動作在橫向、縱向,上的速度。?abstract void onL ongPress(MotionEvente):當(dāng)用戶手指在屏幕上長按時(shí)觸發(fā)該方法。?boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY):當(dāng)用戶手指在屏幕上“滾動”時(shí)觸發(fā)該方法。?void onShowPress(MotionEvent e):當(dāng)用戶手指在觸摸屏上按下,而且還未移動和松開時(shí)觸發(fā)該方法。?boolean onSingleTapUp(MotionEvent e): 用戶手指在觸摸屏上的輕擊事件將會觸發(fā)該方法。
*使用Android的手勢檢測只需兩個步驟。
?創(chuàng)建一個GestureDetector 對象。創(chuàng)建該對象時(shí)必須實(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)滑動時(shí)停止自動翻轉(zhuǎn) if (e1.getX()-e2.getX()>distance){ //當(dāng)從右向左滑動時(shí)// viewFlipper.setInAnimation(animations[0]); // viewFlipper.setOutAnimation(animations[1]); viewFlipper.showPrevious(); //返回上一張視圖 return true; }if (e2.getX()-e1.getX()>distance){ //當(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(); //開始自動翻轉(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) { }}
上述內(nèi)容就是Android中怎么實(shí)現(xiàn)頁面翻轉(zhuǎn)功能,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。