Kotlin Android 访问文本视图的扩展

Kotlin Android Extensions accessing text views

所以我正在自学 android 开发,我只是想用 Volley get 调用的结果更新文本视图。我看过其他 Whosebug 线程和 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)
    }
}

**注意一些导入已替换为,因为导入中有我的名字。

每当我进行此调用时,我都会收到一条错误消息,说明

Attempt to invoke virtual method 'android.view.View android.view.Window.findViewById(int)' on a null object reference

根据我的研究,这是因为在进行 get 调用时尚未创建或访问视图,但是当我尝试在 GetRequestUtils 的 onCreate 中设置消息和故事文本视图时,

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

textViews 没有更新,所以我不确定我什至无法正确访问 activity_main.xml 上的 textViews。

谁能帮我看看我做错了什么?

您可以将每个 Activity 视为一个屏幕,因为您已将 R.layout.activity_main xml 文件附加到 MainActivity,因此您不应将其附加到其他任何地方(除非你想创建另一个具有相同布局的屏幕)。 GetRequestUtils 是用于获取数据的 class,因此不应扩展 Activity。从API获取数据后的return值,可以使用接口回调

    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中,当从 Request Util 获取回调时将值设置为 TextView

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
}