現在表の勉強をしております。自分の目標は二つの配列を使って表のなかに二つの値を表示することです。
まず、表の中に1つの値を持たせる実装は達成できました。
次にこの表の中にそれぞれの人間の好みを当てはめたいと思っています。下の画像が理想形。(合成で作っただけの画像です)
そこで僕が作成したコードが下記
MainActivity.kt
1 2import androidx.appcompat.app.AppCompatActivity 3import android.os.Bundle 4import androidx.recyclerview.widget.DividerItemDecoration 5import androidx.recyclerview.widget.LinearLayoutManager 6import androidx.recyclerview.widget.RecyclerView 7import org.w3c.dom.Text 8 9class MainActivity : AppCompatActivity() { 10 11 private lateinit var recyclerView: RecyclerView 12 13 override fun onCreate(savedInstanceState: Bundle?) { 14 super.onCreate(savedInstanceState) 15 setContentView(R.layout.activity_main) 16 17 val TextList = listOf( 18 "ボブ", 19 "エミリー", 20 "マイク", 21 "サム", 22 "エドワード" 23 ) 24 val TextList2 = listOf( 25 "アイスクリームが好き", 26 "ハチミツが好き", 27 "運動が好き", 28 "アウトドアが好き", 29 "野球観戦が好き" 30 ) 31 32 recyclerView = findViewById(R.id.RecyclerList) 33 ⭐️recyclerView.adapter = RecyclerAdapter(TextList) 34 ⭐️recyclerView.adapter = RecyclerAdapter(TextList2) 35 recyclerView.layoutManager = LinearLayoutManager(this) 36 37 val dividerItemDecoration = 38 DividerItemDecoration(this , LinearLayoutManager(this).getOrientation()) 39 recyclerView.addItemDecoration(dividerItemDecoration) 40 41 } 42}
RecyclerAdapter.kt
1import android.view.LayoutInflater 2import android.view.ViewGroup 3import androidx.recyclerview.widget.RecyclerView 4 5class RecyclerAdapter(val list: List<String>) : RecyclerView.Adapter<ViewHolderList>() { 6 override fun onCreateViewHolder(parent: ViewGroup , viewType: Int): ViewHolderList { 7 val itemView = LayoutInflater.from(parent.context).inflate(R.layout.item_recycler_list, parent, false) 8 return ViewHolderList(itemView) 9 } 10 11 override fun onBindViewHolder(holder: ViewHolderList, position: Int) { 12 holder.characterList.text = list[position] 13 holder.characterList2.text = list[position] 14 } 15 16 override fun getItemCount(): Int = list.size 17}
ViewHolderList.kt
1import android.view.View 2import android.widget.TextView 3import androidx.recyclerview.widget.RecyclerView 4 5class ViewHolderList (item: View) : RecyclerView.ViewHolder(item) { 6 val characterList: TextView = item.findViewById(R.id.Text1) 7 val characterList2: TextView = item.findViewById(R.id.Text2) 8}
activity_main.xml
1<?xml version="1.0" encoding="utf-8"?> 2<LinearLayout 3 xmlns:android="http://schemas.android.com/apk/res/android" 4 android:layout_width="match_parent" 5 android:layout_height="match_parent"> 6 7 <androidx.recyclerview.widget.RecyclerView 8 android:id="@+id/RecyclerList" 9 android:layout_width="match_parent" 10 android:layout_height="match_parent"/> 11 12</LinearLayout>
item_recycler_list.xml
1<LinearLayout 2 android:layout_width="match_parent" 3 android:layout_height="wrap_content" 4 xmlns:android="http://schemas.android.com/apk/res/android" 5 android:orientation="vertical" 6 android:padding="10dp"> 7 8 <LinearLayout 9 android:layout_width="match_parent" 10 android:layout_height="54dp" 11 android:layout_marginLeft="10dp" 12 android:layout_marginRight="10dp" 13 android:layout_marginBottom="0dp"> 14 15 <TextView 16 android:id="@+id/Text1" 17 android:layout_width="wrap_content" 18 android:layout_height="wrap_content" 19 android:layout_marginTop="8dp" 20 android:textSize="10sp" /> 21 22 <TextView 23 android:id="@+id/Text2" 24 android:layout_width="wrap_content" 25 android:layout_height="wrap_content" 26 android:layout_marginTop="23dp" 27 android:textSize="15sp" /> 28 29 </LinearLayout> 30</LinearLayout>
これでエミュレータを実行すると、、、
このように一つの配列が二つのtextviewに反映してしまうようになってしまいます。自己考察としてMainActivity.ktの⭐️マークであるこの2行
⭐️ recyclerView.adapter = RecyclerAdapter(TextList)
⭐️recyclerView.adapter = RecyclerAdapter(TextList2)
recyclerView.adapterに再代入してしまっているためだろうと考察しているのですが、間違えているところがわかっても。修正方法がわかりません。
どなたか正解コードを教えてください。その正解をもとに勉強していきたいです><
回答1件