将值从一个片段传递到另一个

时间:2020-02-16 02:32:55

标签: android-fragments kotlin retrofit

我在Kotlin工作,正在使用改造产品。我有一个回收站视图,其中包含卡片。每张卡都有一个typeName和一个与之关联的图像,现在我已经使用dataclass静态添加了它。现在,一旦用户单击特定的卡,我只需将typeName从CategoryFragment传递到LocationFragment。在LocationFragment中,我想从数据库中检查纬度,经度和typeName是否存在。

这是我的类别数据类的代码: 数据类Category_dataclass(val category_image:Int,val typeName:String)

这是我的CategoryFragment代码:

package com.example.atry.MakeComplaint

import android.content.Context
import android.net.Uri
import android.os.Bundle
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.recyclerview.widget.GridLayoutManager
import androidx.recyclerview.widget.RecyclerView
import com.example.atry.History.Complaints
import com.example.atry.History.MyComplainRecyclerViewAdapter

import com.example.atry.R
import kotlinx.android.synthetic.main.existing_complaint_popup.*


class CategoryFragment : Fragment() {

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

        }
    }

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        val v = inflater.inflate(R.layout.fragment_category, container, false)
        val recyclerView = v.findViewById(R.id.category_list) as RecyclerView

        recyclerView.apply {
            layoutManager = GridLayoutManager(context!!, 2)
        }

        //creating an arraylist to store category using the data class user
        val category = ArrayList<Category_dataclass>()

        //adding some dummy data to the list of categories
        category.add(Category_dataclass((R.drawable.trash) , "Water"))
        category.add(Category_dataclass((R.drawable.fire) , "Sewerage"))
        category.add(Category_dataclass((R.drawable.dustbin) , "load"))




        //creating our adapter
        val adapter = CategoryRecyclerViewAdapter(category)

        //now adding the adapter to recyclerview
        recyclerView.adapter = adapter


        // Inflate the layout for this fragment
        return v



    }




    }

这是CategoryRecyclerViewAdapter:

package com.example.atry.MakeComplaint

import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.ImageView
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
import androidx.recyclerview.widget.RecyclerView
import com.example.atry.History.ComplaintDetailsFragment
import com.example.atry.History.Complaints
import com.example.atry.MakeComplaint.Category_dataclass
import com.example.atry.MakeComplaint.CategoryRecyclerViewAdapter
import com.example.atry.R
import java.util.*
import kotlin.collections.ArrayList

class CategoryRecyclerViewAdapter(val categoryList: ArrayList<Category_dataclass>) : RecyclerView.Adapter<CategoryRecyclerViewAdapter.ViewHolder>() {




    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): CategoryRecyclerViewAdapter.ViewHolder {
        val v = LayoutInflater.from(parent.context).inflate(R.layout.fragment_category_single, parent, false)
        return ViewHolder(v)
    }

    //this method is binding the data on the list
    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
        holder.bindItems(categoryList[position])
        holder.mView.setOnClickListener{view->



            val lFragment = LocationFragment()
            val oldFragment = CategoryFragment()
            val manager = (holder.mView.context as AppCompatActivity).supportFragmentManager
            val transaction =  manager.beginTransaction()
            transaction.replace(
                R.id.first_screen_of_makecomplaint,
                lFragment
            ) // give your fragment container id in first parameter
            transaction.show(lFragment)
            transaction.hide(oldFragment)
            transaction.isAddToBackStackAllowed
            transaction.addToBackStack(oldFragment.fragmentManager.toString())  // if written, this transaction will be added to backstack
            transaction.commit()

        }
    }


    //this method is giving the size of the list
    override fun getItemCount(): Int {
        return categoryList.size
    }


    inner class ViewHolder(val mView : View) : RecyclerView.ViewHolder(mView) {
        fun bindItems(cat:Category_dataclass) {
            val imageViewName = mView.findViewById(R.id.category_image) as ImageView
            val textViewtext = mView.findViewById(R.id.category_text) as TextView

            imageViewName.setImageResource(cat.category_image)
            textViewtext.text = cat.typeName


        }



    }

}

这是我的改型:

 //to check existing complaint

    @GET("api/existingComplain")
    @FormUrlEncoded
    fun checkExistingComplain(@Query("typeName") typeName:String,
                              @Query("longitude") longitude:String,
                              @Query("latitude") latitude:String):Observable<Observables.checkExistingResult>

我创建了对象并存储了数据类,该对象将返回以下内容:

data class checkExistingResult(val description:String , val Complain:String)

如果typeName和位置已经存在于数据库中,则我希望描述和投诉显示在材料样式对话框中。

1 个答案:

答案 0 :(得分:0)

您可以尝试以下方法:

第一步:-

val dashboard = "Dashboard"

采用这样的变量,您可以将其名称作为片段名称,因此可以像这样MainActivity().dashboard

来检查页面名称

现在,第二步:-

创建一个类并在该类中编写类似的函数

 fun openPage(
    activity: Activity,
    pagename: String?, model: PaymentDetails
) {
    when (pagename) {

            MainActivity().dashboard -> {
                val mfragment = DashboardFragment()
                (activity as MainActivity).fragmentManager.beginTransaction()
                    .replace(R.id.nav_host, mfragment).commit()

                val a = Bundle()
                a.putSerializable("model", model)
                mfragment.arguments = a
            }
        }
    }

采用键值对,就像我采用整个模型一样,键是 model ,在我的代码中,您可以编写任何东西。

第三步:-

制作模型可序列化

第四步:-将值添加到模型中时,请添加详细信息,并为要使用这些值的方法添加模型,例如

val payment = PaymentDetails(
            type,
            price,
            name,
            id,
         )
        paymentData!!.add(payment)
        CustomMethods().openPagePaymentDetails(
            activity!!,
            MainActivity().sessionPaymentFragment, payment
        )

第五步:-

用模型类型声明和初始化对象,如下所示:

 //Declare 
 private var model: PaymentDetails? = null 

//initialise
 model = arguments!!.getSerializable("model") as PaymentDetails?

现在终于可以像这样访问上一个片段的值到下一个片段了,

var type: String
type = model!!.type

注意:-请不要忘记使模型类可序列化

希望如此对您有帮助。