Добавление и удаление элементов в режиме корзины Kotlin - PullRequest
0 голосов
/ 30 апреля 2020

У меня проблема с добавлением и удалением элементов в представлении корзины в Kotlin. Первая задача - добавить кнопку «Добавить», и после нажатия на нее одно и то же c изображение нужно добавлять снова и снова. Когда я внедряю эту кнопку в основной xml, кнопка никогда не появляется. Вторая задача - удалить элемент по клику. Это то, что я сделал до сих пор.

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout
android:layout_height="match_parent"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:orientation="vertical">

<androidx.recyclerview.widget.RecyclerView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:id="@+id/recycleview"/>
<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Add an item"
    android:layout_marginStart="280dp"/>

</LinearLayout>

package com.example.lecture11
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import androidx.recyclerview.widget.LinearLayoutManager
import kotlinx.android.synthetic.main.activity_main.*

class MainActivity : AppCompatActivity() {



private var ItemsList= mutableListOf<ModelItem>()
private lateinit var adapter:MyAdapter


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

private  fun init(){

    adapter= MyAdapter(ItemsList)
    recycleview.layoutManager=LinearLayoutManager(this)
    recycleview.adapter=adapter



    setData()
}



private  fun setData(){
        ItemsList.add(ModelItem(R.mipmap.messi,"Messi"))
        ItemsList.add(ModelItem(R.mipmap.iniesta, "Iniesta"))
        ItemsList.add(ModelItem(R.mipmap.henry,"Henry"))
        ItemsList.add(ModelItem(R.mipmap.buffon,"Buffon"))
        ItemsList.add(ModelItem(R.mipmap.messi,"Messi"))
        ItemsList.add(ModelItem(R.mipmap.iniesta, "Iniesta" ))
        ItemsList.add(ModelItem(R.mipmap.henry,"Henry"))
        ItemsList.add(ModelItem(R.mipmap.buffon,"Buffon"))

  }
}


package com.example.lecture11

class ModelItem(var image:Int, var title:String)

package com.example.lecture11

import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView
import kotlinx.android.synthetic.main.items_layout.view.*

class MyAdapter(val ItemsList:MutableList<ModelItem>) : RecyclerView.Adapter<MyAdapter.ViewHolder>() {


override fun getItemCount(): Int {
    return ItemsList.size
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {

    return  
ViewHolder(LayoutInflater.from(parent.context).inflate(R.layout.items_layout,parent,false))
}



override fun onBindViewHolder(holder: ViewHolder, position: Int) {



    holder.onBound()

}

inner class  ViewHolder(view :View):RecyclerView.ViewHolder(view){

    private lateinit var model:ModelItem

    fun onBound(){
        model=ItemsList[adapterPosition]
        itemView.imageview.setImageResource(model.image)
        itemView.title.text=model.title


      }

  }

}

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:background="@drawable/background"
android:orientation="vertical"
android:layout_height="wrap_content">

<ImageView
    android:scaleType="centerCrop"
    android:src="@mipmap/messi"
    android:id="@+id/imageview"
    android:layout_width="match_parent"
    android:layout_height="200dp"/>
<TextView
    android:layout_marginTop="10dp"
    android:id="@+id/title"
    android:textColor="#fff"
    android:textStyle="bold"
    android:textAlignment="center"
    android:text="@string/messi"
    android:textSize="25sp"
    android:layout_width="match_parent"
    android:layout_height="40dp"/>





</LinearLayout>

Ответы [ 2 ]

0 голосов
/ 02 мая 2020

Вам необходимо вызвать notifyDatasetChanged() на адаптере после добавления элементов в данные или один из более конкретных c методов, таких как notifyItemRangeInserted (в вашем случае). Последнее в большинстве случаев более эффективно и не приведет к миганию существующих элементов.

0 голосов
/ 01 мая 2020

Если вы хотите, чтобы кнопка в нижней части экрана оставляла остальной объем просмотра переработчиком, вам нужно использовать вес макета -

<LinearLayout
    android:layout_height="match_parent"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:orientation="vertical">

    <androidx.recyclerview.widget.RecyclerView
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:orientation="vertical"
        android:id="@+id/recycleview"/>
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Add an item"
        android:layout_marginStart="280dp"/>

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