溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android中怎么實(shí)現(xiàn)頁面翻轉(zhuǎn)功能

發(fā)布時(shí)間:2021-08-07 14:29:28 來源:億速云 閱讀:138 作者:Leah 欄目:編程語言

本篇文章為大家展示了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è)資訊頻道。

向AI問一下細(xì)節(jié)

免責(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)容。

AI