Android獲取觸摸手勢實現左右滑動
本文實例為大傢分享瞭Android獲取觸摸手勢實現左右滑動的具體代碼,供大傢參考,具體內容如下
一、Android提供的兩種手勢:
①Android提供瞭手勢檢測,並為手勢提供瞭相應的監聽器
②Android允許開發者添加手勢,並提供瞭相應的API識別用戶手勢
二、手勢檢測:手勢檢測器類:GestureDetector
監聽器:OnGestureListener,負責對用戶的手勢行為提供響應
時間處理方法:boolean OnDraw(MotionEvent e):當觸摸事件按下時觸發該方法
boolean OnFing(MotionEvent e1,MotionEvent e2,float velocity X,float velocity Y):當用戶在觸摸屏上“拖過”時觸發該方法。其中 velocity X,float velocity Y代表“拖過”動作在橫向,縱向上的速度
abstract void onLongPress(MotionEvent e):當用戶在屏幕上長按時觸發該方法
onScroll(MotionEvent e,MotionEvent e2,float distanceX,float distanceY):當用戶在屏幕上“滾動”時觸發該方法
void onShowPress(MotionEvent e):當用戶在觸摸屏上按下,而還未移動和松開時觸發該方法
Android收拾檢測步驟:第一步:創建一個GestureDetector對象。創建該對象時必須實現一個GestureDetector.OnGestureListener監聽器實例:例如:GestureDetector detector=new GestureDetector(this,this)
應用程序的Activity的TouchEvent事件綁定監聽器,在事件處理中指定Activity上的TouchEvent事件交給GestureDetector處理。例如:detector.OnTouchEvent(event)
例子:①演示事件處理的方法
②通過手勢實現翻頁效果:
ViewFlipper組件,該組件可使用動畫控制多個組件之間的切換效果
flipper.setInAnimation()設置組件進入的動畫
flipper.setOutAnimation()設置組件出去的動畫
flipper.showPrevious()顯示上一個視圖
flipper.showNext()顯示下一個視圖
1.MXL如下:
<?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" tools:context="com.example.android_gesture.MainActivity"> <ViewFlipper android:id="@+id/rs_ViewFlipper" android:layout_width="match_parent" android:layout_height="match_parent" > </ViewFlipper> </LinearLayout>
2.樣式
類名:left.in.xml //進
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true" android:duration="1000" > <translate android:fromXDelta="-100%p" android:toXDelta="0" ></translate> </set>
類名:left.out.xml //出
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true" android:duration="1000" > <translate android:fromXDelta="0" android:toXDelta="-100%p" ></translate> </set>
類名:fight.in.xml //進
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true" android:duration="1000" > <translate android:fromXDelta="100%p" android:toXDelta="0" ></translate> </set>
類名:fight.out.xml //出
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true" android:duration="1000" > <translate android:fromXDelta="0" android:toXDelta="100%p" ></translate> </set>
3.實現JAVA類
package com.example.android_gesture; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.View; import android.widget.ImageView; import android.widget.Toast; import android.widget.ViewFlipper; public class MainActivity extends AppCompatActivity { private ViewFlipper rs_viewFlipper; private int image[]={R.drawable.s2,R.drawable.s4,R.drawable.s9}; private GestureDetector gd; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); rs_viewFlipper = (ViewFlipper) findViewById(R.id.rs_ViewFlipper); for (int i = 0; i <image.length ; i++) { ImageView images=new ImageView(this); images.setImageResource(image[i]); rs_viewFlipper.addView(images); } //實例化手勢檢測器類 gd = new GestureDetector(this, new GestureDetector.OnGestureListener() { @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) {//長按 } @Override//拖動 public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { if(e1.getX()-e2.getX()>100){//右滑下一張 rs_viewFlipper.showNext(); //設置效果圖右滑下一張的樣式,一張圖片進,一張圖片出 rs_viewFlipper.setInAnimation(MainActivity.this,R.anim.right_in); rs_viewFlipper.setOutAnimation(MainActivity.this,R.anim.left_out); Toast.makeText(MainActivity.this, "右滑下一張", Toast.LENGTH_SHORT).show(); } if(e2.getX()-e1.getX()>100){//左滑上一張 rs_viewFlipper.showPrevious(); //設置效果圖左滑上一張的樣式,一張圖片進,一張圖片出 rs_viewFlipper.setInAnimation(MainActivity.this,R.anim.left_in); rs_viewFlipper.setOutAnimation(MainActivity.this,R.anim.right_out); Toast.makeText(MainActivity.this, "左滑上一張", Toast.LENGTH_SHORT).show(); } return false; } }); } @Override//觸摸事件 public boolean onTouchEvent(MotionEvent event) { return gd.onTouchEvent(event); } }
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Android實現ViewFlipper圖片動畫滑動
- android viewflipper實現左右滑動切換顯示圖片
- Android使用ViewFlipper實現圖片上下自動輪播的示例代碼
- Android使用kotlin實現多行文本上下滾動播放
- android 實現側邊彈窗特效代碼