Cada vez que desarrollamos una aplicación de Android y la ejecutamos, a menudo observamos que la aplicación viene con una ActionBar con el nombre de la aplicación. Esto sucede de forma predeterminada a menos que se cambie explícitamente. Este texto se denomina título en la solicitud. Se puede cambiar el título de la aplicación haciendo cambios en la string app_name presente en los valores.
Pero, si una aplicación tiene más de una actividad, todas estas actividades tendrán el mismo título. Supongamos que tenemos MainActivity, SecondActivity y ThirdActivity. Durante la navegación se puede observar que todas tendrán el mismo título, es decir, nombre de la aplicación. Entonces, a través de este artículo, le mostraremos cómo puede cambiar dinámicamente el título de la aplicación en tiempo de ejecución. Puede aplicar el mismo concepto si hay más de una actividad para distinguir entre ellos.
Implementación paso a paso
Paso 1: crea un nuevo proyecto en Android Studio
Para crear un nuevo proyecto en Android Studio, consulte Cómo crear/iniciar un nuevo proyecto en Android Studio . Demostramos la aplicación en Kotlin , así que asegúrese de seleccionar Kotlin como idioma principal al crear un nuevo proyecto.
Paso 2: trabajar con el archivo activity_main.xml
Vaya a la aplicación > res > diseño > actividad_principal.xml y agregue el siguiente código a ese archivo. A continuación se muestra el código para el archivo activity_main.xml . Agregue EditText y un botón en el archivo de diseño. Escribiremos el título deseado en EditText y haremos clic en el botón que realizará la operación de cambio de título.
XML
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <!-- Type something in this EditText to change the ActionBar text --> <EditText android:id="@+id/editText" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_centerInParent="true"/> <!-- Click this button to make changes --> <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Change Text" android:layout_centerHorizontal="true" android:layout_below="@id/editText"/> </RelativeLayout>
Paso 4: trabajar con el archivo MainActivity.kt
Vaya al archivo MainActivity.kt y consulte el siguiente código. A continuación se muestra el código del archivo MainActivity.kt . Se agregan comentarios dentro del código para comprender el código con más detalle.
Kotlin
import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.widget.Button import android.widget.EditText import android.widget.Toast class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) // Declaring and initializing EditText // and Button from the layout file val mEditText = findViewById<EditText>(R.id.editText) val mButtonText = findViewById<Button>(R.id.button1) // When the button is clicked mButtonText.setOnClickListener { // If the EditText field is not empty, // the ActionBar title will change // Else, the application will display a Toast message if(mEditText.text.isNotEmpty()){ title = mEditText.text.toString() } else { Toast.makeText(applicationContext, "No input", Toast.LENGTH_SHORT).show() } } } }
Producción:
Puede ver que podemos cambiar el título en tiempo de ejecución.
Publicación traducida automáticamente
Artículo escrito por aashaypawar y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA