https://hirauchi-genta.com/kotlin-listview/#2
こちらのサイトを参考に画像付きのリスト実装を勉強している初学者です。サイトと同じようにアプリ起動時( MainActivity )にリスト画面を表示することは出来ました。そこで、今度は画面遷移の中で同リストを表示させようとしたのですが、これが上手く行っていない状態です。
流れとしては MainActivity でボタンを押す → SubActivity でリスト表示という簡単なものです。コード上はエラーは出ず、アプリも起動できますが、 MainActivity 上のボタンを押すと、「(プロジェクト名)has stopped」とのメッセージが出て画面遷移が出来ず、アプリは落ちてしまいます。
Log を見てみると java.lang.NullPointerException: listView must not be null と表示されており、これがエラーの原因と思われます。自力で調べてみましたが、よく分からず、こちらでエラー文の意味と対処法を教えてくださると嬉しいです。質問内容やコードに不足等ありましたら、申し訳ございません。
kotlin
1SubActivity.kt 2package 3 4import android.content.Intent 5import android.os.Bundle 6import android.widget.ListView 7import androidx.appcompat.app.AppCompatActivity 8 9class SubActivity: AppCompatActivity(),CustomAdapterListener { 10 11 lateinit var mCustomAdapter: CustomAdapter 12 lateinit var mAnimalList: ArrayList<Animal> 13 14 override fun onCreate(savedInstanceState: Bundle?) { 15 super.onCreate(savedInstanceState) 16 setContentView(R.layout.activity_sub) 17 18 // データ一覧の実装 19 val dog = Animal("イヌ", R.drawable.dog1) 20 val cat = Animal("ネコ", R.drawable.cat1) 21 val elephant = Animal("ゾウ", R.drawable.elephant1) 22 val horse = Animal("ウマ", R.drawable.horse1) 23 val lion = Animal("ライオン", R.drawable.lion1) 24 mAnimalList = arrayListOf(dog, cat, elephant, horse, lion) 25 26 val listView = findViewById<ListView>(R.id.list_view) 27 28 // CustomAdapterの生成と設定 29 mCustomAdapter = CustomAdapter(this, mAnimalList,this) 30 listView.adapter = mCustomAdapter 31 } 32 // 追加ボタンがタップされたら呼ばれる 33 override fun clicked(animal: Animal) { 34 mAnimalList.add(animal) 35 36 // CustomAdapterに実装したリスト更新用の関数を呼ぶ 37 mCustomAdapter.updateAnimalList(mAnimalList) 38 } 39 40}
kotlin
1CustomAdapter.kt 2package 3 4import android.content.Context 5import android.view.LayoutInflater 6import android.view.View 7import android.view.ViewGroup 8import android.widget.ArrayAdapter 9import android.widget.Button 10import android.widget.ImageView 11import android.widget.TextView 12 13// interfaceの実装 14interface CustomAdapterListener { 15 fun clicked(animal: Animal) 16} 17 18class CustomAdapter(context: Context, var mAnimalList: List<Animal>,val listener: CustomAdapterListener) : ArrayAdapter<Animal>( 19 context, 20 0, 21 mAnimalList 22) { 23 24 val layoutInflater = context.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater 25 26 override fun getView(position: Int, convertView: View?, parent: ViewGroup): View { 27 // Animalの取得 28 val animal = mAnimalList[position] 29 30 // レイアウトの設定 31 var view = convertView 32 if (convertView == null) { 33 view = layoutInflater.inflate(R.layout.activity_sub, parent, false) 34 } 35 36 // 各Viewの設定 37 val imageView = view?.findViewById<ImageView>(R.id.image) 38 imageView?.setImageResource(animal.imageId) 39 40 val name = view?.findViewById<TextView>(R.id.name) 41 name?.text = animal.name 42 43 44 val button = view?.findViewById<Button>(R.id.button) 45 button?.setOnClickListener { 46 listener.clicked(animal) 47 } 48 49 return view!! 50 } 51 // リスト更新用の関数を実装 52 fun updateAnimalList(animalList: List<Animal>) { 53 mAnimalList = animalList 54 // 再描画 55 notifyDataSetChanged() 56 } 57 58}
xml
1activity_sub.xml 2<?xml version="1.0" encoding="utf-8"?> 3<LinearLayout 4 xmlns:android="http://schemas.android.com/apk/res/android" 5 android:layout_width="match_parent" 6 android:layout_height="match_parent" 7 android:padding="12dp"> 8 9 <ImageView 10 android:id="@+id/image" 11 android:layout_width="60dp" 12 android:layout_height="match_parent" /> 13 14 <TextView 15 android:id="@+id/name" 16 android:layout_width="wrap_content" 17 android:layout_height="36dp" 18 android:layout_weight="1" 19 android:text="TextView" 20 android:textSize="24sp" /> 21 22 <Button 23 android:id="@+id/button" 24 android:layout_width="wrap_content" 25 android:layout_height="wrap_content" 26 android:layout_weight="1" 27 android:text="Button" /> 28 29</LinearLayout>
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。