Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Android

จะอัปเดต listview หลังจากใส่ค่าใน Android sqlite โดยใช้ Kotlin ได้อย่างไร


ตัวอย่างนี้สาธิตวิธีอัปเดต listview หลังจากใส่ค่าใน Android sqlite โดยใช้ Kotlin

ขั้นตอนที่ 1 − สร้างโครงการใหม่ใน Android Studio ไปที่ File? โครงการใหม่และกรอกรายละเอียดที่จำเป็นทั้งหมดเพื่อสร้างโครงการใหม่

ขั้นตอนที่ 2 − เพิ่มรหัสต่อไปนี้ใน res/layout/activity_main.xml

ตัวอย่าง

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
   xmlns:tools="https://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="vertical"
   tools:context=".MainActivity">
<EditText
   android:id="@+id/name"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:hint="Enter Name" />
<EditText
   android:id="@+id/salary"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:hint="Enter Salary"
   android:inputType="numberDecimal" />
<LinearLayout
   android:layout_width="wrap_content"
   android:layout_height="wrap_content">
<Button
   android:id="@+id/save"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="Save" />
<Button
   android:id="@+id/refresh"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="Refresh" />
</LinearLayout>
<ListView
   android:id="@+id/listView"
   android:layout_width="match_parent"
   android:layout_height="wrap_content">
</ListView>
</LinearLayout>

ขั้นตอนที่ 3 − เพิ่มรหัสต่อไปนี้ใน src/MainActivity.kt

import android.os.Bundle
import android.widget.*
import androidx.appcompat.app.AppCompatActivity
class MainActivity : AppCompatActivity() {
   private lateinit var save: Button
   private lateinit var refresh: Button
   private lateinit var name: EditText
   private lateinit var salary: EditText
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.activity_main)
      title = "KotlinApp"
      val helper = DatabaseHelper(this)
      val arrayList: ArrayList<String> = helper.getAllContacts() as ArrayList<String>
      name = findViewById(R.id.name)
      salary = findViewById(R.id.salary)
      save = findViewById(R.id.save)
      refresh = findViewById(R.id.refresh)
      val listView: ListView = findViewById(R.id.listView)
      val arrayAdapter: ArrayAdapter<*> = ArrayAdapter<Any?>(this@MainActivity,
      android.R.layout.simple_list_item_1, arrayList as List<Any?>)
      listView.adapter = arrayAdapter
         save.setOnClickListener {
            arrayList.clear()
            arrayList.addAll(helper.getAllContacts())
            arrayAdapter.notifyDataSetChanged()
            listView.invalidateViews()
            listView.refreshDrawableState()
         }
         refresh.setOnClickListener {
            if (name.text.toString().isNotEmpty() && salary.text.toString().isNotEmpty()) {
            if (helper.addData(name.text.toString(), salary.text.toString())) {
               Toast.makeText(this, "Inserted", Toast.LENGTH_LONG).show()
            } else {
               Toast.makeText(this, "NOT Inserted", Toast.LENGTH_LONG).show()
            }
         } else {
            name.error = "Enter NAME"
            salary.error = "Enter Salary"
         }
      }
   }
}

ขั้นตอนที่ 4 − สร้างคลาสใหม่ DataBaseHelper.kt และเพิ่มรหัสต่อไปนี้

import android.content.ContentValues
import android.content.Context
import android.database.Cursor
import android.database.sqlite.SQLiteDatabase
import android.database.sqlite.SQLiteException
import android.database.sqlite.SQLiteOpenHelper
import java.io.IOException
class DatabaseHelper(context: Context) :
SQLiteOpenHelper(context, dataBaseName, null, dataBaseVersion) {
   private val contactsTableName = "SalaryDetails"
   companion object {
      const val dataBaseName = "salaryDatabase3"
      const val dataBaseVersion = 1
   }
   override fun onCreate(db: SQLiteDatabase?) {
      try {
         db?.execSQL("create table $contactsTableName(id INTEGER PRIMARY KEY, name text,salary text          )")
      } catch (e: SQLiteException) {
         try {
            throw IOException(e)
         } catch (e1: IOException) {
            e1.printStackTrace()
         }
      }
   }
   override fun onUpgrade(db: SQLiteDatabase?, p1: Int, p2: Int) {
      db?.execSQL("DROP TABLE IF EXISTS $contactsTableName")
      onCreate(db)
   }
   fun addData(s: String?, s1: String?): Boolean {
      val db = this.writableDatabase
      val contentValues = ContentValues()
      contentValues.put("name", s)
      contentValues.put("salary", s1)
      db.insert(contactsTableName, null, contentValues)
      return true
   }
   fun getAllContacts(): Collection<String> {
      val db: SQLiteDatabase = this.readableDatabase
      val arrayList = ArrayList<String>()
      val res: Cursor = db.rawQuery("select * from $contactsTableName", null)
      res.moveToFirst()
      while (!res.isAfterLast) {
         arrayList.add(res.getString(res.getColumnIndex("name")));
         res.moveToNext();
      }
      return arrayList
   }
}

ขั้นตอนที่ 5 − เพิ่มรหัสต่อไปนี้ใน androidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="https://schemas.android.com/apk/res/android" package="com.example.q11">
   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      android:roundIcon="@mipmap/ic_launcher_round"
      android:supportsRtl="true"
      android:theme="@style/AppTheme">
      <activity android:name=".MainActivity">
         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>
      </activity>
   </application>
</manifest>

มาลองเรียกใช้แอปพลิเคชันของคุณกัน ฉันคิดว่าคุณได้เชื่อมต่ออุปกรณ์มือถือ Android จริงกับคอมพิวเตอร์ของคุณ ในการรันแอพจาก android studio ให้เปิดไฟล์กิจกรรมของโปรเจ็กต์ของคุณแล้วคลิกไอคอน Run จะอัปเดต listview หลังจากใส่ค่าใน Android sqlite โดยใช้ Kotlin ได้อย่างไร จากแถบเครื่องมือ เลือกอุปกรณ์มือถือของคุณเป็นตัวเลือก จากนั้นตรวจสอบอุปกรณ์มือถือของคุณซึ่งจะแสดงหน้าจอเริ่มต้นของคุณ

จะอัปเดต listview หลังจากใส่ค่าใน Android sqlite โดยใช้ Kotlin ได้อย่างไร