简单来说,活动是用来和用户进行交互的。
一、完成一个简单活动
1、创建活动
在com.example.activitytest下新建一个Empty Activity。这里不勾选Generate Layout File和Launcher Activity选项。其作用分别是创建一个布局文件和将该活动设置为主活动,下面将手动完成这些工作。
2、创建布局
android程序设计讲究逻辑和视图分离,所以活动需要对应的布局。
①、新建文件
res->layout->Layout resource file
②、编辑文件
有2种编辑模式,code和design,前者以代码的方式编辑布局,后者以视图的方式编辑布局。接下来通过代码的方式放置一个Button。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="the button"
/>
</LinearLayout>
效果如下:
3、在活动中调用布局
package com.example.activitytest;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
public class FirstActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.first_layout); //此行代码用于调用布局
}
}
通过setContentView()方法可以调用布局,其传入的参数为布局的id。此外,项目中添加的资源都会在R文件中生成对应的id,所以传入该id即可。
4、注册活动
活动需要在AndroidManifest.xml中注册才能生效,其在app/src/main目录下。Android Studio已经帮我们完成了该活动的注册,不过,当程序启动时,会首先启动主活动,所以,下面将该活动设置为主活动。
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.activitytest">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".FirstActivity"
android:label="my_first_activity"> //指定活动标题栏的内容
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
在FirstActivity标签下,通过标签,将该活动设置为主活动。这样就完成了一个简单的活动,其显示一个Button。
二、Toast与Menu
1、Toast
Toast是一种提醒方式,并且提示的消息会在一段时间后消失,下面完成在点击Button时提示"You Click the Button"。修改onCreate()方法:
package com.example.activitytest;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
public class FirstActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.first_layout); //此行代码用于调用布局
Button bt=(Button)findViewById(R.id.button) ;
bt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Toast.makeText(FirstActivity.this,"You Click the Button",Toast.LENGTH_SHORT).show();
}
});
}
}
通过findViewById()用来获得该按钮的实例,然后为其注册监听器。当点击按钮时,就调用makeText(),创建一个Toast对象,然后,调用show()来显示。其中makeText()有3个参数,分别是上下文、显示的内容、显示时长。
2、Menu
Menu是用来节省手机屏幕空间,其使用如下:
①、新建文件:res->menu->Menu resource file
②、编辑文件
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/add"
android:title="Add"/>
<item
android:id="@+id/remove"
android:title="Remove"/>
</menu>
通过2个item标签设置了2个菜单项
③、显示菜单
在FirstActivity中重写onCreateOptionsMenu()

@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main,menu);
return true;
}
getMenuInflater()用来获得MenuInflater对象
inflate()用来给当前活动创建菜单,其2个参数分别用来指定菜单文件和将菜单项添加到那个Menu对象中
return true表示允许显示,否则不显示
④、菜单响应
在FirstActivity中重写onOptionsItemSelect(0
@Override
public boolean onOptionsItemSelected(@NonNull MenuItem item) {
switch(item.getItemId()){
case R.id.add:
Toast.makeText(this,"You Click the Add",Toast.LENGTH_SHORT).show();
break;
case R.id.remove:
Toast.makeText(this,"You Click the Remove",Toast.LENGTH_SHORT).show();
break;
}
return true;
}
三、退出活动
退出活动可以通过返回键也可以通过代码来实现,下面通过代码:
①、添加一个新的Button
<Button
android:id="@+id/quit"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="quit" />
②、为其注册监听器
Button quit=(Button)findViewById(R.id.quit);
quit.setOnClickListener(
view->{finish();
});
这里使用了Lambda表达式,其中finish()用于结束当前活动。这样,当点击该Button时,就会退出活动
四、代码
FirstActivity.java
package com.example.activitytest;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
public class FirstActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.first_layout); //此行代码用于调用布局
Button bt=(Button)findViewById(R.id.button) ;
bt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Toast.makeText(FirstActivity.this,"You Click the Button",Toast.LENGTH_SHORT).show();
}
});
Button quit=(Button)findViewById(R.id.quit);
quit.setOnClickListener(
view->{finish();
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main,menu);
return true;
}
@Override
public boolean onOptionsItemSelected(@NonNull MenuItem item) {
switch(item.getItemId()){
case R.id.add:
Toast.makeText(this,"You Click the Add",Toast.LENGTH_SHORT).show();
break;
case R.id.remove:
Toast.makeText(this,"You Click the Remove",Toast.LENGTH_SHORT).show();
break;
}
return true;
}
}
first_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="the button"
/>
<Button
android:id="@+id/quit"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="quit" />
</LinearLayout>
main.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/add"
android:title="Add"/>
<item
android:id="@+id/remove"
android:title="Remove"/>
</menu>
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.activitytest">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".FirstActivity"
android:label="my_first_activity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>