尽管已声明文本,但TextView null错误

时间:2018-12-16 15:39:31

标签: android xml string android-recyclerview android-arrayadapter

我正在尝试在Strings中显示RecyclerView的数组,但是我什至会得到与空相关的错误。我已经仔细阅读了代码,但看不到自己做错了什么。在部署期间,logcat返回此错误:

  

txtTitle不能为空

class MyFragment : androidx.fragment.app.Fragment() {
    private val ITEMTYPE = 100
    private val HEADERTYPE = 101
    private val INFOTYPE = 102

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

    private lateinit var mRecyclerView: RecyclerView
    private lateinit var dataTitle: ArrayList<CharSequence>
    private lateinit var dataRating: ArrayList<String>
    private lateinit var dataDescription: ArrayList<String>
    private lateinit var mAdapter: RecyclerView.Adapter<com.companyname.appname.MyFragment.ViewHolder>

    override fun onActivityCreated(savedInstanceState: Bundle?) {
        val v = view

        mRecyclerView = v!!.findViewById(R.id.my_recyclerview)

        // set the linear layout manager
        mRecyclerView.layoutManager = LinearLayoutManager(activity, RecyclerView.VERTICAL, false)

        // SpannableStrings
        // dynamically change SpannableString colour using defined attribute
        val attrS = intArrayOf(R.attr.spannablestringtextColor)
        val ta = activity!!.theme.obtainStyledAttributes(attrS)
        val colorSS = ta.getColor(0, Color.BLACK) //Color.BLACK - default value (colour will change automatically depending on chosen theme)
        ta.recycle()


        // SpannableString (start)
        val ssb1 = SpannableStringBuilder()

        val str1a = SpannableString(getString(R.string.placeholder1_placeholder2_placeholder3,
                " ", getString(R.string.product_a), " "))
        str1a.setSpan(BackgroundColorSpan(Color.BLACK), 0, str1a.length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
        str1a.setSpan(ForegroundColorSpan(ContextCompat.getColor(context!!, R.color.green)), 0, str1a.length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
        ssb1.append(str1a)

        val str1b = SpannableString(" " + getString(R.string.producta_feature))
        str1b.setSpan(ForegroundColorSpan(colorSS), 0, str1b.length, 0)
        ssb1.append(str1b)
        // SpannableString (end)


        // init data
        dataTitle = ArrayList()
        dataTitle.add(ssbA)
        dataTitle.add(getString(R.string.title_b))

        dataRating = ArrayList()
        dataRating.add(getString(R.string.rating_a))
        dataRating.add(getString(R.string.rating_b))

        dataDescription = ArrayList()
        dataDescription.add(getString(R.string.description_a))
        dataDescription.add(getString(R.string.description_b))


        // create the adapter
        mAdapter = createAdapter()

        // set the adapter
        mRecyclerView.adapter = mAdapter

        super.onActivityCreated(savedInstanceState)
    }

    private fun createAdapter(): RecyclerView.Adapter<com.companyname.appname.MyFragment.ViewHolder> {
        return object : RecyclerView.Adapter<com.companyname.appname.MyFragment.ViewHolder>() {
            override fun onCreateViewHolder(parent: ViewGroup, type: Int): com.companyname.appname.MyFragment.ViewHolder {
                return when (type) {
                    HEADERTYPE -> com.companyname.appname.MyFragment.ViewHolder(inflateHelper(R.layout.rv_header, parent))

                    INFOTYPE -> com.companyname.appname.MyFragment.ViewHolder(inflateHelper(R.layout.rv_info, parent))

                    ITEMTYPE -> com.companyname.appname.MyFragment.ViewHolder(inflateHelper(R.layout.rv_item, parent))

                    else -> com.companyname.appname.MyFragment.ViewHolder(inflateHelper(R.layout.rv_item, parent))
                }
            }

            override fun onBindViewHolder(viewHolder: com.companyname.appname.MyFragment.ViewHolder, position: Int) {
                val rlProductInformation = viewHolder.itemView.findViewById<RelativeLayout>(R.id.rl_product_information)

                when (getItemViewType(position)) {
                    HEADERTYPE -> {
                        val buyButton = viewHolder.itemView.findViewById<Button>(R.id.buy_product)
                        buyButton.setText(R.string.buy)
                    }
                    INTROTYPE -> {
                        val tvIntroA = viewHolder.itemView.findViewById<TextView>(R.id.tv_product_intro_A)

                        val tvIntroB = viewHolder.itemView.findViewById<TextView>(R.id.tv_product_intro_B)
                    }
                    ITEMTYPE -> {
                        val itemA = dataTitle[position]
                        val itemB = dataRating[position]
                        val itemC = dataDescription[position]

                        viewHolder.tvTitle.text = itemA
                        viewHolder.tvSubtitle.text = itemB
                        viewHolder.tvDescription.text = itemC
                    }
                }
            }

            override fun getItemCount(): Int {
                return dataTitle.size + 2
            }

            override fun getItemViewType(position: Int): Int {
                return when (position) {
                    0 -> HEADERTYPE
                    else -> ITEMTYPE
                }
            }
        }
    }

    private fun inflateHelper(resId: Int, parent: ViewGroup): View {
        return LayoutInflater.from(activity).inflate(resId, parent, false)
    }

    class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView)
    internal class MyViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
        var tvTitle: TextView = itemView.findViewById(R.id.tv_product_title) as TextView
        var tvSubtitle: TextView = itemView.findViewById(R.id.tv_product_rating) as TextView
        var tvDescription: TextView = itemView.findViewById(R.id.tv_product_description) as TextView

        init {
            tvTitle; tvSubtitle; tvDescription
        }
    }
}

RecyclerView XML

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/linearLayout_recyclerView"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <androidx.recyclerview.widget.RecyclerView
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/my_recyclerview"
        android:clipToPadding="false"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:scrollbars="vertical"
        android:scrollbarSize="3dp">
    </androidx.recyclerview.widget.RecyclerView>
</LinearLayout>

RecyclerView项目XML

<?xml version="1.0" encoding="utf-8"?>
<androidx.cardview.widget.CardView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/cv_product"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:contentPadding="16dp"
    android:layout_marginBottom="30dp">

    <LinearLayout
        android:id="@+id/ll_cv_product"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">


        <LinearLayout
            android:id="@+id/cv_product_title"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:layout_marginBottom="2dp">

            <TextView
                android:id="@+id/tv_product_title"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                style="@android:style/TextAppearance.Large" />
        </LinearLayout>

        <RelativeLayout
            android:id="@+id/rl_product_information"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

            <TextView
                android:id="@+id/tv_product_new"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/board"
                android:textColor="?android:attr/textColorPrimary"
                style="@android:style/TextAppearance.Large"
                android:layout_below="@+id/cv_product_title"/>

            <TextView
                android:id="@+id/tv_product_rating"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginStart="10dp"
                android:textColor="?android:attr/textColorPrimary"
                style="@android:style/TextAppearance.Large"
                android:layout_below="@+id/cv_product_title"
                android:layout_toEndOf="@+id/tv_product_new" />

            <TextView
                android:id="@+id/tv_product_description"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textColor="?android:attr/textColorPrimary"
                style="@android:style/TextAppearance.Medium"
                android:layout_below="@+id/tv_product_rating" />
        </RelativeLayout>
    </LinearLayout>
</androidx.cardview.widget.CardView>

1 个答案:

答案 0 :(得分:-1)

您应该将RecyclerView初始化代码放在onViewCreated中。该代码很难阅读,但错误表明该项目的相应布局xml中定义了tv_product_title。