Kotlin Android Jetpack Навигация между фрагментами в backstack - PullRequest
0 голосов
/ 07 декабря 2018

У меня есть небольшое приложение.1 Activity (MainActivity.kt) и два фрагмента (MainFragment и CreateNewJobFragment).

Мэйнфрагмент имеет вид Recycler.CreateNewJobFragment содержит 6 блесен и текст редактирования.Я пытаюсь получить выбор из счетчиков и текст редактирования, чтобы заполнить RecyclerView, когда пользователь делает свой выбор и нажимает кнопку «создать работу».

Проблема заключается в том, что при нажатии этой кнопки приложениевернётся обратно в стек обратно к главному фрагменту, но вместо того, чтобы заполнять представление переработчика новым элементом, он снова запускает onCreate и ничего не происходит.

MainFragment.kt

class MainFragment : Fragment() ,ItemClickedCustomListener{
override fun onCustomSpinnerItemSelected(selectedItems: JobData) {

    Log.v("MainFragment","onCustomSpinnerItemSelected")
    Log.v("MainFragment","selectedItems --> "
            + selectedItems.companyName + " "
            + selectedItems.location + " "
            + selectedItems.pumpTruck + " "
            + selectedItems.smartPiggers)
    jobs.add(selectedItems)
    adapter = recyclerView.adapter as JobAdapter
    adapter.data(jobs)
}

var jobs = ArrayList<JobData>()
lateinit var  adapter : JobAdapter

private lateinit var binding: FragmentMainBinding
lateinit var recyclerView : RecyclerView

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

        if (savedInstanceState == null) {
            binding = FragmentMainBinding.inflate(inflater)
            //getting recyclerview from xml and binding it
            recyclerView = binding.jobRecyclerView

            //adding a layoutmanager
            recyclerView.layoutManager = LinearLayoutManager(context, RecyclerView.VERTICAL, false)

            //Arraylist to store jobs using the data class JobData.
            // TODO: Change this to a user created list from CreateNewJobFragment.kt
            jobs = ArrayList()

            Log.v("MainFragment", "onCreateView --> ")

            //creating adapter
            adapter = JobAdapter(jobs)

            //add adapter to recyclerView
            recyclerView.adapter = adapter

            //Setting onClickListener for FAB(floating action button) using Navigation
            binding.createNewJobFAB.setOnClickListener { v: View ->
                v.findNavController().navigate(R.id.action_mainFragment_to_createNewJobFragment)
            }
        }
    return binding.root
}

}

CreateNewJobFragment.kt

class CreateNewJobFragment : Fragment() {

private lateinit var binding: FragmentCreateNewJobBinding

override fun onCreateView(
    inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
    binding = FragmentCreateNewJobBinding.inflate(inflater)
    return binding.root
}

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

    var addJobToRecyclerview = JobData("","","","")


    //String array.
    //TODO: Move this to res/strings
    val companyNames = arrayOf("Company A", "Company B", "Company C", "Company D", "Company E")

    var nameSpinner = binding.spinnerCustomerName

    //Adapter for spinner
    nameSpinner.adapter = ArrayAdapter(activity, android.R.layout.simple_spinner_dropdown_item, companyNames)

    //item selected listener for spinner
    nameSpinner.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
        override fun onNothingSelected(p0: AdapterView<*>?) {
            TODO("not implemented yet")
        }

        override fun onItemSelected(p0: AdapterView<*>?, p1: View?, p2: Int, p3: Long) {
            //user selected spinner choice added
            addJobToRecyclerview.companyName = companyNames[p2]
        }
    }

    //String array.
    //TODO: Move this to res/strings
    val refineryTown = arrayOf("Long Beach", "Houston", "Cherry Point", "Wood River", "Bismark")

    var townSpinner = binding.spinnerLocation

    //Adapter for spinner
    townSpinner.adapter = ArrayAdapter(activity, android.R.layout.simple_spinner_dropdown_item, refineryTown)

    //item selected listener for spinner
    townSpinner.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
        override fun onNothingSelected(p0: AdapterView<*>?) {
            TODO("not implemented yet")
        }

        override fun onItemSelected(p0: AdapterView<*>?, p1: View?, p2: Int, p3: Long) {
            addJobToRecyclerview.location = refineryTown[p2]
        }
    }

    <SNIP>Cutting out 5 repeated spinners and editText to save some space</SNIP>


    //Setting onClickListener for 'Create Job' button using Navigation
    binding.buttonCreateJob.setOnClickListener { v: View ->
        (activity as MainActivity).itemClickedCustomListener.onCustomSpinnerItemSelected(addJobToRecyclerview)
        Log.v("CreateNewJobFragment", "Job data added -->$addJobToRecyclerview")
        Log.v("CreateNewJobFragment", "Create job button --> clicked")

        v.findNavController().navigate(R.id.action_createNewJobFragment_to_mainFragment)

    }

}

}

В качестве руководства я использую следующую документацию по Android: Реализация навигации

И эта часть, в частности, для перехода обратно к главному фрагменту: Связать места назначения с виджетами пользовательского интерфейса

После нажатия кнопки «Создать работу».Приложение возвращается в MainFragment.Но, как уже упоминалось, в Recyclerview ничего не отображается.

У меня есть некоторые записи на месте.Это из журналов:

Пример журнала

2018-12-07 22: 03: 17.959 5806-5806 / com.palarran.pigtimer V /MainActivity: onCustomSpinnerItemSelected

2018-12-07 22: 03: 17.959 5806-5806 / com.palarran.pigtimer V / MainActivity: selectedItems -> Компания Компания Лонг-Бич 1 Компания 4

2018-12-07 22: 03: 17.960 5806-5806 / com.palarran.pigtimer V / CreateNewJobFragment: добавлены данные о задании -> JobData (companyName = компания A, местоположение = Лонг-Бич, pumpTruck = компания 1, smartPiggers = компания 4)

2018-12-07 22: 03: 17.960 5806-5806 / com.palarran.pigtimer V / CreateNewJobFragment: кнопка Создать задание -> нажал

2018-12-07 22:03: 18.026 5806-5806 / com.palarran.pigtimer V / MainFragment: onCreateView ->

2018-12-07 22: 03: 18.146 5806-5806 / com.palarran.pigtimer V / JobAdapter: getItemCount0

2018-12-07 22: 03: 18.146 5806-5806 / com.palarran.pigtimer V / JobAdapter: getItemCount 0

Как видно, после записи в журналедля «Создать кнопку задания -> нажал» он переходит к «onCreateView» в MainFragment, и количество элементов в моем настраиваемом адаптере (JobAdapter.kt) не увеличивается.

JobAdapter.kt

class JobAdapter(private var jobList: ArrayList<JobData>) : RecyclerView.Adapter<JobAdapter.ViewHolder>() {

//Returning view for each item in the list
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): JobAdapter.ViewHolder {
    val v = LayoutInflater.from(parent.context).inflate(R.layout.job_list_item, parent, false)
    Log.v("JobAdapter","onCreateViewHolder")
    return ViewHolder(v)
}

//Binding the data on the list
override fun onBindViewHolder(holder: JobAdapter.ViewHolder, position: Int) {
    Log.v("JobAdapter","onBindViewHolder")
    holder.bindItems(jobList[position])
}

override fun getItemCount(): Int {
    Log.v("JobAdapter","getItemCount " + jobList.size)
    return jobList.size
}

fun data(jobs: ArrayList<JobData>) {
    Log.v("JobAdapter","DataSetChanged")
    jobList = jobs
    notifyDataSetChanged()
}

//Class holds the job list view
class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {

    fun bindItems(job: JobData) {
        val textViewCompanyName = itemView.findViewById(R.id.tv_companyName) as TextView
        val textViewLocation  = itemView.findViewById(R.id.tv_job_location) as TextView

        textViewCompanyName.text = job.companyName
        Log.v("JobAdapter", "bindItems" + textViewCompanyName.text)
        textViewLocation.text = job.location
        Log.v("JobAdapter", "bindItems" + textViewLocation.text)
    }
}

}

Я что-то упустил в документах или неправильно их прочитал?Я определенно что-то неправильно понимаю.

1 Ответ

0 голосов
/ 19 декабря 2018

Поздно отвечаю на это.

Мне удалось выяснить это.Используя базу данных Sugar ORM.Вызов его в onResume () в моем MainFragment.

Это был глупый вопрос, который я должен был изучить больше, прежде чем публиковать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...