Android——Click事件实现方式

低功耗蓝牙项目,需要一块懂省电的板

思澈 SF32LB52 芯片,BLE 协议栈深度优化,上手即开发

Android观察者模式(Observer Design Pattern):在对象之间定义⼀个⼀对多的依赖,当⼀个对象状态改变
的时候,所有依赖的对象都会得到通知并⾃动更新。说⼈话:也叫发布订阅模式,能够很好的解耦一个对象改变,⾃动改变另⼀个对象这种情况。
①、Subject 被观察者
定义被观察者必须实现的职责, 它必须能够动态地增加、 取消观察者。 它⼀般是抽象类或者是实现
类, 仅仅完成作为被观察者必须实现的职责: 管理观察者并通知观察者。
②、Observer观察者
观察者接收到消息后, 即进⾏update(更新⽅法) 操作, 对接收到的信息进⾏处理。
③、ConcreteSubject具体的被观察者
定义被观察者⾃⼰的业务逻辑, 同时定义对哪些事件进⾏通知。
④、ConcreteObserver具体的观察者
每个观察在接收到消息后的处理反应是不同, 各个观察者有自己的处理逻辑。

一、匿名类

MainActivity代码:

package com.example.click;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

import android.widget.Toast;

import androidx.activity.EdgeToEdge;

import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity{

    private Button button1,button2,button3,button4,button5,button6,button7,button8;

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        EdgeToEdge.enable(this);

        setContentView(R.layout.activity_main);

        button1=findViewById(R.id.button1);

        button1.setOnClickListener(new View.OnClickListener() {

            @Override

            public void onClick(View view) {

                Toast.makeText(MainActivity.this,"匿名函数",Toast.LENGTH_SHORT).show();

            }

       });

}

}

以上代码(用于 Android 开发)做了以下几件事:

  1. 定义 MainActivity 类继承自 AppCompatActivity,声明了 8 个按钮变量。
  2. 在 onCreate 方法中,先调用父类 onCreate 完成初始化,接着启用可能与屏幕边缘显示相关的功能,然后设置界面布局。
  3. 从布局里找到 id 为 button1 的按钮,给它添加点击事件监听器,点击该按钮时会弹出显示 “匿名函数” 的 Toast 提示框。

运行效果图如下:

点击button1可看见匿名函数

二、内部类

MainActivity代码:

package com.example.click;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

import android.widget.Toast;

import androidx.activity.EdgeToEdge;

import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    private Button button1, button2, button3, button4, button5, button6, button7, button8;

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        EdgeToEdge.enable(this);

        setContentView(R.layout.activity_main);

        button2 = findViewById(R.id.button2);

        button3 = findViewById(R.id.button3);

        button4 = findViewById(R.id.button4);

        button2.setOnClickListener(new MyClickListener());

        button3.setOnClickListener(new MyClickListener());

        button4.setOnClickListener(new MyClickListener());

}

private class MyClickListener implements View.OnClickListener {

       @Override

       public void onClick(View view) {

            if (view.getId() == R.id.button2) {

                Toast.makeText(MainActivity.this, "内部类1", Toast.LENGTH_SHORT).show();

            } else if (view.getId() == R.id.button3) {

                Toast.makeText(MainActivity.this, "内部类2", Toast.LENGTH_SHORT).show();

            } else {

                Toast.makeText(MainActivity.this, "内部类3", Toast.LENGTH_SHORT).show();

              }

         }

    }

}

以上代码(用于 Android 开发)做了以下几件事:

  1. 定义 MainActivity 类继承 AppCompatActivity,声明了 8 个按钮变量。
  2. 在 onCreate 方法中,先执行父类 onCreate 初始化,启用屏幕边缘相关功能,设置界面布局,然后获取 id 为 button2button3button4 的按钮。
  3. 为这三个按钮设置点击事件监听器,使用自定义的内部类 MyClickListener 实现。点击 button2 弹出显示 “内部类 1” 的 Toast 提示,点击 button3 弹出 “内部类 2” 的 Toast 提示,点击 button4 弹出 “内部类 3” 的 Toast 提示。

运行效果图如下:

分别点击 button2, button3, button4,即可看到内部类1,内部类2,内部类3

三、继承接口

MainActivity代码:

package com.example.click;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

import android.widget.Toast;

import androidx.activity.EdgeToEdge;

import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity implements View.OnClickListener{

    private Button button1,button2,button3,button4,button5,button6,button7,button8;

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        EdgeToEdge.enable(this);

        setContentView(R.layout.activity_main);

        button5=findViewById(R.id.button5);

        button6=findViewById(R.id.button6);

        button7=findViewById(R.id.button7);

        button5.setOnClickListener(this);

        button6.setOnClickListener(this);

        button7.setOnClickListener(this);

}

@Override

public void onClick(View view) {

     if(view.getId()==R.id.button5){

           Toast.makeText(MainActivity.this,"继承接口1",Toast.LENGTH_SHORT).show();

         }

     else if(view.getId()==R.id.button6){

           Toast.makeText(MainActivity.this,"继承接口2",Toast.LENGTH_SHORT).show();

         }

     else{

           Toast.makeText(MainActivity.this,"继承接口3",Toast.LENGTH_SHORT).show();

         }

 }

}

以上代码(用于 Android 开发)做了以下几件事:

  1. 类的定义与继承、接口实现
    定义了 MainActivity 类,该类继承自 AppCompatActivity,同时实现了 View.OnClickListener 接口,意味着这个类既要具备 AppCompatActivity 的相关特性与功能,又要按照接口规范去处理视图点击事件。

  2. onCreate 方法内的操作

    • 初始化相关
      调用 super.onCreate(savedInstanceState),完成父类 AppCompatActivity 的初始化工作,传递 savedInstanceState 参数用于可能的状态恢复;接着通过 EdgeToEdge.enable(this) 启用可能与屏幕边缘显示适配相关的功能(具体取决于 EdgeToEdge 类的实现);再利用 setContentView(R.layout.activity_main) 设置当前 Activity 的界面布局,即加载对应的 XML 布局文件所描述的界面元素到该 Activity 上展示。
    • 按钮获取与点击事件设置
      通过 findViewById 方法分别获取 id 为 button5button6button7 的按钮,并为它们设置点击事件监听器,都设置为当前类实例(因为实现了 View.OnClickListener 接口),也就是当这些按钮被点击时会触发当前类中重写的 onClick 方法来处理点击逻辑。
  3. onClick 方法的逻辑
    在重写的 onClick 方法中,通过判断点击的视图(按钮)的 id 来区分具体是哪个按钮被点击:

    • 若点击的视图 id 为 R.id.button5,则通过 Toast.makeText 弹出一个显示内容为 “继承接口 1” 的短暂提示信息(Toast),用于向用户展示相关提示内容。
    • 若点击的视图 id 为 R.id.button6,则弹出显示 “继承接口 2” 的 Toast 提示信息。
    • 若点击的视图 id 不是前面两者(即 button7 或其他符合此处判断逻辑的按钮),则弹出显示 “继承接口 3” 的 Toast 提示信息。

运行效果图如下:

分别点击 button5,button6,button7,即可看到继承接口1,继承接口2,继承接口3

四、配置⽂件设置click⽅法

MainActivity代码:

    public void click(View View){

        Toast.makeText(MainActivity.this,"Click",Toast.LENGTH_SHORT).show();

        }

运行效果图如下:

点击button8可看见Click

总布局activity_main.xml代码:

<?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/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button1" />
    <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button2" />
    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button3" />
    <Button
        android:id="@+id/button4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button4" />
</LinearLayout>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
    <Button
        android:id="@+id/button5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button5" />
    <Button
        android:id="@+id/button6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button6" />
    <Button
        android:id="@+id/button7"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button7" />
    </LinearLayout>
    <Button
        android:id="@+id/button8"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button8"
        android:onClick="click"/>
</LinearLayout>

   

低功耗蓝牙项目,需要一块懂省电的板

思澈 SF32LB52 芯片,BLE 协议栈深度优化,上手即开发

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值