アプリが閉じられたときに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つを開き、ツールバーの[実行]アイコンをクリックします。オプションとしてモバイルデバイスを選択し、デフォルトの画面を表示するモバイルデバイスを確認します-
-
Androidで写真を撮るときに通知をブロックする方法
強力なスマートフォンカメラが手に入れたので、写真を撮るのはとても簡単です。ただし、写真を撮ろうとしているときなど、通知が間違ったタイミングで表示される可能性があります。 ほぼすべてのアプリがあるので、完璧な写真を撮っているときに通知が邪魔にならないようにするアプリもあります。これは無料のアプリであり、使いやすいです。 カメラアプリ使用時に通知をブロックする方法 最終的にすべての友達を同じ場所に集めて写真を撮るときは非常に煩わしいことがあります。写真を撮ろうとすると、通知が邪魔になります。確かに、通知をスワイプするのに1秒しかかかりませんが、完璧な写真を撮るのを逃すのに必要なのはそれだけの場
-
Windows 10 で Android 通知を取得する方法
Android は、世界で最も使用されているオペレーティング システムの 1 つであり、多数のユーザーを抱えています。 Android を搭載したスマートフォンの性能が向上したため、Windows 10 で Android の通知を受け取ることができるようになりました。これにより、仕事中や携帯電話が遠くにある場合でも、確認するために取りに行く必要がなくなります。 Windows 10 での通知の取得は組み込み機能の 1 つであるため、微調整が必要な設定がいくつかあります。設定を理解する前に、正規の Windows 10 と必要な更新プログラムを使用していることが重要です。 Window