質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
ダイアログ

ユーザーにウィンドウやボックス等の形で個別で表示されるフォームであり、ユーザーに判断を促す目的で表示される。ユーザーが見逃す事のないよう、操作中のフォーム上にポップアップして表示される。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

Q&A

1回答

1118閲覧

【Kotlin】日付選択ダイアログ仕様に変更したい

torepyon

総合スコア4

ダイアログ

ユーザーにウィンドウやボックス等の形で個別で表示されるフォームであり、ユーザーに判断を促す目的で表示される。ユーザーが見逃す事のないよう、操作中のフォーム上にポップアップして表示される。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

0グッド

0クリップ

投稿2020/02/03 06:47

編集2022/01/12 10:55

現在、日付を文字入力する仕様になっているのですが、日付選択ダイアログにする方法がわかりません。

以下ソース

MainActivity

class MainActivity : AppCompatActivity() {
private lateinit var realm: Realm
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
setSupportActionBar(toolbar)
realm = Realm.getDefaultInstance()
val schedules = realm.where<Schedule>().findAll()
listView.adapter = ScheduleAdapter(schedules)

fab.setOnClickListener { view -> startActivity<ScheduleEditActivity>() Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG) .setAction("Action", null).show() } listView.setOnItemClickListener { parent, view, position, id -> val schedule = parent.getItemAtPosition(position) as Schedule startActivity<ScheduleEditActivity>("schedule_id" to schedule.id) } } override fun onDestroy() { super.onDestroy() realm.close() }

}

ScheduleEditActivity

class ScheduleEditActivity : AppCompatActivity() {
private lateinit var realm: Realm

override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_schedule_edit) realm = Realm.getDefaultInstance() val scheduleId = intent?.getLongExtra("schedule_id", -1L) if(scheduleId != -1L) { val schedule = realm.where<Schedule>() .equalTo("id", scheduleId).findFirst() dateEdit.setText( DateFormat.format("yyyy/MM/dd", schedule?.date) ) titleEdit.setText(schedule?.title) detailEdit.setText(schedule?.detail) delete.visibility = View.VISIBLE } else { delete.visibility = View.INVISIBLE } save.setOnClickListener { when(scheduleId) { -1L -> { realm.executeTransaction { val maxId = realm.where<Schedule>().max("id") val nextId = (maxId?.toLong() ?: 0L) + 1 val schedule = realm.createObject<Schedule>(nextId) dateEdit.text.toString().toDate("yyyy/MM/dd")?.let { schedule.date = it } schedule.title = titleEdit.text.toString() schedule.detail = detailEdit.text.toString() } alert("追加しました") { yesButton { finish() } }.show() } else -> { realm.executeTransaction { val schedule = realm.where<Schedule>() .equalTo("id", scheduleId).findFirst() dateEdit.text.toString().toDate("yyyy/MM/dd")?.let { schedule?.date = it } schedule?.title = titleEdit.text.toString() schedule?.detail = detailEdit.text.toString() } alert("修正しました") { yesButton { finish() } }.show() } } } delete.setOnClickListener { realm.executeTransaction { realm.where<Schedule>().equalTo("id", scheduleId) ?.findFirst() ?.deleteFromRealm() } alert("削除しました") { yesButton { finish() } }.show() } } override fun onDestroy() { super.onDestroy() realm.close() } fun String.toDate(pattern: String = "yyyy/MM/dd HH:mm"): Date? { val sdFormat = try { SimpleDateFormat(pattern) } catch (e: IllegalArgumentException) { null } val date = sdFormat?.let { try { it.parse(this) } catch (e: ParseException) { null } } return date }

}

Dialog

class DatePickerFragment : DialogFragment(),
DatePickerDialog.OnDateSetListener {

interface OnDateSelectedListener { fun onSelected(year: Int, month: Int, date: Int) } private lateinit var listener: OnDateSelectedListener override fun onAttach(context: Context?) { super.onAttach(context) if(context is OnDateSelectedListener) { listener = context } } override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { val c = Calendar.getInstance() val year = c.get(Calendar.YEAR) val month = c.get(Calendar.MONTH) val date = c.get(Calendar.DAY_OF_MONTH) return DatePickerDialog(context, this, year, month, date) } override fun onDateSet(view: DatePicker, year: Int, month: Int, date: Int) { ```listener.onSelected(year, month, date)
} } 試したこと -- Dialogファイルを作成し、DatePickerFragment.OnDateSelectedListenerをMainActivityに書いたところ日付選択ダイアログは表示されたのですが、日付を選択した後落ちてしまいます。エラー内容(kotlin.UninitializedPropertyAccessException: lateinit property listener has not been initialized at com.example.myalarmclock.DatePickerFragment.onDateSet)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

keicha_hrs

2020/02/04 13:24

現行、示されているコードにはDatePickerFragmentが用いられていませんが、どのように使ったのでしょうか。「実際に落ちてしまうコード」を示すべきでしょう。また、コードを示すときはコード修飾用の Markdownを使用(質問エディターの<code>ボタンを押して、出てきた雛形の```の行の間にコードを挟むように記述する)するようにしてください。
guest

回答1

0

kotlin

1class DatePickerFragment : DialogFragment(), DatePickerDialog.OnDateSetListener {

そもそも上記がおかしいです。OnDateSetListenerの実装(implements)は、このダイアログを呼び出すActivityに行う必要があるのではありませんか。

kotlin

1class MainActivity : AppCompatActivity(), DatePickerDialog.OnDateSetListener {

のようにしてMainActivityにOnDateSetListenerを実装して、抽象メソッドであるonSelectedも記述すれば良いのではないかと思います。

OnDateSetListenerが実装されていないActivityからDatePickerFragmentを呼び出しても、下記の処理で変数listenerには何も値が渡されず、以降の処理でlistenerを参照する処理を行った時点で落ちることでしょう。

kotlin

1 override fun onAttach(context: Context?) { 2 super.onAttach(context) 3 // OnDateSelectedListenerが実装されていないクラスのインスタンスがcontextに渡されても 4 // 下記のif文は真とならずlistenerには何も代入されない 5 if(context is OnDateSelectedListener) { 6 listener = context 7 } 8 }

ミスの構図としては前回の質問と全く同一です。

投稿2020/02/05 15:58

keicha_hrs

総合スコア6766

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問