Как программно изменить атрибут представления из представления в моем recyclerView в моем фрагменте? - PullRequest
0 голосов
/ 12 февраля 2019

Я установил поле просмотра (представление карты) в моем XML-файле моего элемента, этот файл XML-элемента будет использоваться для моего адаптера recyclerView.

Как вы можете видеть в моем XML-файле ниже,что я дал поле сверху, снизу, начало и конец.и я хочу изменить поле из моего фрагмента

Вот мой xml-файл, item_category_list.xml:

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

<androidx.cardview.widget.CardView
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:cardCornerRadius="8dp"
        app:cardElevation="4dp"
        android:id="@+id/cardView_item_category_list" android:layout_marginStart="8dp" android:layout_marginEnd="8dp"
        android:layout_marginBottom="8dp" android:layout_marginTop="8dp">

    <androidx.constraintlayout.widget.ConstraintLayout
            xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:app="http://schemas.android.com/apk/res-auto"
            xmlns:tools="http://schemas.android.com/tools"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:color/background_light">

        <ImageView
                android:layout_width="0dp"
                android:layout_height="0dp"
                app:srcCompat="@drawable/logo_apps"
                android:id="@+id/categoryImageView_Item"
                android:layout_marginTop="16dp"
                app:layout_constraintTop_toTopOf="parent"
                app:layout_constraintStart_toStartOf="parent"
                android:layout_marginStart="24dp"
                app:layout_constraintEnd_toEndOf="parent"
                android:layout_marginEnd="24dp"
                app:layout_constraintDimensionRatio="w,1:1" android:scaleType="centerCrop"/>

        <TextView
                android:text="@string/Category"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:id="@+id/categoryName_textView_item"
                app:layout_constraintTop_toBottomOf="@+id/categoryImageView_Item"
                app:layout_constraintStart_toStartOf="parent"
                app:layout_constraintBottom_toBottomOf="parent"
                android:layout_marginStart="4dp"
                app:layout_constraintEnd_toEndOf="parent"
                android:layout_marginEnd="4dp"
                android:textAlignment="center"
                android:minLines="1"
                android:maxLines="2"
                app:autoSizeTextType="uniform"
                app:autoSizeMinTextSize="10sp"
                app:autoSizeMaxTextSize="15sp"
                app:autoSizeStepGranularity="1sp"
                android:layout_marginBottom="24dp"
                android:layout_marginTop="24dp"/>


    </androidx.constraintlayout.widget.ConstraintLayout>


</androidx.cardview.widget.CardView>

Вот адаптер :

class CategoryAdapter(val context: Context, val categories: List<Category>) : RecyclerView.Adapter<CategoryAdapter.ViewHolderCategory>() {

    private lateinit var mListener : CategoryAdapterListener

    interface CategoryAdapterListener {
        fun onItemClick(position: Int)
    }

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolderCategory {

        val layoutInflater = LayoutInflater.from(parent.context)
        val itemView = layoutInflater.inflate(R.layout.item_category_list,parent, false)
        return ViewHolderCategory(itemView,mListener)
    }

    override fun getItemCount(): Int {
        return categories.size
    }

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

        val category = categories[position]

        holder.categoryNameTextView.text = category.name
        Glide
            .with(context)
            .load(category.getFormattedImageURL())
            .into(holder.categoryImageView)

    }

    inner class ViewHolderCategory(itemView: View, listener: CategoryAdapterListener) : RecyclerView.ViewHolder(itemView) {

        val categoryImageView = itemView.findViewById<ImageView>(R.id.categoryImageView_Item)
        val categoryNameTextView = itemView.findViewById<TextView>(R.id.categoryName_textView_item)
        val cardView = itemView.findViewById<CardView>(R.id.cardView_item_category_list)

        init {

            itemView.setOnClickListener {
                val position = adapterPosition
                if (position != RecyclerView.NO_POSITION) {
                    listener.onItemClick(position)
                }
            }

        }

    }

    fun setCategoryAdapterListener(listener: CategoryAdapterListener) {
        mListener = listener

    }
}

и во фрагменте я устанавливаю адаптер в представление переработчика:

val categoryAdapter = CategoryAdapter(mContext,parentCategory)
val layoutManager = GridLayoutManager(mContext,4,RecyclerView.VERTICAL,false)

recyclerViewParentCategory.adapter = categoryAdapter
recyclerViewParentCategory.layoutManager = layoutManager
recyclerViewParentCategory.setHasFixedSize(true)

Я хочу изменить это поле в виде карты в моем item_category_list.xml программно в моем файле java / kotlin (в моем файле фрагмента) , чтобы я мог изменить поле из своего фрагмента.

Так как мне этого добиться?Java / Kotlin любой язык является предпочтительным.

Ответы [ 3 ]

0 голосов
/ 12 февраля 2019

Чтобы установить поля на cardView, вам нужно будет создать layoutParams, установить поля для него, а затем установить его как cardView LayoutParams, например:

inner class ViewHolderCategory(itemView: View, listener: CategoryAdapterListener) : RecyclerView.ViewHolder(itemView) {

        val categoryImageView = itemView.findViewById<ImageView>(R.id.categoryImageView_Item)
        val categoryNameTextView = itemView.findViewById<TextView>(R.id.categoryName_textView_item)
        val cardView = itemView.findViewById<CardView>(R.id.cardView_item_category_list)
        //Main code here
        val lparams=LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT)
        lparams.setMargins(leftMargin,topmargin,rightMargin,bottomMargin)
        cardView?.layoutParams=lparams
}
0 голосов
/ 12 февраля 2019

Прежде всего, это долгий путь.Так что я просто предлагаю способ.

  1. Прежде всего.В вашем фрагменте, когда происходит какое-то действие, вам нужно изменить размер карты в элементе списка адаптеров xml.

    Итак.Вам нужен интерфейс для этого (скажем, interface ChangeMargin).создайте интерфейс во Fragment и внедрите этот интерфейс в свой адаптер следующим образом:

class CategoryAdapter(val context: Context, val categories: List<Category>):RecyclerView.Adapter<CategoryAdapter.ViewHolderCategory>(),ChangeMargin()

Как создать интерфейс, чтобы пройти1017 * это

Теперь в этом интерфейсе вам нужно получить вид карты и назначить новое поле.

 @Override
         public void ChangeMargin() {
         val linear_params=LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT)
                 linear_params.setMargins(leftMargin,topmargin,rightMargin,bottomMargin)
                 cardView?.layoutParams=linear_params
         }

и не забудьте уведомить адаптер

0 голосов
/ 12 февраля 2019

Вы можете сделать что-то вроде этого.Создайте идентификатор карты, создайте его экземпляр в своем адаптере и выполните этот код

ViewGroup.MarginLayoutParams layoutParams = (ViewGroup.MarginLayoutParams) myCardView.getLayoutParams ();layoutParams.setMargins (10, 10, 10, 10);

myCardView.requestLayout();
...