- Урок 5. Kotlin. Добавление второго экрана в android-приложение. Передача данных через Intent
- Вы узнаете
- Создаем новое активити
- Изучите файл манифеста
- Создаем макет для нового активити
- Добавьте TextView для заголовка
- Добавьте TextView для отображения случайного числа
- Изменение цвета фона макета
- Запуск второго активити
- Передача информации между активити
- Обновите SecondActivity для вычисления и отображения случайного числа
- Обновите метод onCreate()
- How to pass the values from activity to another activity
Урок 5. Kotlin. Добавление второго экрана в android-приложение. Передача данных через Intent
Продолжаем курс по обучению основам разработки мобильных приложений в Android Studio на языке Kotlin.
В этом уроке создадим второй экран в приложении, и настроим взаимодействие между экранами с передачей данных.
Предыдущий урок, в котором мы обрабатывали нажатия кнопок, здесь
Продолжаем разработку приложения на языке Kotlin, которое мы делали на прошлом уроке. Исходный код можно скачать на странице прошлого урока.
Пока что наше приложение имеет только один экран. В этом уроке мы добавим второе активити, которое будет отображать экран с данными, полученными на основе данных с первого экрана. При нажатии кнопки Random будет отображаться окно со случайным числом от нуля до текущего значения счетчика.
- Вы узнаете
- Создаем новое активити
- Изучите файл манифеста
- Создаем макет для нового активити
- ДобавьтеTextView для заголовка
- ДобавьтеTextView для отображения случайного числа
- Изменение цвета фона макета
- Запуск второго активити
- Передача информации между активити
- ОбновитеSecondActivity для вычисления и отображения случайного числа
- Обновите методonCreate()
Вы узнаете
- Как запустить новое активити с помощью интента
- Как передать данные во второе активити через интент
- Как получить данные, переданные через интент во втором активити
Создаем новое активити
- Раскройте пакет с именем com.example.android.myfirstapp по пути apps >java >com.example.android.myfirstapp.
- Правым кликом выберите команду File >New >Activity >Empty Activity.
- В окне настроек нового активити установите для него имя SecondActivity. Убедитесь, что в поле Source Language установлен Kotlin.
Также проверьте им пакета, оно должно соответствовать вашему приложению. Если вы не выделили имя пакета в меню при вызове команды добавления нового активити, установите в это поле android.example.com.myfirstapp.
4. Нажмите Finish. Android Studio создаст файл на языке Kotlin и файл макета на языке XML для нового активити.
5. Дождитесь синхронизации gradle в Android Studio.Gradle это система сборки, которая используется в Android Studio для компиляции и постройки приложения. Вы будете видеть сообщения от gradle о прогрессе сборки приложения внизу экрана.
Изучите файл манифеста
- Откройте файл манифеста приложения по пути app >manifests >AndroidManifest.xml.Файл манифеста содержит информацию о приложении, включая список всех активити.
- Обратите внимание на текст между тегами для MainActivity:Как видите, тег содержит параметр имени активити. MainActivity запускается после при старте приложения, поэтому включает дополнительные параметры, которые определяют его как стартовое активити.
- Изучите тег для второго активити. Он содержит только параметр имени.
Каждое активити должно быть определено в файле манифеста. Вы можете добавить новое активити в приложение не через меню добавления активити, но тогда вам нужно будет вручную прописать его в манифесте.
Изучите файл Kotlin нового активити
- Откройте файл SecondActivity.kt.
- Обратите внимание на метод onCreate(). Постмотрите на вызов setContentView(). Этот метод указывает файл макета activity_second.xml как разметку нового активити.
setContentView(R.layout.activity_second);
В этом активити мы добавим метод отображения случайного числа. Но сначала нам нужно определить поле в макете для его отображения.
Создаем макет для нового активити
Экран нового активити будет отображать заголовок и случайный номер. На вкладке дизайн редактора макетов можно увидеть, как будет выглядеть экран:
Добавьте TextView для заголовка
- Откройте файл activity_second.xml. Вы увидите пустой ConstraintLayout. Это макет по умолчанию для шаблона Empty Activity.
- Добавьте TextView из палитры компонентов. Этот TextView будет использовано для отображения заголовка вверху экрана.
- Ограничение верхнего края TextView установим по верхней границе окна, левый край по левой стороне, а правый край по правой стороне экрана. Нижний край не ограничиваем.
- Установите значение ширину match_parent, а высоту wrap_content, поэтому высота изменится в соответствии с высотой содержимого.
- Установите идентификатор @+id/textview_label.
- Установите верхний, левый и правый отступ 24dp. Левый и правый отступы могут также иметь значение “start” и “end” для поддержки локализации языков с написанием справа налево.
- Установите значение параметра цвета текста @color/colorPrimaryDark и размер текста 24sp.
- Поместите текст в TextView “Это случайное число между 0 и %1d.” Спецификатор %1dбудет заменен числом в процессе работы приложения.
- Поместите текст в ресурсы с именем random_heading.
Это код XML для TextView, которое отображает заголовок:
Добавьте TextView для отображения случайного числа
- Добавьте TextView для отображения случайного числа.
- Установите значения параметров высоты и ширины wrap_content.
- Этот TextView будет находиться ниже TextView заголовка. Ограничьте верхний край по нижнему краю TextView заголовка. Остальные ограничения установите по остальным сторонам экрана.
- Установите идентификатор @+id/textview_random.
- Установите значение верхнего, леаого и правого отступов 24dp.
- Установите значение параметров textColor в @android:color/white, textSize в 72sp, и textStyle в bold.
- Напишите букву R в текстовом поле. Этот текст является просто заменителем, пока не будет сгенерировано случайное число.
- Установите значение параметра layout_constraintVertical_bias в 0.45.Этот TextView имеет ограничения по всем краям, так что лучше использовать вертикальные смещения, чем отступы для регулировки вертикального положения, чтобы макет одинаково хорошо выглядел в разных ориентациях и размерах экрана.
Это код XML для TextView которое отображает случайный номер:
Изменение цвета фона макета
Установите новому активити новый цвет фона, отличающийся от первого:
2. В макете для второго активити, установите элементу ConstraintLayout новый цвет. Это можно сделать в панели свойств или в коде XML:
android:background="@color/screenBackground2"
Макет для второго активити готов. Вы можете посмотреть его на вкладке Дизайн.
Теперь пришло время реализовать переход на второй экран.
Запуск второго активити
Интент – это объект для обмена между активити, который абстрактно представляет собой намерение выполнить какое-либо действие. В основном интенты используются для запуска активити. Как только интент отправляется, его получает система Android, и считывает информацию в нем. Для открытия второго экрана, нам нужно создать и отправить объект Intent с указанием активити, которое нужно открыть. Затем вызвать метод startActivity() с передачей объекта Intent, который отправит это сообщение фреймворку Android, который откроет это активити.
- Откройте класс MainActivity.kt.
- Добавьте метод randomMe(), который будет вызываться, когда нажата кнопка Random.Если вы забыли, как реализовать такой метод, посмотрите на код методов toastMe() и countMe().
- Добавьте код для запуска второго активити в тело метода randomMe():
// Create an Intent to start the second activity val randomIntent = Intent(this, SecondActivity::class.java) // Start the new activity. startActivity(randomIntent)
4. Что еще нужно сделать, чтобы связать метод randomMe() с кнопкой Random? Сделайте это самостоятельно. Ищите подсказки в прошлом уроке.
5. Запустите приложение. Нажмите кнопку Random. Второе активити откроется, но оно пока не показывает случайный номер.
Передача информации между активити
На втором экране при открытии должно отображаться случайное число из диапазона от нуля до текущего значения счетчика на первом экране. Для этого второму активити требуется текущее значение счетчика. Мы можем передать эту информацию в интенте, используя метод putExtra(). Второе активити может получить интент, который запустил его, и извлечь данные Extra Data из этого интента.
Обновите MainActivity для передачи дополнительных данных второму активити
- В классе SecondActivity.kt, объявите статическую переменную TOTAL_COUNT, для использования ее в качестве ключа для Extra Data.
2. Изменим метод randomMe(). Сначала получим текущее значение счетчика из TextView. Конвертируем значение в тип int, затем с помощью метода putExtra() добавим значение в Intent. Метод putExtra() принимает ключ и значение; в качестве ключа укажем константу TOTAL_COUNT из SecondActivity.kt.
randomIntent.putExtra(SecondActivity.TOTAL_COUNT, count)
Вот полный код метода randomMe():
Обновите SecondActivity для вычисления и отображения случайного числа
Мы написали код для отправки текущего значения счетчика во второе активити. На следующем шаге настроим SecondActivity.kt для получения и использования значения счетчика.
Напишем метод для извлечения значения счетчика и вычисления на его основе случайного числа
- В классе SecondActivity.kt, добавим метод showRandomNumber() без аргументов.
- Пропишем в этом методе генерацию и отображение случайного числа, максимальное значение которого соответствует значению счетчика.
- Используем метод getIntent() для получения интента, запустившего это активити. Используем метод getIntExtra() для получения extra data из интента; аргументами являются ключ или значение по умолчанию при его отсутствии.
Внимание: при получении данных из интента, вы должны знать их тип. Используйте соответствующий getter метод, например getStringExtra() или getIntExtra().
Полный код метода showRandomNumber():
//Other class code. fun showRandomNumber() < // Get the count from the intent extras val count = intent.getIntExtra(TOTAL_COUNT, 0) // Generate the random number val random = Random() var randomInt = 0 // Add one because the bound is exclusive if (count >0) < // Add one because the bound is exclusive randomInt = random.nextInt(count + 1) >// Display the random number. textview_random.text = Integer.toString(randomInt) // Substitute the max value into the string resource // for the heading, and update the heading textview_label.text = getString(R.string.random_heading, count) >
Обновите метод onCreate()
Метод onCreate() вызывается при старте активити. Текущий метод onCreate() для SecondActivity устанавливает макет разметки для экрана. Добавим вызов метода showRandomNumber() в метод onCreate(), он будет обновлять текстовое поле для отображения случайного числа.
override fun onCreate(savedInstanceState: Bundle?)
2. Запустим приложение. Нажмем кнопку счетчика на некоторое время, затем нажмем кнопку Random button. В новом окне должно отобразиться случайное число.
На этом наш урок подошел к концу. Исходный код урока вы можете скачать по ссылке. Вопросы можно задавать в комментариях.
Следующий урок, в котором мы изучим жизненный цикл активити:
How to pass the values from activity to another activity
As I’m learning Kotlin for Android development, I’m now trying the basic programs like hello world and how to navigate from one activity to another activity, there is no issue with this. When I move from one activity to another, it works fine, but I do not know how to pass the values between the activities. I tried to set the values in one activity and retrieved them in another activity it does not work. Please see the code snippet below This is my main activity where I take the username and password from edit text and setting to the intent:
class MainActivity : AppCompatActivity() < val userName = null val password = null override fun onCreate(savedInstanceState: Bundle?) < super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) button.setOnClickListener < val intent = Intent(this@MainActivity,SecondActivity::class.java); var userName = username.textø var password = password_field.text intent.putExtra("Username", userName) intent.putExtra("Password", password) startActivity(intent); >> >
class SecondActivity : AppCompatActivity() < override fun onCreate(savedInstanceState: Bundle?) < super.onCreate(savedInstanceState) setContentView(R.layout.activity_second) var strUser: String = intent.getStringExtra("Username") var strPassword: String = intent.getStringExtra("Password") user_name.setText("Seelan") passwor_print.setText("Seelan") >>
Please guide me on how to do this, whether I have some other way to do this in Kotlin if not by intent.
Kotlin should make it simpler. We should be able to pass data like Parameters in Activity. I am pretty sure it is not hard to achieve.