Creación de una aplicación de Android Anagram Checker en Android Studio con Kotlin

Un anagrama de una palabra es otra palabra que contiene los mismos caracteres, solo el orden de los caracteres puede ser diferente. Por ejemplo, «abcd» y «dabc» son un anagrama el uno del otro. En este artículo, crearemos una aplicación de Android Anagram Checker en Android Studio utilizando Kotlin y XML. La aplicación verificará si las palabras ingresadas son anagramas entre sí. Si las palabras ingresadas son un anagrama entre sí, se mostrará un Toast con el mensaje «Las palabras ingresadas son un anagrama». De lo contrario, el mensaje de Toast será «Las palabras ingresadas no son un anagrama». 

Implementación paso a paso

Paso 1: Crear un nuevo proyecto  

Para crear un nuevo proyecto en Android Studio, consulte Cómo crear/iniciar un nuevo proyecto en Android Studio . Tenga en cuenta que seleccione Kotlin como lenguaje de programación.

Paso 2: Trabajar con el archivo build.gradle(Module)

Debe aplicar el complemento kotlin-android-extensions en el módulo build.gradle de esta manera

plugins {

   id 'com.android.application'
   id 'kotlin-android'
   id 'kotlin-android-extensions'

}

Paso 3: 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. 

XML

<?xml version="1.0" encoding="utf-8"?>
<androidx.appcompat.widget.LinearLayoutCompat
    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"
    android:orientation="vertical"
    tools:context=".MainActivity">
  
    <TextView
        android:textColor="#2E7D32"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="40dp"
        android:text="Anagram Checker"
        android:textSize="35sp"
        android:textStyle="bold"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
  
    <androidx.appcompat.widget.LinearLayoutCompat
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="40dp"
        android:orientation="horizontal">
        
        <TextView
            android:paddingLeft="10dp"
            android:textColor="#2E7D32"
            android:layout_weight="1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:layout_marginTop="120dp"
            android:text="Word 1"
            android:textSize="30sp"
            android:textStyle="bold" />
  
        <EditText
            android:hint="Enter first word"
            android:layout_weight="2"
            android:id="@+id/et_text1"
            android:layout_width="190dp"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:layout_marginTop="50dp" />
  
  
    </androidx.appcompat.widget.LinearLayoutCompat>
  
    <androidx.appcompat.widget.LinearLayoutCompat
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        
        <TextView
            android:paddingLeft="10dp"
            android:textColor="#2E7D32"
            android:layout_weight="1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:layout_marginTop="120dp"
            android:text="Word 2"
            android:textSize="30sp"
            android:textStyle="bold" />
  
        <EditText
            android:layout_weight="2"
            android:id="@+id/et_text2"
            android:layout_width="190dp"
            android:hint="Enter second word"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:layout_marginTop="50dp" />
  
  
    </androidx.appcompat.widget.LinearLayoutCompat>
  
    <Button
        android:id="@+id/check_btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="30dp"
        android:backgroundTint="#E67212"
        android:text="Check"
        android:textColor="@color/white" />
  
</androidx.appcompat.widget.LinearLayoutCompat>

Después de escribir tanto código, nuestra interfaz de usuario se ve así:

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.util.Log
import android.widget.Toast
import kotlinx.android.synthetic.main.activity_main.*
import java.util.*
  
class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
  
        // when user clicks on check button
        check_btn.setOnClickListener {
  
            val word1: String = et_text1.text.toString()
            val word2: String = et_text2.text.toString()
  
            //check if words are anagrams of each other.
            val check: Boolean = areAnagram(word1, word2)
  
            if (check) {
                Toast.makeText(this, "Entered words are anagram", Toast.LENGTH_SHORT).show()
            } else {
                Toast.makeText(this, "Entered words are not anagram", Toast.LENGTH_SHORT).show()
            }
        }
    }
  
    // function to check 
      // whether two strings are
    // anagram of each other
    private fun areAnagram(str1: String, str2: String): Boolean {
        // Both String Length must be Equal
        if (str1.length != str2.length) {
            return false
        }
  
        // Convert Strings to character Array
        val strArray1 = str1.toCharArray()
        val strArray2 = str2.toCharArray()
  
        // Sort the Arrays
        Arrays.sort(strArray1)
        Arrays.sort(strArray2)
  
        // Convert Arrays to String
        val sortedStr1 = String(strArray1)
        val sortedStr2 = String(strArray2)
  
        // Check Both String Equals
          // or not After Sorting
        // and Return value True or False
        return sortedStr1 == sortedStr2
    }
}

Producción:

Publicación traducida automáticamente

Artículo escrito por nirajgusain5 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *