Как отобразить переработчик в макете Tab с помощью kotlin? - PullRequest
0 голосов
/ 30 августа 2018

Я новичок в Android, у меня есть приложение, разработанное на языке kotlin. Одно из моих занятий содержит макет вкладок с фрагментами (две вкладки). На каждой вкладке есть список переработанных данных с данными. Я поражен отображением моего повторного просмотра с данными в представлении вкладок. Это то, что я пытался.

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
    }
}

1 Ответ

0 голосов
/ 30 августа 2018

Изменение:

        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(). Вы на самом деле делали это слишком сложным.

...