TextView не устанавливается при создании фрагмента - PullRequest
0 голосов
/ 16 сентября 2018

Это мой первый вопрос о переполнении стека, поэтому заранее прошу прощения, если я задаю неправильный вопрос.

Я пытаюсь создать базовое приложение в Kotlin, в котором у меня есть меню гамбургерас некоторыми фрагментами в нем.Когда пользователь нажимает на HomeFragment, я хочу отобразить приветственное сообщение с его именем (сохраненное в объекте «Общие настройки»).

Однако каждый раз, когда я нажимаю на кнопку меню, чтобы открыть фрагмент, происходит сбой.- даже если я удаляю все имя пользователя / общие префы и просто пытаюсь установить какой-нибудь простой текст.

Вот мой HomeFragment.kt файл:

package com.urmilshroff.kotlindemo

import android.content.Context
import android.net.Uri
import android.os.Bundle
import android.support.v4.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import kotlinx.android.synthetic.main.fragment_home.*


private const val ARG_PARAM1="param1"
private const val ARG_PARAM2="param2"

class HomeFragment:Fragment()
{
    private var param1:String?=null
    private var param2:String?=null
    private var listener:OnFragmentInteractionListener?=null

    override fun onCreate(savedInstanceState:Bundle?)
    {
        super.onCreate(savedInstanceState)
        arguments?.let {
            param1=it.getString(ARG_PARAM1)
            param2=it.getString(ARG_PARAM2)
        }

    }

    override fun onCreateView(inflater:LayoutInflater,container:ViewGroup?,
                              savedInstanceState:Bundle?):View?
    {
        super.onCreate(savedInstanceState)

        val username=SharedPrefObj.getUsername(this.activity!!)
        textViewHello.text="Hi there, $username!"

        return inflater.inflate(R.layout.fragment_home,container,false)
    }

    fun onButtonPressed(uri:Uri)
    {
        listener?.onFragmentInteraction(uri)
    }

    override fun onAttach(context:Context)
    {
        super.onAttach(context)
        if(context is OnFragmentInteractionListener)
        {
            listener=context
        }
        else
        {
            throw RuntimeException(context.toString()+" must implement OnFragmentInteractionListener")
        }
    }

    override fun onDetach()
    {
        super.onDetach()
        listener=null
    }

    interface OnFragmentInteractionListener
    {
        fun onFragmentInteraction(uri:Uri)
    }

    companion object
    {
        @JvmStatic
        fun newInstance()=
                HomeFragment().apply {
                    arguments=Bundle().apply {
                        putString(ARG_PARAM1,param1)
                        putString(ARG_PARAM2,param2)
                    }
                }
    }
}

Мой fragment_home.xml, простов случае:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    tools:context=".HomeFragment">

    <android.support.constraint.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <TextView
            android:id="@+id/textViewHello"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginBottom="8dp"
            android:layout_marginEnd="8dp"
            android:layout_marginStart="8dp"
            android:layout_marginTop="8dp"
            android:fontFamily="monospace"
            android:textAlignment="center"
            android:textColor="@color/colorAccent"
            android:textSize="30sp"
            app:layout_constraintBottom_toTopOf="@+id/textViewDesc"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.993" />

        <TextView
            android:id="@+id/textViewDesc"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginBottom="240dp"
            android:layout_marginEnd="8dp"
            android:layout_marginStart="8dp"
            android:fontFamily="monospace"
            android:text="@string/text_view_desc"
            android:textAlignment="center"
            android:textSize="20sp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintHorizontal_bias="0.503"
            app:layout_constraintStart_toStartOf="parent" />

    </android.support.constraint.ConstraintLayout>
</FrameLayout>

Журнал аварий:

09-17 00:19:24.968 25279-25279/com.urmilshroff.kotlindemo E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.urmilshroff.kotlindemo, PID: 25279
    java.lang.IllegalStateException: textViewHello must not be null
        at com.urmilshroff.kotlindemo.HomeFragment.onCreateView(HomeFragment.kt:37)
        at android.support.v4.app.Fragment.performCreateView(Fragment.java:2346)
        at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1428)
        at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1759)
        at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1827)
        at android.support.v4.app.BackStackRecord.executeOps(BackStackRecord.java:797)
        at android.support.v4.app.FragmentManagerImpl.executeOps(FragmentManager.java:2596)
        at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2383)
        at android.support.v4.app.FragmentManagerImpl.removeRedundantOperationsAndExecute(FragmentManager.java:2338)
        at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2245)
        at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:703)
        at android.os.Handler.handleCallback(Handler.java:790)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)

В нем говорится, что textViewHello не должно быть нулевым, поэтому я попытался сделать его обнуляемым, но он вылетает.Не уверен, что не так.Любая помощь очень ценится, спасибо!

Ответы [ 5 ]

0 голосов
/ 17 сентября 2018

Вам нужно использовать его в onViewCreated.

переопределить веселье onCreateView (inflater: LayoutInflater, container: ViewGroup ?, saveInstanceState: Bundle?): View? { вернуть inflater.inflate (R.layout.qr_my_fragment, контейнер, false) }

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
    super.onViewCreated(view, savedInstanceState)
    init()
}

private fun init() {
    setQRCode()
    initToolbar()
    clickEvents()
}
0 голосов
/ 17 сентября 2018

Вы используете Kotlin Android Extentions в своем проекте, поэтому больше не нужно вызывать метод findViewById.

Все, что вам нужно сделать, это изменить код на:

override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,
                          savedInstanceState: Bundle?): View? {
    super.onCreate(savedInstanceState)
    return inflater.inflate(R.layout.fragment_home, container, false)
}

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
    super.onViewCreated(view, savedInstanceState)
    val username = SharedPrefObj.getUsername(this.activity!!)
    textViewHello.text = "Hi there, $username!"
}
0 голосов
/ 16 сентября 2018

Вы пытаетесь вызвать метод setText, но ваш объект TextView фактически равен нулю. Вам нужно инициализировать. Перед тем, как установить текст, вы должны сделать какой-то шаг. 1. Раздувать представление в переменной

val view = inflater.inflate(R.layout.fragment_home,container,false)

2. Найти и связать объект xml с переменной класса

val textView: TextView = view.findViewById(R.id.textViewHello)

3. Теперь вы можете позвонить setText

textView.setText("Example text")

Просто измените метод onCreateView

val view = inflater.inflate(R.layout.fragment_home,container,false)
val textView: TextView = view.findViewById(R.id.textViewHello)
textView.setText("Example text")
0 голосов
/ 16 сентября 2018

поставить ниже строки в методе onViewCreated.Вам необходимо переопределить этот метод.

textViewHello.text="Hi there, $username!"

, это установит текстовое представление после того, как оно было инициировано в onCreateView

0 голосов
/ 16 сентября 2018

textViewHello не было инициализировано.

Инициализируйте это следующим образом:

val rootView = inflater.inflate(R.layout.fragment_home,container,false) 
val textViewHello: TextView = rootView.findViewById(R.id.textViewHello) as TextView

Добавьте строку выше, прежде чем задавать текст в textview

final onCreateView будет выглядетькак это:

    super.onCreate(savedInstanceState)
    val rootView = inflater.inflate(R.layout.fragment_home,container,false) 
    val username=SharedPrefObj.getUsername(this.activity!!)
    val textViewHello: TextView = rootView.findViewById(R.id.textViewHello) as TextView
    textViewHello.text="Hi there, $username!"
    return rootView;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...