У меня есть активность с фрагментами в качестве основного контента.
В этом действии есть панель инструментов с TextView внутри:
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(my_activity)
val toolbar = findViewById<Toolbar>(R.id.toolbar)
setSupportActionBar(toolbar)
supportActionBar!!.setDisplayHomeAsUpEnabled(false)
supportActionBar!!.setDisplayShowTitleEnabled(false)
}
Вот панель инструментов в xml документе этого занятия:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MyActivity">
<include
android:id="@+id/toolbar"
layout="@layout/my_toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<FrameLayout
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@id/toolbar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent">
<fragment android:name="org.siku.siku.MyFragment"
android:id="@+id/fullscreen_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
layout="@layout/my_fragment" />
</FrameLayout>
</android.support.constraint.ConstraintLayout>
А вот toolbar.xml, который я использую:
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<Button
android:id="@+id/closeBtn"
android:layout_width="wrap_content"
android:layout_height="match_parent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<LinearLayout
android:id="@+id/titleLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<TextView
android:id="@+id/toolBarText1"
android:layout_width="wrap_content"
android:layout_height="match_parent"/>
</LinearLayout>
</android.support.constraint.ConstraintLayout>
</android.support.v7.widget.Toolbar>
Я могу легко изменить текст из этого упражнения, но я не могу изменить текст из фрагмента:
Я попытался получить доступ к TextView из фрагмента, но получаю сообщение об ошибке
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?): View? {
myView = inflater.inflate(R.layout.my_frament, container, false)
val toolbar = activity!!.findViewById<Toolbar>(R.id.toolbar)
val toolbarTextView = toolbar.findViewById<TextView>(R.id.toolBarText1)
}
Вот ошибка, которую я получаю:
Причина: java.lang.NullPointerException: попытка вызвать виртуальную
Метод 'android.view.View
android.support.v7.widget.Toolbar.findViewById (int) 'для нулевого объекта
ссылка
Ошибка исходит из этой строки:
val toolbarTextView = toolbar.findViewById (R.id.toolBarText1)
Это означает, что я не получаю этот TextView должным образом, но из примеров, которые я видел, это должен быть правильный способ сделать это.