在Kotlin中的两个活动之间传递对象实例 [英] Passing an object instance between two activities in Kotlin

查看:129
本文介绍了在Kotlin中的两个活动之间传递对象实例的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想知道是否有人可以通过Intent帮助我解决此错误?

I'm wondering if someone could help me to fix this error with Intent?

我有2个活动可以在以下两者之间建立联系: 网格视图"MainActivity.kt"的第一个活动, 第二个是列表视图"Main2Activity.kt",我有2个来自"Main2Activity.kt"的对象实例(adapter1,adapter2),当我单击"MainActivity"中的特定图像时,我想传递特定的对象实例(adapter1)或(adapter2). kt"

I have 2 activities to connect between the: The first activity for Grid View "MainActivity.kt", second for List View "Main2Activity.kt"and I have 2 object instance (adapter1,adapter2) from "Main2Activity.kt" and I wanna pass specific object instance (adapter1) or (adapter2) when click on specific image in the "MainActivity.kt"

注意:我正在使用BaseAdapter

Note: I'm using BaseAdapter

这是MainActivity.kt

class MainActivity : AppCompatActivity() {

var adapter:FoodAdapter?=null
var listOfFoods =ArrayList<Food>()
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(layout.activity_main)


    // load foods
    listOfFoods.add(Food("Coffee","   Coffee preparation is", a))
    listOfFoods.add(Food("Coffee","   Coffee preparation is", b))
    listOfFoods.add(Food("Coffee","   Coffee preparation is", c))
    listOfFoods.add(Food("Coffee","   Coffee preparation is", d))

    adapter= FoodAdapter(this,listOfFoods)

    gvListFood.adapter =adapter

}


class  FoodAdapter: BaseAdapter {
    var listOfFood= ArrayList<Food>()
    var context: Context?=null
    constructor(context:Context,listOfFood:ArrayList<Food>):super(){
        this.context=context
        this.listOfFood=listOfFood
    }
    override fun getView(p0: Int, p1: View?, p2: ViewGroup?): View? {
        val food = this.listOfFood[p0]
        var inflator = context!!.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater
        var foodView= inflator.inflate(layout.food_ticket,null)
        foodView.ivFoodImage.setImageResource(food.image!!)
        foodView.ivFoodImage.setOnClickListener {


            if (foodView.ivFoodImage.context!!.equals(a) ) {
                val intent = Intent(context, Main2Activity::class.java)
                intent.putExtra(Main2Activity.EXTRA_ADAPTER_MODE, AdapterType.ADAPTER_TYPE_2.ordinal)
                    intent.putExtra("name", food.name!!)
                    intent.putExtra("des", food.des!!)
                    intent.putExtra("image", food.image!!)

                    context!!.startActivity(intent)

            }
            else if (foodView.ivFoodImage.context!!.equals(b)) {
                val intent = Intent(context, Main2Activity::class.java)
                intent.putExtra(Main2Activity.EXTRA_ADAPTER_MODE, AdapterType.ADAPTER_TYPE_2.ordinal)
                    intent.putExtra("name", food.name!!)
                    intent.putExtra("des", food.des!!)
                    intent.putExtra("image", food.image!!)
                    context!!.startActivity(intent)

           }
        }
        return foodView
    }

    override fun getItem(p0: Int): Any {
        return listOfFood[p0]
    }

    override fun getItemId(p0: Int): Long {
        return p0.toLong()
    }

    override fun getCount(): Int {

        return listOfFood.size
    }

}
}

这是Main2Activity.kt

class Main2Activity : AppCompatActivity() {
companion object {
    val EXTRA_ADAPTER_MODE = "extra_adapter_mode"
}
var adapter1: FoodAdapter? = null
var adapter2: FoodAdapter2? = null
var listOfFoods2 = ArrayList<Food>()
var listOfFoods3 = ArrayList<Food>()
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main2)


    val bundle = intent?.getIntExtra(EXTRA_ADAPTER_MODE, AdapterType.ADAPTER_TYPE_1.ordinal)
    val name = bundle?.let { AdapterType.fromOrdinal(it) }
    val des = bundle?.let { AdapterType.fromOrdinal(it) }
    val image = bundle?.let { AdapterType.fromOrdinal(it) }

    //val bundle = intent.extras
    //val name = bundle.getString("name")
    //val des = bundle.getString("des")
    //val image = bundle.getInt("image")



    /*
    ivFoodImage2?.let {
        it.setImageResource(image)
    }

    tvName2?.let {
        it.text = name
    }

    tvDes2?.let {
        it.text = des
    }
    */





    // load foods2
    listOfFoods2.add(Food("Coffee", "   Coffee1 preparation is", R.drawable.a))
     listOfFoods2.add(Food("Coffee", "   Coffee2 preparation is", R.drawable.b))

         //listOfFoods2.add(Food("Coffee","   Coffee preparation is",R.drawable.c))
         //listOfFoods2.add(Food("Coffee","   Coffee preparation is",R.drawable.d))


    // load foods3


    //listOfFoods3.add(Food("Coffee","   Coffee preparation is",R.drawable.a))
    //listOfFoods3.add(Food("Coffee","   Coffee preparation is",R.drawable.b))
    listOfFoods3.add(Food("Coffee", "   Coffee3 preparation is", R.drawable.c))
    listOfFoods3.add(Food("Coffee", "   Coffee4 preparation is", R.drawable.d))



   if(adapter1 ==lvFoods2.adapter) {
       adapter1 = FoodAdapter(listOfFoods2, this)
       lvFoods2.adapter = adapter1
    } else if (adapter2==lvFoods2.adapter) {
       adapter2 = FoodAdapter2(listOfFoods3, this)
       lvFoods2.adapter = adapter2
     }

    }


class FoodAdapter : BaseAdapter {
    var context: Context? = null
    var listOfFoodsLocal2 = ArrayList<Food>()

  constructor(listOfFoods2: ArrayList<Food>, context: Context) : super() {
        this.listOfFoodsLocal2 = listOfFoods2
        this.context = context
    }

    override fun getView(p0: Int, p1: View?, p2: ViewGroup?): View {
        val food = this.listOfFoodsLocal2[p0]
        var inflator = context!!.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater
        val foodView = inflator.inflate(R.layout.food_ticket2, null)


                 foodView.ivFoodImage2?.let {
                     it.setImageResource(food.image!!)
                 }
        foodView.tvName2?.let {

            it.text = food.name!!
        }
        foodView.tvDes2?.let {
            it.text = food.des!!
        }

        foodView.ivFoodImage2.setOnClickListener {

            //move to next
            val intent = Intent(context, FoodDetails::class.java)
            intent.putExtra("name", food.name!!)
            intent.putExtra("des", food.des!!)
            intent.putExtra("image", food.image!!)

            context!!.startActivity(intent)

        }
        return foodView

    }


    override fun getItem(p0: Int): Any {
        return listOfFoodsLocal2[p0]
    }

    override fun getItemId(p0: Int): Long {
        return p0.toLong()
    }

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

}

class FoodAdapter2 : BaseAdapter {
    var context: Context? = null
    var listOfFoodsLocal3 = ArrayList<Food>()

  constructor(listOfFoods3: ArrayList<Food>, context: Context) : super() {
        this.listOfFoodsLocal3 = listOfFoods3
        this.context = context
    }

    override fun getView(p0: Int, p1: View?, p2: ViewGroup?): View {
        val food = this.listOfFoodsLocal3[p0]
        var inflator = context!!.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater
        val foodView = inflator.inflate(R.layout.food_ticket2, null)


         foodView.ivFoodImage2?.let {
             it.setImageResource(food.image!!)
         }
        foodView.tvName2?.let {
            it.text = food.name!!
        }
         foodView.tvDes2?.let {
             it.text = food.des!!
         }



        foodView.ivFoodImage2.setOnClickListener {

            //move to next
            val intent = Intent(context, FoodDetails::class.java)
            intent.putExtra("name", food.name!!)
            intent.putExtra("des", food.des!!)
            intent.putExtra("image", food.image!!)

            context!!.startActivity(intent)

        }
        return foodView

    }


    override fun getItem(p0: Int): Any {
        return listOfFoodsLocal3[p0]
    }

    override fun getItemId(p0: Int): Long {
        return p0.toLong()
    }

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

}
}

这是枚举类

enum class AdapterType {
ADAPTER_TYPE_1,
ADAPTER_TYPE_2,
ADAPTER_TYPE_3;


companion object {
     fun fromOrdinal(name:String,des:String,image: Int): AdapterType? {
        return AdapterType.values().firstOrNull { it.ordinal == image}



     }
}
}

推荐答案

创建并将int添加到包中. 对于Kotlin,您必须使用同伴对象来定义变量,例如

and add the int to the bundle. For Kotlin you have to use a companion object to define the variables like

class FirstActivity {
    companion object { 
         val ADAPTER_MODE1 = 0
         val ADAPTER_MODE2 = 1
         val ADAPTER_MODE3 = 2
         //...
    }
}

因此,您可以将无限制的适配器保护套传递给第二项活动

So you can pass unlimited adapter cases to your 2nd activity

编辑: Kotlin 不支持 @IntDef,因此您应该为此使用一个枚举:

EDIT: Kotlin doesn't support @IntDef so you should use an enum for that:

enum class AdapterType {
    ADAPTER_TYPE_1,
    ADAPTER_TYPE_2,
    ADAPTER_TYPE_3;

    companion object {
        fun fromOrdinal(ordinal: Int): AdapterType? {
            return AdapterType.values().firstOrNull { it.ordinal == ordinal }
        }
    }
}

然后像这样使用它:

class FirstActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val intent = Intent(this, SecondActivity::class.java)
        intent.putExtra(SecondActivity.EXTRA_ADAPTER_MODE, AdapterType.ADAPTER_TYPE_2.ordinal)
    }
}

并像这样检索它:

class SecondActivity : AppCompatActivity() {
    companion object {
        val EXTRA_ADAPTER_MODE = "extra_adapter_mode"
    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        //...
        val adapterTypeOrdinal = intent?.getIntExtra(EXTRA_ADAPTER_MODE, AdapterType.ADAPTER_TYPE_1.ordinal)
        val adapterType = adapterTypeOrdinal?.let { AdapterType.fromOrdinal(it) }

        // do something with it
    }
}

这篇关于在Kotlin中的两个活动之间传递对象实例的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆