前提
Android studioでAlarm managerを使って、時間をセットしたら1日おきに通知がくるようなアプリを作りたいです。
実現したいこと
・時間をセットして通知を送るようにする
・バックグラウンドでも通知が来るようにしたい
・1日おきに指定した時間に通知が来るようにしたい
発生している問題・エラーメッセージ
元々、時間を指定してバックグラウンドでも通知が来るようにはできたのですが、定期実行を行おうと「INTERBAL_DAY」を入れたら、バックグラウンドで出来なくなったり、通知がきたり来なかったりしてしまいます。
↓↓↓元々のコード
alarmManager.set(AlarmManager.RTC_WAKEUP, alarmStartTime, pendingIntent);
↓↓↓定期実行のために編集したコード
alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, alarmStartTime, AlarmManager.INTERVAL_DAY, pendingIntent);
該当のソースコード
activity_main.xml
1<?xml version="1.0" encoding="utf-8"?> 2<LinearLayout 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 android:orientation="vertical" 9 android:gravity="center" 10 android:padding="10dp"> 11 12 <EditText 13 android:id="@+id/editText" 14 android:layout_width="match_parent" 15 android:layout_height="wrap_content" 16 android:hint="Message"/> 17 18 <TimePicker 19 android:id="@+id/timePicker" 20 android:layout_width="310dp" 21 android:layout_height="360dp" 22 android:layout_marginTop="20dp"/> 23 24 <LinearLayout 25 android:layout_width="wrap_content" 26 android:layout_height="wrap_content" 27 android:layout_marginTop="20dp"> 28 <Button 29 android:id="@+id/setBtn" 30 android:layout_width="wrap_content" 31 android:layout_height="wrap_content" 32 android:text="SET"/> 33 <Button 34 android:id="@+id/cancelBtn" 35 android:layout_width="wrap_content" 36 android:layout_height="wrap_content" 37 android:text="CANCEL"/> 38 </LinearLayout> 39 40</LinearLayout>
MainActivity.java
1package com.example.alarm2; 2 3import androidx.appcompat.app.AppCompatActivity; 4 5import android.app.AlarmManager; 6import android.app.PendingIntent; 7import android.content.Intent; 8import android.os.Bundle; 9import android.view.View; 10import android.widget.EditText; 11import android.widget.TimePicker; 12import android.widget.Toast; 13 14import com.example.alarm2.AlarmReceiver; 15import com.example.alarm2.R; 16 17import java.util.Calendar; 18 19public class MainActivity extends AppCompatActivity implements View.OnClickListener { 20 21 private int notificationId = 1; 22 23 @Override 24 protected void onCreate(Bundle savedInstanceState) { 25 super.onCreate(savedInstanceState); 26 setContentView(R.layout.activity_main); 27 28 // Set onClick Listener 29 findViewById(R.id.setBtn).setOnClickListener(this); 30 findViewById(R.id.cancelBtn).setOnClickListener(this); 31 } 32 33 @Override 34 public void onClick(View view) { 35 36 EditText editText = findViewById(R.id.editText); 37 TimePicker timePicker = findViewById(R.id.timePicker); 38 39 // Intent 40 Intent intent = new Intent(MainActivity.this, AlarmReceiver.class); 41 intent.putExtra("notificationId", notificationId); 42 intent.putExtra("message", editText.getText().toString()); 43 44 // PendingIntent 45 PendingIntent pendingIntent = PendingIntent.getBroadcast( 46 MainActivity.this, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT 47 ); 48 49 // AlarmManager 50 AlarmManager alarmManager = (AlarmManager)getSystemService(ALARM_SERVICE); 51 52 switch (view.getId()) { 53 case R.id.setBtn: 54 int hour = timePicker.getCurrentHour(); 55 int minute = timePicker.getCurrentMinute(); 56 57 // Create time. 58 Calendar startTime = Calendar.getInstance(); 59 startTime.set(Calendar.HOUR_OF_DAY, hour); 60 startTime.set(Calendar.MINUTE, minute); 61 startTime.set(Calendar.SECOND, 0); 62 long alarmStartTime = startTime.getTimeInMillis(); 63 64 // Set Alarm 65 // 今回問題のコード ↓↓↓ 66 alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, alarmStartTime, AlarmManager.INTERVAL_DAY, pendingIntent); 67 68 Toast.makeText(this, "Done!", Toast.LENGTH_SHORT).show(); 69 break; 70 71 case R.id.cancelBtn: 72 alarmManager.cancel(pendingIntent); 73 Toast.makeText(this, "Canceled.", Toast.LENGTH_SHORT).show(); 74 break; 75 } 76 77 } 78} 79
AlarmReceiver
1package com.example.alarm2; 2 3import android.app.NotificationChannel; 4import android.app.NotificationManager; 5import android.app.PendingIntent; 6import android.content.BroadcastReceiver; 7import android.content.Context; 8import android.content.Intent; 9import android.os.Build; 10 11import androidx.core.app.NotificationCompat; 12 13import com.example.alarm2.MainActivity; 14 15public class AlarmReceiver extends BroadcastReceiver { 16 17 private static final String CHANNEL_ID = "CHANNEL_SAMPLE"; 18 19 @Override 20 public void onReceive(Context context, Intent intent) { 21 22 // Get id & message 23 int notificationId = intent.getIntExtra("notificationId", 0); 24 String message = intent.getStringExtra("message"); 25 26 // Call MainActivity when notification is tapped. 27 Intent mainIntent = new Intent(context, MainActivity.class); 28 PendingIntent contentIntent = PendingIntent.getActivity(context, 0, mainIntent, 0); 29 30 // NotificationManager 31 NotificationManager notificationManager = 32 (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); 33 34 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { 35 // For API 26 and above 36 CharSequence channelName = "My Notification"; 37 int importance = NotificationManager.IMPORTANCE_DEFAULT; 38 39 NotificationChannel channel = new NotificationChannel(CHANNEL_ID, channelName, importance); 40 notificationManager.createNotificationChannel(channel); 41 } 42 43 // Prepare Notification 44 NotificationCompat.Builder builder = new NotificationCompat.Builder(context, CHANNEL_ID) 45 .setSmallIcon(android.R.drawable.ic_dialog_info) 46 .setContentTitle("TITLE") 47 .setContentText(message) 48 .setContentIntent(contentIntent) 49 .setPriority(NotificationCompat.PRIORITY_DEFAULT) 50 .setAutoCancel(true); 51 52 // Notify 53 notificationManager.notify(notificationId, builder.build()); 54 } 55}
補足情報(FW/ツールのバージョンなど)
android studio
Nexus 6P API 28
をしようしています。
あなたの回答
tips
プレビュー