安卓学习笔记5.3 按钮、图像视图与图像按钮
创始人
2024-04-05 04:55:59
0

文章目录

  • 零、本讲学习目标
  • 一、导入新课
    • 二、新课讲解
    • (一)按钮控件
      • 1、继承关系图
      • 2、常用属性
    • (二)图像视图
      • 1、继承关系图
      • 2、常用属性
    • (三)图像按钮
      • 1、继承关系图
      • 2、常用属性
    • (四)教学案例:通过按钮缩放图片
      • 1、创建安卓应用
      • 2、准备图片素材
      • 3、字符串资源文件
      • 4、主布局资源文件
      • 5、主界面类实现功能
      • 6、启动应用,查看效果
  • 三、归纳总结
  • 四、上机操作

零、本讲学习目标

  1. 熟练使用按钮和图像按钮
  2. 熟练使用图像视图显示图片

一、导入新课

  • 安卓应用中,按钮一般用于用户点击确认某项功能,当然也可以用图像按钮。显示图片,我们经常使用图像视图(ImageView)。一个界面最好能图文并茂,给用户较好的体验。

二、新课讲解

在这里插入图片描述

(一)按钮控件

1、继承关系图

  • Button是TextView的子类
    在这里插入图片描述

2、常用属性

属性含义
text文本内容
textSize文本字号,单位:sp
textColor文本颜色,#ff0000 - 红色
background背景颜色或背景图片
layout_height高度,单位:dp (wrap_content, match_parent)
layout_weight宽度,单位:dp (wrap_content, match_parent)
onClick单击事件(用于绑定事件处理方法)

(二)图像视图

1、继承关系图

  • ImageView是View的子类
    在这里插入图片描述

2、常用属性

属性含义
layout_height高度,单位:dp (wrap_content, match_parent)
layout_weight宽度,单位:dp (wrap_content, match_parent)
src源(用于设置图片源)
background背景(用于设置背景图片)
scaleType缩放类型(fitXY)
tint蒙版

(三)图像按钮

1、继承关系图

  • ImageButton是ImageView的子类
    在这里插入图片描述

2、常用属性

属性含义
layout_height高度,单位:dp (wrap_content, match_parent)
layout_weight宽度,单位:dp (wrap_content, match_parent)
src源(用于设置图片源)
background背景(用于设置背景图片)

(四)教学案例:通过按钮缩放图片

1、创建安卓应用

  • 基于Empty Activity模板创建安卓应用 - ZoomImageByButton
    在这里插入图片描述
  • 单击【Finish】按钮
    在这里插入图片描述

2、准备图片素材

  • 将三张图片拷贝到drawable目录
    在这里插入图片描述

3、字符串资源文件

  • 字符串资源文件 - strings.xml
    在这里插入图片描述
通过按钮缩放图片放大图片缩小图片

4、主布局资源文件

  • 主布局资源文件 - activity_main.xml
    在这里插入图片描述
  • 将默认的约束布局改成线性布局,设置相关属性
    在这里插入图片描述
  • 添加两个线性布局
    在这里插入图片描述
  • 在第一个子线性布局里添加两个按钮和一个图像按钮
    在这里插入图片描述
  • 在第二个子线性布局里添加一个图像控件,显示米老鼠
    在这里插入图片描述
  • 查看完整代码



  • 查看预览效果
    在这里插入图片描述

5、主界面类实现功能

  • 主界面类 - MainActivity
    在这里插入图片描述
  • 声明变量
    在这里插入图片描述
  • 通过资源标识符获取控件实例
    在这里插入图片描述
  • 获得屏幕尺寸
    在这里插入图片描述
  • 获取图像尺寸
    在这里插入图片描述
  • 编写【缩小图片】按钮单击事件处理方法
    在这里插入图片描述
  • 编写【放大图片】按钮单击事件处理方法
    在这里插入图片描述
  • 编写【关闭】图像按钮单击事件处理方法
    在这里插入图片描述
  • 查看完整代码
package net.hw.zoom_image;import androidx.appcompat.app.AppCompatActivity;import android.os.Bundle;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Toast;public class MainActivity extends AppCompatActivity {private ImageView ivMickey; // 米老鼠图像控件private double imageWidth; // 图像宽度private double imageHeight; // 图像高度private double screenWidth; // 手机屏幕宽度private double screenHeight; // 手机屏幕高度private double scale = 0.95; // 缩小比例@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// 利用布局资源文件设置用户界面setContentView(R.layout.activity_main);// 通过资源标识符获取控件实例ivMickey = findViewById(R.id.iv_mickey);// 获得屏幕尺寸screenWidth = getWindowManager().getDefaultDisplay().getWidth();screenHeight = getWindowManager().getDefaultDisplay().getHeight();// 获取图像尺寸imageWidth = ivMickey.getLayoutParams().width;imageHeight = ivMickey.getLayoutParams().height;}/*** 【缩小图片】按钮单击事件处理方法** @param view*/public void doShrinkImage(View view) {// 获取图像新尺寸int newWidth = (int) (imageWidth * scale);int newHeight = (int) (imageHeight * scale);// 按新尺寸设置图像(不能缩小为零,否则不能再放大)if (newWidth > 50) {// 按新尺寸设置图像ivMickey.setLayoutParams(new LinearLayout.LayoutParams(newWidth, newHeight));// 更新图像尺寸变量imageWidth = ivMickey.getLayoutParams().width;imageHeight = ivMickey.getLayoutParams().height;} else {Toast.makeText(this, "温馨提示:图片不能再缩小,要不然看不见咯~",Toast.LENGTH_SHORT).show();}}/*** 【放大图片】按钮单击事件处理方法** @param view*/public void doEnlargeImage(View view) {// 获取图像新尺寸int newWidth = (int) (imageWidth / scale);int newHeight = (int) (imageHeight / scale);// 按新尺寸设置图像(不能再放大,否则就出界了)if (newWidth < screenWidth) {// 按新尺寸设置图像ivMickey.setLayoutParams(new LinearLayout.LayoutParams(newWidth, newHeight));// 更新图像尺寸变量imageWidth = ivMickey.getLayoutParams().width;imageHeight = ivMickey.getLayoutParams().height;} else {Toast.makeText(this, "温馨提示:图片不能再放大,要不然就出界咯~",Toast.LENGTH_SHORT).show();}}/*** 【关闭】图像按钮单击事件处理方法** @param view*/public void doExit(View view) {finish(); // 关闭当前窗口}
}

6、启动应用,查看效果

  • 通过三个按钮来操作
    在这里插入图片描述
  • 录屏演示操作
    在这里插入图片描述

三、归纳总结

  • 回顾本节课所讲的内容,并通过提问的方式引导学生解答问题并给予指导。

四、上机操作

  • 形式:单独完成
  • 题目:切换缩放图片(泸职院掠影)
  • 要求:切换图片(通过普通按钮或者手势滑动);缩放图片(通过缩放按钮ZoomControls来实现)
    在这里插入图片描述

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...