前提・実現したいこと
はじめてのAndroidプログラミングを読みながらAndroid Studioを使って勉強をしているのですが
サンプルコードを入力してダイアログを表示させようとしているのですが上手く表示されません。
何度も見直したのですがわかりませんでした。
発生している問題・エラーメッセージ
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {
val builder = AlertDialog.Builder(requireActivity())
builder.setMessage("時間になりました")
builder.setPositiveButton("起きる"){dialog, which ->
listener?.getUp()
}
builder.setNegativeButton("あと5分"){dialog, which ->
listener?.snooze()
}
return builder.create()
}
こちらのコードの4行目と7行目の dialog, which の下に灰色で波線が表示されています。
それ以外にエラーなどは出ていません。
ダイアログに関して最新のバージョンだと書き方が違うなどあるのでしょうか?
プログラミング初心者ですので的外れな質問でしたら申し訳ございません。
該当のソースコード
Kotlin
ソースコード
MainActivity.kt
html
1package com.example.myalarmclock 2 3import android.app.AlarmManager 4import android.app.PendingIntent 5import android.content.Context 6import android.content.Intent 7import android.os.Build 8import android.support.v7.app.AppCompatActivity 9import android.os.Bundle 10import android.widget.Toast 11import kotlinx.android.synthetic.main.activity_main.* 12import java.util.* 13 14class MainActivity : AppCompatActivity(),TimeAlertDialog.Listener { 15 16 override fun getUp() { 17 Toast.makeText(this,"起き上がるがクリックされました",Toast.LENGTH_SHORT) 18 .show() 19 } 20 21 override fun snooze() { 22 Toast.makeText(this,"あと5分がクリックされました",Toast.LENGTH_SHORT) 23 .show() 24 } 25 26 override fun onCreate(savedInstanceState: Bundle?) { 27 super.onCreate(savedInstanceState) 28 29 if(intent?.getBooleanExtra("onReceive",false) == true){ 30 val dialog = TimeAlertDialog() 31 dialog.show(supportFragmentManager,"alert_dialog") 32 } 33 34 setContentView(R.layout.activity_main) 35 36 setAlarm.setOnClickListener{ 37 val calendar = Calendar.getInstance() 38 calendar.timeInMillis = System.currentTimeMillis() 39 calendar.add(Calendar.SECOND,5) 40 setAlarmManager(calendar) 41 42 cancelAlarm.setOnClickListener{ 43 cancelAlarmManager() 44 } 45 } 46 } 47 48 private fun setAlarmManager(calendar: Calendar){ 49 val am = getSystemService(Context.ALARM_SERVICE) as AlarmManager 50 val intent = Intent(this,AlarmBroadcastReceiver::class.java) 51 val pending = PendingIntent.getBroadcast(this,0,intent,0) 52 when{ 53 Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP -> { 54 val info = AlarmManager.AlarmClockInfo( 55 calendar.timeInMillis, null) 56 am.setAlarmClock(info, pending) 57 } 58 Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT ->{ 59 am.setExact(AlarmManager.RTC_WAKEUP, 60 calendar.timeInMillis,pending) 61 } 62 else ->{ 63 am.set(AlarmManager.RTC_WAKEUP, 64 calendar.timeInMillis,pending) 65 } 66 } 67 } 68 69 private fun cancelAlarmManager(){ 70 val am = getSystemService(Context.ALARM_SERVICE) as AlarmManager 71 val intent = Intent(this,AlarmBroadcastReceiver::class.java) 72 val pending = PendingIntent.getBroadcast(this,0,intent,0) 73 am.cancel(pending) 74 } 75}
AlarmBroadcastReceiver.kt
html
1package com.example.myalarmclock 2 3import android.content.BroadcastReceiver 4import android.content.Context 5import android.content.Intent 6import android.widget.Toast 7 8class AlarmBroadcastReceiver : BroadcastReceiver() { 9 10 override fun onReceive(context: Context, intent: Intent) { 11 val mainIntent = Intent(context,MainActivity::class.java) 12 .putExtra("onReceive",true) 13 .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK) 14 context.startActivity(mainIntent) 15 } 16}
Dialogs.kt
html
1package com.example.myalarmclock 2 3import android.app.AlertDialog 4import android.app.Dialog 5import android.content.Context 6import android.os.Bundle 7import android.support.v4.app.DialogFragment 8 9 10class TimeAlertDialog : DialogFragment(){ 11 interface Listener { 12 fun getUp() 13 fun snooze() 14 } 15 private var listener: Listener? = null 16 17 override fun onAttach(context: Context) { 18 super.onAttach(context) 19 when(context){ 20 is Listener -> listener = context 21 } 22 } 23 override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { 24 val builder = AlertDialog.Builder(requireActivity()) 25 builder.setMessage("時間になりました") 26 builder.setPositiveButton("起きる"){dialog, which -> 27 listener?.getUp() 28 } 29 builder.setNegativeButton("あと5分"){dialog, which -> 30 listener?.snooze() 31 } 32 return builder.create() 33 } 34}
activity_main.xml
html
1<?xml version="1.0" encoding="utf-8"?> 2<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:app="http://schemas.android.com/apk/res-auto" 4 xmlns:tools="http://schemas.android.com/tools" 5 android:layout_width="match_parent" 6 android:layout_height="match_parent" 7 tools:context=".MainActivity"> 8 9 <ImageView 10 android:id="@+id/imageView" 11 android:layout_width="0dp" 12 android:layout_height="0dp" 13 android:scaleType="centerCrop" 14 app:layout_constraintBottom_toBottomOf="parent" 15 app:layout_constraintEnd_toEndOf="parent" 16 app:layout_constraintHorizontal_bias="0.0" 17 app:layout_constraintStart_toStartOf="parent" 18 app:layout_constraintTop_toTopOf="parent" 19 app:layout_constraintVertical_bias="0.0" 20 app:srcCompat="@drawable/background" /> 21 22 <TextView 23 android:id="@+id/dateText" 24 android:layout_width="0dp" 25 android:layout_height="wrap_content" 26 android:layout_marginStart="32dp" 27 android:layout_marginTop="32dp" 28 android:layout_marginEnd="32dp" 29 android:background="@color/textBackground" 30 android:textColor="@android:color/white" 31 android:textSize="36sp" 32 app:layout_constraintEnd_toEndOf="parent" 33 app:layout_constraintStart_toStartOf="parent" 34 app:layout_constraintTop_toTopOf="parent" /> 35 36 <TextView 37 android:id="@+id/timeText" 38 android:layout_width="0dp" 39 android:layout_height="wrap_content" 40 android:layout_marginStart="32dp" 41 android:layout_marginTop="32dp" 42 android:layout_marginEnd="32dp" 43 android:background="@color/textBackground" 44 android:textAlignment="center" 45 android:textColor="@android:color/white" 46 android:textSize="36sp" 47 app:layout_constraintEnd_toEndOf="parent" 48 app:layout_constraintStart_toStartOf="parent" 49 app:layout_constraintTop_toBottomOf="@+id/dateText" /> 50 51 <Button 52 android:id="@+id/setAlarm" 53 android:layout_width="wrap_content" 54 android:layout_height="wrap_content" 55 android:layout_marginStart="32dp" 56 android:layout_marginTop="32dp" 57 android:layout_marginEnd="32dp" 58 android:text="@string/setAlarm" 59 app:layout_constraintEnd_toEndOf="parent" 60 app:layout_constraintStart_toStartOf="parent" 61 app:layout_constraintTop_toBottomOf="@+id/timeText" /> 62 63 <Button 64 android:id="@+id/cancelAlarm" 65 android:layout_width="wrap_content" 66 android:layout_height="wrap_content" 67 android:layout_marginStart="32dp" 68 android:layout_marginTop="32dp" 69 android:layout_marginEnd="32dp" 70 android:text="@string/cancerAlarm" 71 app:layout_constraintEnd_toEndOf="parent" 72 app:layout_constraintStart_toStartOf="parent" 73 app:layout_constraintTop_toBottomOf="@+id/setAlarm" /> 74</android.support.constraint.ConstraintLayout>
試したこと
val builder = AlertDialog.Builder(requireActivity())
requireActivity()を requireContext()などに変えてみたりしました。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/05/23 15:27