安卓基础学习 Day18|按键事件+手势操作(图片的放大、缩小、切换)

目录

一、按键事件的概念

二、案例演示

1.提出要求

 2.主布局资源文件

3.主界面

一、触摸事件的概述

触摸分类

触摸动作

触摸监听器

触摸方法

触点个数与坐标

二、单点触摸

案例:移动米老鼠

提出要求

 主布局资源文件

主界面

 三、多点缩放

案例:缩放米老鼠

提出要求

  主布局资源文件

主界面

四、手势切换照片 

1.手势操作原理

2.安卓手势类与接口

MotionEvent

GestureDetector

OnGestureListener

3.案例操作

1.提出要求

2. 下载喜欢的图片并存放在res/mipmap中

3.主布局资源文件

 4.主界面

一、按键事件的概念

按键事件:用户按下或者释放手机键盘上的某个界面时产生的事件

监听器是:View.OnKeyListener

事件处理方法是:onKey()

二、案例演示

1.提出要求

通过按上、下、左、右方向键来移动米老鼠。

 2.主布局资源文件

将布局设置为线性布局,并在里面插入一张图片

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/root"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <ImageView
        android:id="@+id/iv_mickey"
        android:layout_width="100dp"
        android:layout_height="130dp"
        android:src="@mipmap/mickey"
        android:scaleType="fitXY" />

</LinearLayout>

效果

3.主界面

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    //声明变量
    protected static final int STEP = 10;
    private ImageView ivMickey;
    private LinearLayout root;
    private LinearLayout.LayoutParams layoutParams;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //利用布局资源文件设置用户界面
        setContentView(R.layout.activity_main);
        //通过资源索引获取控件实例
        ivMickey = findViewById(R.id.iv_mickey);
        root = findViewById(R.id.root);

        //设置根布局可以获取焦点
        root.setFocusable(true);
        //让根布局获取焦点
        root.requestFocus();

        //获取图像控件的布局参数
        layoutParams = (LinearLayout.LayoutParams) ivMickey.getLayoutParams();

        //给根布局注册监听器
        root.setOnKeyListener(new View.OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event) {
                switch (keyCode) {
                    //根据按键修改图像控件的布局参数
                    case KeyEvent.KEYCODE_DPAD_UP://按上方按键
                        //上边界碰撞检测
                        if (ivMickey.getTop() >= 10) {
                            layoutParams.topMargin = layoutParams.topMargin - STEP;
                        } else {
                            Toast.makeText(MainActivity.this, "碰到上边界", Toast.LENGTH_SHORT).show();
                        }
                        break;
                    case KeyEvent.KEYCODE_DPAD_DOWN://按下方按键
                        layoutParams.topMargin = layoutParams.topMargin + STEP;
                        break;
                    case KeyEvent.KEYCODE_DPAD_LEFT://按左方按键
                        layoutParams.leftMargin = layoutParams.leftMargin - STEP;
                        break;
                    case KeyEvent.KEYCODE_DPAD_RIGHT://按右方按键
                        layoutParams.leftMargin = layoutParams.leftMargin + STEP;
                        break;
                }
                //重新获取图像控件的布局参数
                ivMickey.setLayoutParams(layoutParams);

                return false;
            }
        });
    }
}

效果展示:

这里只有上边缘的碰撞检测,现在对剩下的三边添加代码进行碰撞检测

switch (keyCode) {
                    //根据按键修改图像控件的布局参数
                    case KeyEvent.KEYCODE_DPAD_UP://按上方按键
                        //上边界碰撞检测
                        if (ivMickey.getTop() >= 10) {
                            layoutParams.topMargin = layoutParams.topMargin - STEP;
                        } else {
                            Toast.makeText(MainActivity.this, "碰到上边界", Toast.LENGTH_SHORT).show();
                        }
                        break;
                    case KeyEvent.KEYCODE_DPAD_DOWN://按下方按键
                        //下边界碰撞检测
                        if (ivMickey.getBottom() <= 1800) {
                            layoutParams.topMargin = layoutParams.topMargin + STEP;
                        } else {
                            Toast.makeText(MainActivity.this, "碰到下边界", Toast.LENGTH_SHORT).show();
                        }
                        break;
                    case KeyEvent.KEYCODE_DPAD_LEFT://按左方按键
                        //左边界碰撞检测
                        if (ivMickey.getLeft() >= 0) {
                            layoutParams.leftMargin = layoutParams.leftMargin - STEP;
                        } else {
                            Toast.makeText(MainActivity.this, "碰到左边界", Toast.LENGTH_SHORT).show();
                        }
                        break;
                    case KeyEvent.KEYCODE_DPAD_RIGHT://按右方按键
                        //右边界碰撞检测
                        if (ivMickey.getRight() &
  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鲁不吃猪蹄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值