Crear y llenar una tabla en Android Studio y Mysql [12]
En este video vamos a crear y llenar una tabla en Android Studio y Mysql siguiendo estos pasos.
- Creamos un archivo de tipo “AndroidResourceFile” donde insertamos un TableRow con dos TextView y dos Botones.
- Nombre, Email y los botones Editar y Borrar.
- En nuestro MainActivity llenamos el TableLayout.
- A nuestros botones Editar y Borrar les personalizamos el id.
Codigo: https://github.com/programadornovato/AndroidMysql/commit/3736cd8b97e54808538a62e5e0f8e13a36e24c48
//app/src/main/java/com/programadornovato/androidmysql/MainActivity.kt
package com.programadornovato.androidmysql
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.widget.EditText
import android.widget.TableLayout
import android.widget.TextView
import android.widget.Toast
import com.android.volley.Request
import com.android.volley.Response
import com.android.volley.toolbox.StringRequest
import com.android.volley.toolbox.Volley
class MainActivity : AppCompatActivity() {
var txtNombre:EditText?=null
var txtEmail:EditText?=null
var txtTelefono:EditText?=null
var txtPass:EditText?=null
var tbUsuarios:TableLayout?=null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
txtNombre=findViewById(R.id.txtNombre)
txtEmail=findViewById(R.id.txtEmail)
txtTelefono=findViewById(R.id.txtTelefono)
txtPass=findViewById(R.id.txtPass)
tbUsuarios=findViewById(R.id.tbUsuarios)
tbUsuarios?.removeAllViews()
for (i in 0 until 5){
val registro=LayoutInflater.from(this).inflate(R.layout.table_row_np,null,false)
val colNombre=registro.findViewById<View>(R.id.colNombre) as TextView
val colEmail=registro.findViewById<View>(R.id.colEmail) as TextView
val colEditar=registro.findViewById<View>(R.id.colEditar)
val colBorrar=registro.findViewById<View>(R.id.colBorrar)
colNombre.text="Nombre $i"
colEmail.text="Email $i"
colEditar.id=i
colBorrar.id=i
tbUsuarios?.addView(registro)
}
}
fun clickTablaEditar(view: View){
Toast.makeText(this,view.id.toString(),Toast.LENGTH_LONG).show()
}
fun clickTablaBorrar(view: View){
Toast.makeText(this,view.id.toString(),Toast.LENGTH_LONG).show()
}
fun clickBtnInsertar(view:View){
val url="http://192.168.8.100/android_mysql/insertar.php"
val queue=Volley.newRequestQueue(this)
var resultadoPost = object : StringRequest(Request.Method.POST,url,
Response.Listener<String> { response ->
Toast.makeText(this,"Usuario insertado exitosamente",Toast.LENGTH_LONG).show()
},Response.ErrorListener { error ->
Toast.makeText(this,"Error $error ",Toast.LENGTH_LONG).show()
}){
override fun getParams(): MutableMap<String, String> {
val parametros=HashMap<String,String>()
parametros.put("nombre",txtNombre?.text.toString())
parametros.put("email",txtEmail?.text.toString())
parametros.put("telefono",txtTelefono?.text.toString())
parametros.put("pass",txtPass?.text.toString())
return parametros
}
}
queue.add(resultadoPost)
}
fun cickVer(view: View){
var txtId=findViewById<EditText>(R.id.txtId)
var intent= Intent(this,MainActivity2::class.java)
intent.putExtra("id",txtId.text.toString())
startActivity(intent)
}
}
///app/src/main/res/layout/activity_main.xml
<?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"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<EditText
android:id="@+id/txtNombre"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="12dp"
android:ems="10"
android:hint="Nombre"
android:inputType="textPersonName"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/tbUsuarios" />
<EditText
android:id="@+id/txtId"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="20dp"
android:layout_marginLeft="20dp"
android:layout_marginTop="52dp"
android:ems="10"
android:hint="ID"
android:inputType="number"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btnInsertar" />
<Button
android:id="@+id/btnVer"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="48dp"
android:layout_marginLeft="48dp"
android:layout_marginTop="52dp"
android:onClick="cickVer"
android:text="Ver"
app:layout_constraintStart_toEndOf="@+id/txtId"
app:layout_constraintTop_toBottomOf="@+id/btnInsertar" />
<EditText
android:id="@+id/txtTelefono"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="24dp"
android:ems="10"
android:hint="Telefono"
android:inputType="phone"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.484"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txtEmail" />
<EditText
android:id="@+id/txtPass"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:ems="10"
android:hint="Password"
android:inputType="textPassword"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.484"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txtTelefono" />
<Button
android:id="@+id/btnInsertar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="68dp"
android:layout_marginEnd="20dp"
android:layout_marginRight="20dp"
android:onClick="clickBtnInsertar"
android:text="Guardar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txtPass" />
<EditText
android:id="@+id/txtEmail"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:ems="10"
android:hint="Email"
android:inputType="textEmailAddress"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.484"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txtNombre" />
<TableLayout
android:id="@+id/tbUsuarios"
android:layout_width="361dp"
android:layout_height="200dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent" />
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent" />
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent" />
<TableRow
android:layout_width="match_parent"
android:layout_height="match_parent" />
</TableLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
///app/src/main/res/layout/table_row_np.xml
<?xml version="1.0" encoding="utf-8"?>
<TableRow
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="wrap_content">
<TextView
android:id="@+id/colNombre"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="TextView" />
<TextView
android:id="@+id/colEmail"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="TextView" />
<ImageButton
android:id="@+id/colEditar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="clickTablaEditar"
app:srcCompat="@android:drawable/ic_menu_edit" />
<ImageButton
android:id="@+id/colBorrar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="clickTablaBorrar"
app:srcCompat="@android:drawable/ic_input_delete" />
</TableRow>
🎦 Lista de reproducción de este curso: https://www.youtube.com/watch?v=915R9eq_r-s&list=PLCTD_CpMeEKSiUQ_svD3ovD1qXdKQFMvO&ab_channel=programadornovato
🎦 [Curso] Android Studio con Bases de datos: https://www.youtube.com/watch?v=CeQZ0c1l_pY&list=PLCTD_CpMeEKQJiP5LPFF4x-1gIf-19LVe&ab_channel=programadornovato
🎦 Curso de Android Studio: https://www.youtube.com/watch?v=AHyTqIB_8Rs&list=PLCTD_CpMeEKTT9pb9J-89j1SPtqHzU7sF&ab_channel=programadornovato
🎦 [Curso] Android Studio con Interfaz Grafica de 0 a 100: https://www.youtube.com/watch?v=3ZUlE_tvfaM&list=PLCTD_CpMeEKRL2-HaZThebGcyyR3_RshO&ab_channel=programadornovato
🎦 [CURSO] MARIADB DE 0 A 100: https://www.youtube.com/watch?v=oV0zZvTz4Ak&list=PLCTD_CpMeEKRoPFmVqG-COyGptWcbeesj&ab_channel=programadornovato
🎦 [CURSO] MYSQL DE 0 A 100🐬: https://www.youtube.com/watch?v=UzN-lDFvu3k&list=PLCTD_CpMeEKQmH9cRKWWHahygZFtIdwYG&ab_channel=programadornovato
🎦 [Curso] Kotlin de 0 a 100: https://www.youtube.com/playlist?list=PLCTD_CpMeEKSjzbsW_zmVNz23GyOVsdbS
🎦 [Curso] Java Netbeans Completo☕: https://www.youtube.com/playlist?list=PLCTD_CpMeEKTT-qEHGqZH3fkBgXH4GOTF
🔗 Facebook: https://facebook.com/ProgramadorNovatoOficial
🔗 Twitter: https://twitter.com/programadornova
🔗 Linkedin: https://www.linkedin.com/in/programadornovato/
🔗 Instagram: https://www.instagram.com/programadornovato/
🔗 Pagina oficial: https://www.programadornovato.com
🔗 Gracias por apoyar este canal: https://www.patreon.com/programadornovato
Anterior tutorial Siguiente tutorial