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" >
   <Button
      android :layout_width = "match_parent"
      android :layout_height = "wrap_content"
      android :layout_centerInParent = "true"
      android :onClick = "closeApp"
      android :text = "close App for notification" />
</RelativeLayout>

ステップ3 −次のコードをsrc / MainActivity

に追加します
package app.tutorialspoint.com.notifyme ;
import android.content.Intent ;
import android.os.Bundle ;
import android.support.v7.app.AppCompatActivity ;
import android.view.View ;
public class MainActivity extends AppCompatActivity {
   @Override
   protected void onCreate (Bundle savedInstanceState) {
      super .onCreate(savedInstanceState) ;
      setContentView(R.layout. activity_main ) ;
   }
   @Override
   protected void onStop () {
      super .onStop() ;
      startService( new Intent( this, NotificationService. class )) ;
   }
   public void closeApp (View view) {
      finish() ;
   }
}

ステップ4 −次のコードをsrc / NotificationService

に追加します
package app.tutorialspoint.com.notifyme ;
import android.app.NotificationChannel ;
import android.app.NotificationManager ;
import android.app.Service ;
import android.content.Intent ;
import android.os.Handler ;
import android.os.IBinder ;
import android.support.v4.app.NotificationCompat ;
import android.util.Log ;
import java.util.Timer ;
import java.util.TimerTask ;
public class NotificationService extends Service {
   public static final String NOTIFICATION_CHANNEL_ID = "10001" ;
   private final static String default_notification_channel_id = "default" ;
   Timer timer ;
   TimerTask timerTask ;
   String TAG = "Timers" ;
   int Your_X_SECS = 5 ;
   @Override
   public IBinder onBind (Intent arg0) {
      return null;
   }
   @Override
   public int onStartCommand (Intent intent , int flags , int startId) {
      Log. e ( TAG , "onStartCommand" ) ;
      super .onStartCommand(intent , flags , startId) ;
      startTimer() ;
      return START_STICKY ;
   }
   @Override
   public void onCreate () {
      Log. e ( TAG , "onCreate" ) ;
   }
   @Override
   public void onDestroy () {
      Log. e ( TAG , "onDestroy" ) ;
      stopTimerTask() ;
      super .onDestroy() ;
   }
   //we are going to use a handler to be able to run in our TimerTask
   final Handler handler = new Handler() ;
   public void startTimer () {
      timer = new Timer() ;
      initializeTimerTask() ;
      timer .schedule( timerTask , 5000 , Your_X_SECS * 1000 ) ; //
   }
   public void stopTimerTask () {
      if ( timer != null ) {
         timer .cancel() ;
         timer = null;
      }
   }
   public void initializeTimerTask () {
      timerTask = new TimerTask() {
         public void run () {
            handler .post( new Runnable() {
               public void run () {
                  createNotification() ;
               }
            }) ;
         }
      } ;
   }
   private void createNotification () {
      NotificationManager mNotificationManager = (NotificationManager) getSystemService( NOTIFICATION_SERVICE ) ;
      NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(getApplicationContext() , default_notification_channel_id ) ;
      mBuilder.setContentTitle( "My Notification" ) ;
      mBuilder.setContentText( "Notification Listener Service Example" ) ;
      mBuilder.setTicker( "Notification Listener Service Example" ) ;
      mBuilder.setSmallIcon(R.drawable. ic_launcher_foreground ) ;
      mBuilder.setAutoCancel( true ) ;
      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) ;
         mBuilder.setChannelId( NOTIFICATION_CHANNEL_ID ) ;
         assert mNotificationManager != null;
         mNotificationManager.createNotificationChannel(notificationChannel) ;
      }
      assert mNotificationManager != null;
      mNotificationManager.notify(( int ) System. currentTimeMillis () , mBuilder.build()) ;
   }
}

ステップ5 −次のコードを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>
      <service
         android :name = ".NotificationService"
         android :label = "@string/app_name" >
         <intent-filter>
            <action
               android :name = "app.tutorialspoint.com.notifyme.NotificationService" />
            <category android :name= "android.intent.category.DEFAULT" />
         </intent-filter>
      </service>
   </application>
</manifest>

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


  1. AndroidStudioの初心者向けガイド

    Android Studioは、Androidアプリを開発するためのAndroidの公式統合開発環境(IDE)です。これは、Python開発者に人気のあるPyCharmで使用されているのと同じコードエディターであるIntelliJに基づいて構築されています。 Android Studioを初めて使用する場合は、以下の簡単な手順に従ってIDEに慣れてください。 インストール アプリケーションをダウンロードする前に、公式サイトにアクセスしてください。これを書いている時点で、完全にテストされたバージョン3.3をダウンロードする必要があります。追加機能を備えたより高いバージョンが利用可能ですが、そ

  2. Whatsapp が Android スマートフォンで最高の「自己メモ」アプリである理由

    WhatsAppインスタントメッセージングアプリは、同社が頻繁に新機能を導入しているため、最近ニュースになっています.受信者が画像を 1 回表示した後に画像を自動削除する ViewOnce 機能や、同じ WhatsApp で署名できるデバイスの数を 4 に増やすことは、機能の一部です。しかし今日は、長い間存在していたものの、宣伝されることのなかった隠された機能、つまり WhatsApp で自分とチャットする機能についてお話ししたいと思います。 WhatsAppのライバルアプリであるSignalとTelegramを見てみると、自分とチャットできる「note to self」という特別な機能があ