如何使用 kotlin 在 Tab 布局中显示 recyclerview?

How to display recyclerview in Tab layout using kotlin?

我是 Android 的新手,我有一个由 kotlin language.One 开发的应用程序 activity 包含带有片段的选项卡布局(两个选项卡)。每个选项卡都有一个列表在 data.i 的 recyclerview 中,我尝试在选项卡 view.This 中显示带有数据的 recyclerview。

main.kt

private fun setupViewPager(viewPager: ViewPager) {
        val adapter = ViewPagerAdapter(supportFragmentManager)
        adapter.addFragment(OneFragment(), "RECEIVE LIST")
        adapter.addFragment(TwoFragment(), "SEND LIST")
        viewPager.adapter = adapter
    }

    internal inner class ViewPagerAdapter(manager: FragmentManager) : FragmentPagerAdapter(manager) {
        private val mFragmentList = ArrayList<Fragment>()
        private val mFragmentTitleList = ArrayList<String>()

        override fun getItem(position: Int): Fragment {
            return mFragmentList[position]
        }

        override fun getCount(): Int {
            return mFragmentList.size
        }

        fun addFragment(fragment: Fragment, title: String) {
            mFragmentList.add(fragment)
            mFragmentTitleList.add(title)
        }

        override fun getPageTitle(position: Int): CharSequence {
            return mFragmentTitleList[position]
        }
    }

TransactionRecyclerAdapter.kt

enum class TransactionAdapterDirection {
    INCOMING, OUTGOING
}

class TransactionRecyclerAdapter(private val transactionList: List<TransactionEntity>,
                                 val appDatabase: AppDatabase,
                                 private val direction: TransactionAdapterDirection,
                                 val networkDefinitionProvider: NetworkDefinitionProvider) : RecyclerView.Adapter<TransactionViewHolder>() {

    override fun getItemCount() = transactionList.size

    override fun onBindViewHolder(holder: TransactionViewHolder, position: Int) = holder.bind(transactionList[position], appDatabase)

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): TransactionViewHolder {
        val itemView = LayoutInflater.from(parent.context).inflate(R.layout.transaction_item, parent,false)
        return TransactionViewHolder(itemView,direction,networkDefinitionProvider)

OneFragment.kt

class OneFragment : Fragment() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

    }

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        // Inflate the layout for this fragment
        //return inflater!!.inflate(R.layout.frag_one, container, false)

        val rootView = inflater!!.inflate(R.layout.frag_one, container, false)
        val recyclerView = rootView.findViewById<RecyclerView>(R.id.transaction_recycler_in) as RecyclerView
        recyclerView.setHasFixedSize(true);
        recyclerView
                .setLayoutManager(LinearLayoutManager(getActivity()));//Linear Items

        recyclerView.adapter = TransactionRecyclerAdapter()// struck with here 
        recyclerView.layoutManager = LinearLayoutManager(context)
        return rootView
    }
}

变化:

        recyclerView.setHasFixedSize(true);
        recyclerView.setLayoutManager(LinearLayoutManager(getActivity()));

        recyclerView.adapter = TransactionRecyclerAdapter()// struck with here 
        recyclerView.layoutManager = LinearLayoutManager(context)

收件人:

linearLayoutManager = LinearLayoutManager(getActivity(), LinearLayout.VERTICAL, false)
        recyclerView?.layoutManager = linearLayoutManager
        recyclerView?.adapter = TransactionRecyclerAdapter() // Your adapter
        recyclerView?.setHasFixedSize(true);

不要忘记添加:

private var linearLayoutManager: LinearLayoutManager? = null

onCreateView() 之上。你把它搞得太复杂了。