Android
 Computer >> コンピューター >  >> プログラミング >> Android

Androidでローカル通知をスケジュールする方法は?


この例は、Androidでローカル通知をスケジュールする方法について示しています。

ステップ1 − Android Studioで新しいプロジェクトを作成し、[ファイル]⇒[新しいプロジェクト]に移動して、新しいプロジェクトを作成するために必要なすべての詳細を入力します。

ステップ2 −次のコードをres / layout/activity_main.xmlに追加します。

<? xml version = "1.0" encoding = "utf-8" ?>
<RelativeLayout xmlns: android = "https://schemas.android.com/apk/res/android"
   xmlns: tools = "https://schemas.android.com/tools"
   android :layout_width = "match_parent"
   android :layout_height = "match_parent"
   android :padding = "16dp"
   tools :context = ".MainActivity" />

ステップ3 −次のコードをres / menu/main_menu.xmlに追加します。

<? xml version = "1.0" encoding = "utf-8" ?>
<menu xmlns: android = "https://schemas.android.com/apk/res/android"
   xmlns: app = "https://schemas.android.com/apk/res-auto" >
   <item
      android :id = "@+id/action_5"
      app :showAsAction = "never"
      android :title = "5 seconds" />
   <item
      android :id = "@+id/action_10"
      app :showAsAction = "never"
      android :title = "10 seconds" />
   <item
      android :id = "@+id/action_30"
      app :showAsAction = "never"
      android :title = "30 seconds" />
</menu>

ステップ4 −次のコードをsrc/MainActivityに追加します。

package app.tutorialspoint.com.notifyme ;
import android.app.AlarmManager ;
import android.app.Notification ;
import android.app.NotificationManager ;
import android.app.PendingIntent ;
import android.content.Context ;
import android.content.Intent ;
import android.os.Bundle ;
import android.os.SystemClock ;
import android.support.v4.app.NotificationCompat ;
import android.support.v7.app.AppCompatActivity ;
import android.view.Menu ;
import android.view.MenuItem ;
public class MainActivity extends AppCompatActivity {
   public static final String NOTIFICATION_CHANNEL_ID = "10001" ;
   private final static String default_notification_channel_id = "default" ;
   @Override
   protected void onCreate (Bundle savedInstanceState) {
      super .onCreate(savedInstanceState) ;
      setContentView(R.layout. activity_main ) ;
   }
   @Override
   public boolean onCreateOptionsMenu (Menu menu) {
      // Inflate the menu; this adds items to the action bar if it is present.
      getMenuInflater().inflate(R.menu. menu_main , menu) ;
      return true;
   }
   @Override
   public boolean onOptionsItemSelected (MenuItem item) {
      switch (item.getItemId()) {
         case R.id. action_5 :
            scheduleNotification(getNotification( "5 second delay" ) , 5000 ) ;
            return true;
         case R.id. action_10 :
            scheduleNotification(getNotification( "10 second delay" ) , 10000 ) ;
            return true;
         case R.id. action_30 :
            scheduleNotification(getNotification( "30 second delay" ) , 30000 ) ;
            return true;
         default :
            return super .onOptionsItemSelected(item) ;
      }
   }
   private void scheduleNotification (Notification notification , int delay) {
      Intent notificationIntent = new Intent( this, MyNotificationPublisher. class ) ;
      notificationIntent.putExtra(MyNotificationPublisher. NOTIFICATION_ID , 1 ) ;
      notificationIntent.putExtra(MyNotificationPublisher. NOTIFICATION , notification) ;
      PendingIntent pendingIntent = PendingIntent. getBroadcast ( this, 0 , notificationIntent , PendingIntent. FLAG_UPDATE_CURRENT ) ;
      long futureInMillis = SystemClock. elapsedRealtime () + delay ;
      AlarmManager alarmManager = (AlarmManager) getSystemService(Context. ALARM_SERVICE ) ;
      assert alarmManager != null;
      alarmManager.set(AlarmManager. ELAPSED_REALTIME_WAKEUP , futureInMillis , pendingIntent) ;
   }
   private Notification getNotification (String content) {
      NotificationCompat.Builder builder = new NotificationCompat.Builder( this, default_notification_channel_id ) ;
      builder.setContentTitle( "Scheduled Notification" ) ;
      builder.setContentText(content) ;
      builder.setSmallIcon(R.drawable. ic_launcher_foreground ) ;
      builder.setAutoCancel( true ) ;
      builder.setChannelId( NOTIFICATION_CHANNEL_ID ) ;
      return builder.build() ;
   }
}

ステップ5 −次のコードをsrc/MyNotificationPublisherに追加します。

package app.tutorialspoint.com.notifyme ;
import android.app.Notification ;
import android.app.NotificationChannel ;
import android.app.NotificationManager ;
import android.content.BroadcastReceiver ;
import android.content.Context ;
import android.content.Intent ;
import static app.tutorialspoint.com.notifyme.MainActivity. NOTIFICATION_CHANNEL_ID ;
public class MyNotificationPublisher extends BroadcastReceiver {
   public static String NOTIFICATION_ID = "notification-id" ;
   public static String NOTIFICATION = "notification" ;
   public void onReceive (Context context , Intent intent) {
      NotificationManager notificationManager = (NotificationManager)context.getSystemService(Context. NOTIFICATION_SERVICE ) ;
      Notification notification = intent.getParcelableExtra( NOTIFICATION ) ;
      if (android.os.Build.VERSION. SDK_INT >= android.os.Build.VERSION_CODES. O ) {
         int importance = NotificationManager. IMPORTANCE_HIGH ;
         NotificationChannel notificationChannel = new NotificationChannel( NOTIFICATION_CHANNEL_ID , "NOTIFICATION_CHANNEL_NAME" , importance) ;
         assert notificationManager != null;
         notificationManager.createNotificationChannel(notificationChannel) ;
      }
      int id = intent.getIntExtra( NOTIFICATION_ID , 0 ) ;
      assert notificationManager != null;
      notificationManager.notify(id , notification) ;
   }
}

ステップ6 −次のコードをAndroidManifest.xmlに追加します

<? xml version = "1.0" encoding = "utf-8" ?>
<manifest xmlns: android = "https://schemas.android.com/apk/res/android"
   package= "app.tutorialspoint.com.notifyme" >
   <uses-permission android :name = "android.permission.VIBRATE" />
   <application
      android :allowBackup = "true"
      android :icon = "@mipmap/ic_launcher"
      android :label = "@string/app_name"
      android :roundIcon = "@mipmap/ic_launcher_round"
      android :supportsRtl = "true"
      android :theme = "@style/AppTheme" >
      <activity android :name = ".MainActivity" >
         <intent-filter>
            <action android :name = "android.intent.action.MAIN" />
            <category android :name = "android.intent.category.LAUNCHER" />
         </intent-filter>
      </activity>
      <receiver android :name = ".MyNotificationPublisher" />
   </application>
</manifest>

アプリケーションを実行してみましょう。実際のAndroidモバイルデバイスをコンピューターに接続していると思います。 android studioからアプリを実行するには、プロジェクトのアクティビティファイルの1つを開き、ツールバーの[実行]アイコンをクリックします。オプションとしてモバイルデバイスを選択し、デフォルトの画面を表示するモバイルデバイスを確認します-

Androidでローカル通知をスケジュールする方法は?

Androidでローカル通知をスケジュールする方法は?


  1. Android でプッシュ通知を有効にする方法

    プッシュ通知とは、スマートフォンにときどきポップアップするメッセージです。オンラインで買い物をするのが好きなら、プッシュ通知でたくさんのオファーが届きます。それらのいくつかは、数時間利用できる場合があります。 Android でプッシュ通知を誤って無効にすると、再度有効にする作業になる可能性があります。 ほとんどのアプリは、インストール中にプッシュ通知を送信する許可を求めます。アプリに許可しているため、これらの広告通知を受け取ります。ただし、プロンプトが表示されない場合や誤って無効にした場合は、次の手順に従って Android でプッシュ通知を有効にしてください。 「設定」 に移動します

  2. Windows 10 で Android 通知を取得する方法

    Android は、世界で最も使用されているオペレーティング システムの 1 つであり、多数のユーザーを抱えています。 Android を搭載したスマートフォンの性能が向上したため、Windows 10 で Android の通知を受け取ることができるようになりました。これにより、仕事中や携帯電話が遠くにある場合でも、確認するために取りに行く必要がなくなります。 Windows 10 での通知の取得は組み込み機能の 1 つであるため、微調整が必​​要な設定がいくつかあります。設定を理解する前に、正規の Windows 10 と必要な更新プログラムを使用していることが重要です。 Window