Перед погружением в код я хочу упомянуть, что Android Studio сообщает Не найден следующий класс: android .support.v7.widget.CardView , даже если он у меня загружен. (Изображения ниже)
( Ошибка, при которой CardView не найден, хотя опция загрузки не найдена.)
Вот код действия с ошибкой.
ContactsActivity.kt
(contactView - это RecyclerView)
package com.smartherd.msgshareapp
import android.os.Bundle
import android.util.Log
import androidx.appcompat.app.AppCompatActivity
import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView
import com.smartherd.msgshareapp.models.Contact
import com.smartherd.msgshareapp.models.adapters.ContactAdapter
import kotlinx.android.synthetic.main.activity_contacts.*
class ContactsActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val layoutManager = LinearLayoutManager(this)
layoutManager.orientation = LinearLayoutManager.VERTICAL
contactsView.layoutManager = layoutManager // Oops! contactsView is NULL!
contactsView.adapter = ContactAdapter(this, Contact.allContacts)
}
}
Вот activity_contact. xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:baselineAligned="false"
android:orientation="vertical"
android:padding="10dp">
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/contactsView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical" />
</LinearLayout>
Класс контакта
package com.smartherd.msgshareapp.models
import org.json.JSONArray
import org.json.JSONObject
import java.io.File
data class Contact(val name: String, val phone: String, val email: String) {
companion object {
val allContacts: List<Contact>
get() {
val json = JSONObject(File("contacts.json").readText()).getJSONArray("contacts")
// Looks like {"contacts": [{"name": ..., "email": ..., "phone": ...}, ...]}
val contacts = mutableListOf<Contact>()
var i = 0
while (i < json.length()) {
val name = json.getJSONObject(i).getString("name")
val phone = json.getJSONObject(i).getString("phone")
val email = json.getJSONObject(i).getString("email")
contacts.add(Contact(name, phone, email))
++i
}
return contacts
}
}
}
И класс адаптера контакта (ContactAdapter.kt)
package com.smartherd.msgshareapp.models.adapters
import android.content.Context
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView
import com.smartherd.msgshareapp.R
import com.smartherd.msgshareapp.models.Contact
import kotlinx.android.synthetic.main.card_contact.view.*
class ContactAdapter(val context: Context, val contacts: List<Contact>) :
RecyclerView.Adapter<ContactAdapter.ContactHolder>() {
inner class ContactHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
fun initialize(contact: Contact) {
itemView.contactName.text = "${contact.name}\n${contact.email}"
// itemView.contactImage is not set yet.
}
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ContactHolder =
ContactHolder(
LayoutInflater.from(context).inflate(R.layout.card_contact, parent, false)
)
override fun getItemCount(): Int = contacts.size
override fun onBindViewHolder(holder: ContactHolder, position: Int) = holder.initialize(contacts[position])
}