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
}
所以我正在自学 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
}