Расширения Kotlin Android для доступа к текстовым представлениям - PullRequest
1 голос
/ 06 ноября 2019

Так что я учу себя разработке Android и просто пытаюсь обновить текстовое представление с результатами вызова Volley get. Я посмотрел на другие потоки stackoverflow и учебники kotlin, но, похоже, ничего не работает.

У меня есть 3 основных файла, с которыми я имею дело

activity_main.xml с этими представлениями

<TextView
    android:id="@+id/message"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="@dimen/activity_horizontal_margin"
    android:layout_marginStart="@dimen/activity_horizontal_margin"
    android:layout_marginTop="@dimen/activity_vertical_margin"
    android:text="Title"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintTop_toTopOf="parent" />

<android.support.design.widget.BottomNavigationView
    android:id="@+id/navigation"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginEnd="0dp"
    android:layout_marginStart="0dp"
    android:background="?android:attr/windowBackground"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toRightOf="parent"
    app:menu="@menu/navigation" />

<TextView
    android:id="@+id/story"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginStart="16dp"
    android:layout_marginLeft="16dp"
    android:layout_marginTop="32dp"
    android:text="Story Contents"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toBottomOf="@+id/message" />

MainActivity.kt

    import android.os.Bundle
import android.support.design.widget.BottomNavigationView
import android.support.v7.app.AppCompatActivity
import kotlinx.android.synthetic.main.activity_main.*
import <GetRequest>

class MainActivity : AppCompatActivity() {

    private val mOnNavigationItemSelectedListener = BottomNavigationView.OnNavigationItemSelectedListener { item ->
        when (item.itemId) {
            R.id.navigation_home -> {

                val getRequestUtils = GetRequestUtils()
                getRequestUtils.makeGetRequest(this)
                return@OnNavigationItemSelectedListener true
            }
            R.id.navigation_dashboard -> {
                message.setText(R.string.title_dashboard)
                return@OnNavigationItemSelectedListener true
            }
        }
        false
    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        navigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener)
    }}

GetRequestUtils.kt

import android.app.Activity
import android.content.Context
import android.os.Bundle
import com.android.volley.Request
import com.android.volley.Response
import com.android.volley.toolbox.StringRequest
import com.android.volley.toolbox.Volley
import kotlinx.android.synthetic.main.activity_main.*
import <Book>
import <R>

class GetRequestUtils : Activity(){
    val parseResponseUtil = ParseResponseUtil()

    fun makeGetRequest(context: Context) {
        val queue = Volley.newRequestQueue(context)
        val stringRequest = StringRequest(Request.Method.GET, <Get Request URL>, Response.Listener<String> { response ->
            val book = parseResponseUtil.getBookComponents(response)
            message?.text = book.title
            story?.text = book.story
        }, Response.ErrorListener { Book("Something went wrong", "Something went wrong", "Something went wrong")})
        queue.add(stringRequest)
    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
    }
}

** Обратите внимание, что некоторые операции импорта были заменены, поскольку в них указано мое имя.

Всякий раз, когда я делаю этот вызов, я получаю сообщение об ошибке

Попытка вызвать виртуальный метод 'android.view.View android.view.Window.findViewById (int)' для ссылки на нулевой объект

Из моих исследований это связано с тем, что представление не создается и не доступно к моменту выполнения вызова get, но когда я пытаюсь установить текстовые представления сообщений и историй внутри onCreate объекта GetRequestUtils,

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    message.setText("HERE")
    story.setText("HERE2")
}

textViews не обновляются, поэтому я не уверен, что я даже правильно обращаюсь к textViews на activity_main.xml.

Может кто-нибудь помочь мне увидеть, что я делаюнеправильно?

1 Ответ

1 голос
/ 06 ноября 2019

Вы можете рассматривать каждое действие как экран, потому что у вас есть прикрепленный файл R.layout.activity_main xml с MainActivity, поэтому вы не должны прикреплять его где-либо еще (если только вы не хотите создать другой экран с таким же макетом). GetRequestUtils - это класс, используемый для получения данных, поэтому он не должен расширяться Activity. Чтобы вернуть значение после получения данных из API, вы можете использовать интерфейсный обратный вызов

    class GetRequestUtils {

        interface Callback {
            fun onDone(book: Book)
        }

        val parseResponseUtil = ParseResponseUtil()

        fun makeGetRequest(context: Context, callback: Callback) {
            val queue = Volley.newRequestQueue(context)
            val stringRequest = StringRequest(Request.Method.GET, <Get Request URL>, Response.Listener<String> { response ->
                val book = parseResponseUtil.getBookComponents(response)
                callback.onDone(book)
            }, Response.ErrorListener { 
                val book = Book("Something went wrong", "Something went wrong", "Something went wrong")
                callback.onDone(book)
            })
            queue.add(stringRequest)
        }
    }

В MainActivity, установите значение TextView при получении обратного вызова из Request Util

R.id.navigation_home -> {
    val getRequestUtils = GetRequestUtils()
    getRequestUtils.makeGetRequest(this, object : GetRequestUtils.Callback {
        override fun onDone(book: Book) {
            message?.text = book.title
            story?.text = book.story
        })
    return@OnNavigationItemSelectedListener true
}
...