0
点赞
收藏
分享

微信扫一扫

Android实现图片浏览器应用(手势滑动)

贵州谢高低 2022-05-03 阅读 28

实现图片浏览器应用

效果图:

在这里插入图片描述
代码:

Activity

package com.example.application;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;

        import android.view.GestureDetector;
        import android.view.MotionEvent;
        import android.widget.ImageView;


public class MainActivity extends AppCompatActivity {
    // 定义保存ImageView的对象
    private ImageView imageView;
    //定义手势检测器对象
    private GestureDetector gestureDetector;
    //定义图片的资源数组
    private int[] ResId = new int[]{
            R.drawable.picture0, R.drawable.picture1, R.drawable.picture2,
            R.drawable.picture3, R.drawable.picture4, R.drawable.picture5,
            R.drawable.picture6, R.drawable.picture7, R.drawable.picture8,
            R.drawable.picture9, R.drawable.picture10, R.drawable.picture11,
            R.drawable.picture12
    };
    //定义当前显示的图片的下标
    private int count = 0;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);
        findView();
        setListener();
    }

    private void setListener() {
        //设置手势监听器的处理效果由onGestureListener来处理
        gestureDetector = new GestureDetector(MainActivity.this,
                onGestureListener);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        //当前Activity被触摸时回调
        return gestureDetector.onTouchEvent(event);
    }

    private void findView() {
        //得到当前页面的imageview控件
        imageView = (ImageView) findViewById(R.id.imageView);
    }
    //定义了GestureDetector的手势识别监听器
    private GestureDetector.OnGestureListener onGestureListener
            = new GestureDetector.SimpleOnGestureListener() {
        //当识别的收拾是滑动手势时回调onFinger方法
        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
                               float velocityY) {
            //得到滑动手势的其实和结束点的x,y坐标,并进行计算
            float x = e2.getX() - e1.getX();
            float y = e2.getY() - e1.getY();

            //通过计算结果判断用户是向左滑动或者向右滑动
            if (x > 0) {
                count++;
                count %= 13;
            } else if (x < 0) {
                count--;
                count = (count + 13) % 13;
            }
            //切换imageview的图片
            changeImg();
            return true;
        }
    };

    public void changeImg() {
        //设置当前位置的图片资源
        imageView.setImageResource(ResId[count]);
    }



}

Layout

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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=".MainActivity">

        <ImageView
            android:id="@+id/imageView"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:srcCompat="@drawable/picture0" />
</RelativeLayout>
举报

相关推荐

0 条评论