Для взаимодействия между различными объектами activity ключевым классом является android.content.Intent. Он представляет собой задачу, которую надо выполнить приложению.
Для работы с Intent добавим новый класс Activity. Для этого нажмем правой кнопкой мыши в папку, в которой находится класс MainActivity, и затем в контекстном меню выберем New->Activity->Empty Views Activity:
Новый класс Activity назовем SecondActivity, а все остальные настройки оставим по умолчанию:
И после этого в проект будет добавлена новая Activity - SecondActivity:
После этого в файле манифеста AndroidManifest.xml мы сможем найти следующие строки:
<activity android:name=".SecondActivity" android:exported="false" /> <activity android:name=".MainActivity" android:exported="true"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity>
Все используемые классы activity должны быть описаны в файле AndroidManifest.xml с помощью элемента <activity>
. Каждый подобный
элемент содержит как минимум один атрибут android:name
, который устанавливает имя класса activity.
Однако по сути activity - это стандартные классы java, которые наследуются от класса Activity или его наследников. Поэтому вместо встроенных шаблонов в Android Studio можем добавлять обычные классы, и затем их наследовать от класса Activity. Однако в этом случае нужно будет вручную добавлять в файл манифеста данные об activity.
Причем для MainActivity в элементе intent-filter определяется интент-фильтр. В нем элемент action значение "android.intent.action.MAIN" представляет главную точку входа в приложение. То есть MainActivity остается основной и запускается приложением по умолчанию.
Для SecondActivity просто указано, что она в проекте, и никаких intent-фильтров для нее не задано.
Чтобы из MainActivity запустить SecondActivity, надо вызвать метод startActivity()
:
Intent intent = new Intent(this, SecondActivity.class); startActivity(intent);
В качестве параметра в метод startActivity передается объект Intent. Для своего создания Intent в конструкторе принимает два параметра: контекст выполнения (в данном случае это текущий объект MainActivity) и класс, который используется объектом Intent и представляет передаваемые в задачу данные (фактически класс activity, которую мы будем запускать).
Теперь рассмотрим реализацию перехода от одной Activity к другой. Для этого в файле activity_main.xml (то есть в интерфейсе для MainActivity) определим кнопку:
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <Button android:id="@+id/navButton" android:textSize="20sp" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Перейти к SecondActivity" android:onClick="onClick" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toTopOf="parent"/> </androidx.constraintlayout.widget.ConstraintLayout>
И определим для кнопки в классе MainActivity обработчик нажатия, по которому будет производиться переход к новой Activity:
package com.example.viewapp; import androidx.appcompat.app.AppCompatActivity; import android.content.Intent; import android.os.Bundle; import android.view.View; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } public void onClick(View view) { Intent intent = new Intent(this, SecondActivity.class); startActivity(intent); } }
В обработчике нажатия будет запускаться SecondActivity.
Далее изменим код SecondActivity:
package com.example.viewapp; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.widget.TextView; public class SecondActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //setContentView(R.layout.activity_second); TextView textView = new TextView(this); textView.setTextSize(20); textView.setPadding(16, 16, 16, 16); textView.setText("SecondActivity"); setContentView(textView); } }
Запустим приложение и перейдем от одной Activity к другой: