前提・実現したいこと
ここに質問の内容を詳しく書いてください。
kotlin言語ででandroidのアプリを作っています。
背景を変えるように作ったspinnerのリストをクリックし、MainActivityの画面に戻っても、画像変更が反映されるように作っています。しかし実行してみると背景が変化しません
■■な機能を実装中に以下のエラーメッセージが発生しました。
実行しても背景が変わりません。(実行エラー)
該当のソースコード
kotlin
ソースコード
MainActivity.kt package com.example.mkualarm import android.app.Activity import android.content.Context import android.content.Intent import android.content.SharedPreferences import android.support.v7.app.AppCompatActivity import android.os.Bundle import kotlinx.android.synthetic.main.activity_main.* open class MainActivity : AppCompatActivity() {//open修飾子 継承できるようにする override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) AddAlarm.setOnClickListener { //SetActivityに移動 val intent = Intent(this, SetActivity::class.java) startActivity(intent) } } // MainActivity#onResumeで固定値定義されている画像を不揮発領域を参照して差し替える処理に変更すれば問題なく動作します。らしい //背景場面を統一 override fun onResume() {//onResumeはActivityが呼び出された時に実行される super.onResume() //SetActivityから背景選択の際に受け取った変数を入れる val text = intent.getIntExtra("TEXT_KEY",R.drawable.mokou2) background.setImageResource(text)//imageviewの背景のやつ } }
SetActivity.kt package com.example.mkualarm import android.app.Activity import android.content.Context import android.content.Intent import android.content.SharedPreferences import android.os.Bundle import android.support.v7.app.AppCompatActivity import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import android.widget.* import kotlinx.android.synthetic.main.activity_set.* import java.text.SimpleDateFormat import java.util.* open class SetActivity : MainActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_set) //listviewの名前の配列 val listView = findViewById<ListView>(R.id.listview) listView.adapter = MycoustomAdapter(this) //clickしたときの処理 settingA.setOnClickListener { //MainActivityに戻る val intent = Intent(this, MainActivity::class.java) startActivity(intent) } } public inner class MycoustomAdapter(context: Context) : BaseAdapter() { //innerクラスにした fun getToday(): String {//現在時刻取得 val date = Date() val format = SimpleDateFormat("HH:mm", Locale.getDefault()) return format.format(date) } private val mContext: Context private val names = arrayListOf<String>( "時刻", "背景", "音声", "未定" ) val descriptions = listOf("", "", "", "") val arrays = arrayListOf(//spinnerのやつ R.array.txt_time_arr,//ここ R.array.txt_image_arr, R.array.txt_sound_arr, R.array.txt_unknown_arr ) init { mContext = context } //responsible for how many rows in my list override fun getCount(): Int { return names.size } override fun getItemId(position: Int): Long { return position.toLong() } override fun getItem(position: Int): Any { return "TEST STRING" } //responsible for rendering out each row override fun getView(position: Int, convertView: View?, viewGroup: ViewGroup?): View { val layoutInflater = LayoutInflater.from(mContext) val LISTITEM = layoutInflater.inflate(R.layout.list_item, viewGroup, false) val NameTextView = LISTITEM.findViewById<TextView>(R.id.nameTextView) NameTextView.text = names.get(position) val DescTextView = LISTITEM.findViewById<TextView>(R.id.descTextView) DescTextView.text = descriptions.get(position)//Textview2がdescriptionsの要素に変わる val spinner: Spinner = LISTITEM.findViewById(R.id.spinner)//spinnerをにつける var adapter = ArrayAdapter.createFromResource(//adapterのレイアウト mContext, arrays.get(position), R.layout.spinner_item ) adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item) // Apply the adapter to the spinner spinner.adapter = adapter // リスナーを登録 spinner.onItemSelectedListener = object : AdapterView.OnItemSelectedListener { // アイテムが選択された時 override fun onItemSelected( parent: AdapterView<*>?, view: View?, pos: Int, id: Long ) { val spinnerParent = parent as Spinner val item = spinnerParent.selectedItem as String // Kotlin Android Extensions //pos == 1は背景のリスト if (position == 1) { when (pos) { 0 -> { background.setImageResource(R.drawable.mokou2)//背景変更○ val text = R.drawable.mokou2 //intent変数をつなげる(第一引数はキー,第二引数は渡したい変数) intent.putExtra("TEXT_KEY",text) } 1 -> { background.setImageResource(R.drawable.mokou3) val text = R.drawable.mokou3 intent.putExtra("TEXT_KEY",text) }//背景変更○ } } } // アイテムが選択されなかった override fun onNothingSelected(parent: AdapterView<*>?) { } } return LISTITEM } } }
試したこと
MainActivity.ktのソースコードの
//SetActivityから背景選択の際に受け取った変数を入れる
val text = intent.getIntExtra("TEXT_KEY",R.drawable.mokou2)
のgetIntExtra処理の第二引数(初期値)を0にすると画像が出なくなるので、background.setImageResource(text)が機能していることはわかりました。
###以下を参考にして作りました
https://akira-watson.com/android/kotlin/activity-trans-data.html#1
https://qiita.com/kazu5546325/items/d3e18579215c0b379f93
補足情報(FW/ツールのバージョンなど)
回答1件
あなたの回答
tips
プレビュー