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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Android Studio

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

Kotlin

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

Android Emulator

Android EmulatorはアンドロイドのOSで起動しているアンドロイドのデバイスの機能をシミュレートするソフトウェアです。Emulatorは開発者に複数の違う設定を持ったデバイスを必要とすることなくアプリケーションを開発しテストすることが可能になります。

Q&A

解決済

1回答

1104閲覧

Kotlin Android Studio ダイアログが表示されません。

hego

総合スコア1

Android Studio

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

Kotlin

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

Android Emulator

Android EmulatorはアンドロイドのOSで起動しているアンドロイドのデバイスの機能をシミュレートするソフトウェアです。Emulatorは開発者に複数の違う設定を持ったデバイスを必要とすることなくアプリケーションを開発しテストすることが可能になります。

0グッド

0クリップ

投稿2020/05/23 11:58

前提・実現したいこと

はじめての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/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

AlarmBroadcastReceiverが走っていないのではないでしょうか。

AndroidManifest.xmlに

xml

1 <receiver android:name=".AlarmBroadcastReceiver" />

のような記述が必要になると思われますが、それが抜けているということはありませんか?


余談。

kotlin

1 builder.setPositiveButton("起きる") { dialog, which ->

のdialogやwhichのところに黄波線(灰色っぽく見えるかも)がついているのは、これらの引数が未使用だからです。気になるのであれば、

kotlin

1 builder.setPositiveButton("起きる") { _, _ ->

のようにアンダースコアに置き換えることもできます。

投稿2020/05/23 12:42

編集2020/05/23 12:46
keicha_hrs

総合スコア6768

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

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

hego

2020/05/23 15:27

ありがとうございます! AndroidManifest.xmlを調べて見た所ファイル名を間違えておりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問