一、匿名类
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 开发)做了以下几件事:
- 定义
MainActivity类继承自AppCompatActivity,声明了 8 个按钮变量。 - 在
onCreate方法中,先调用父类onCreate完成初始化,接着启用可能与屏幕边缘显示相关的功能,然后设置界面布局。 - 从布局里找到
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 开发)做了以下几件事:
- 定义
MainActivity类继承AppCompatActivity,声明了 8 个按钮变量。 - 在
onCreate方法中,先执行父类onCreate初始化,启用屏幕边缘相关功能,设置界面布局,然后获取id为button2、button3、button4的按钮。 - 为这三个按钮设置点击事件监听器,使用自定义的内部类
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 开发)做了以下几件事:
-
类的定义与继承、接口实现:
定义了MainActivity类,该类继承自AppCompatActivity,同时实现了View.OnClickListener接口,意味着这个类既要具备AppCompatActivity的相关特性与功能,又要按照接口规范去处理视图点击事件。 -
onCreate方法内的操作:- 初始化相关:
调用super.onCreate(savedInstanceState),完成父类AppCompatActivity的初始化工作,传递savedInstanceState参数用于可能的状态恢复;接着通过EdgeToEdge.enable(this)启用可能与屏幕边缘显示适配相关的功能(具体取决于EdgeToEdge类的实现);再利用setContentView(R.layout.activity_main)设置当前 Activity 的界面布局,即加载对应的 XML 布局文件所描述的界面元素到该 Activity 上展示。 - 按钮获取与点击事件设置:
通过findViewById方法分别获取id为button5、button6、button7的按钮,并为它们设置点击事件监听器,都设置为当前类实例(因为实现了View.OnClickListener接口),也就是当这些按钮被点击时会触发当前类中重写的onClick方法来处理点击逻辑。
- 初始化相关:
-
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>



3246

被折叠的 条评论
为什么被折叠?



