Android BroadcastReceiverの例のチュートリアル
今日は、Androidフレームワークの非常に重要なコンポーネントであるAndroid BroadcastReceiverの話し合いと実装について取り上げます。
アンドロイドのブロードキャストレシーバー
AndroidのBroadcastReceiverは、システム全体のブロードキャストイベントやインテントを受け取るAndroidの非アクティブコンポーネントです。これらのイベントが発生すると、ステータスバーに通知を作成したり、タスクを実行したりすることによって、アプリケーションをアクティブにします。アクティビティとは異なり、AndroidのBroadcastReceiverにはユーザーインターフェースは含まれていません。ブロードキャストレシーバは、受信されたインテントデータのタイプに応じて、タスクをサービスに委任するために一般的に実装されます。以下に、重要なシステム全体の生成インテントのいくつかを示します。
-
- android.intent.action.BATTERY_LOW:デバイスのバッテリーが低い状態を示します。
-
- android.intent.action.BOOT_COMPLETED:システムの起動が完了した後、一度放送されます。
-
- android.intent.action.CALL:データで指定された相手に通話を行うために使用します。
-
- android.intent.action.DATE_CHANGED:日付が変更されました。
-
- android.intent.action.REBOOT:デバイスを再起動させます。
- android.net.conn.CONNECTIVITY_CHANGE:モバイルネットワークまたはWi-Fi接続が変更された(またはリセットされた)ことを示します。
Androidにおけるブロードキャストレシーバー
Androidアプリケーションでブロードキャストレシーバをセットアップするには、次の2つのことを行う必要があります。
-
- ブロードキャストレシーバを作成する
- ブロードキャストレシーバを登録する
ブロードキャストレシーバーの作成
以下のように、カスタムのBroadcastReceiverを迅速に実装しましょう。
public class MyReceiver extends BroadcastReceiver {
public MyReceiver() {
}
@Override
public void onReceive(Context context, Intent intent) {
Toast.makeText(context, "Action: " + intent.getAction(), Toast.LENGTH_SHORT).show();
}
}
ブロードキャストレシーバーは、onReceiver()メソッドを持つ抽象クラスです。onReceiver()メソッドは、イベントが発生したときに登録されたブロードキャストレシーバーに最初に呼び出されます。インテントオブジェクトは、すべての追加データと共に渡されます。また、Contextオブジェクトも利用可能であり、context.startActivity(myIntent);またはcontext.startService(myService);を使用してアクティビティやサービスを起動するために使用されます。
AndroidアプリでのBroadcastReceiverの登録を行う
ブロードキャストレシーバーは2つの方法で登録できます。
- 以下のようにAndroidManifest.xmlファイルで定義することによって。
<receiver android:name=".ConnectionReceiver" >
<intent-filter>
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</intent-filter>
</receiver>
意図フィルターを使用することで、システムに、サブエレメントに一致する意図は特定のブロードキャストレシーバーに配信されるべきであると伝えます。3. プログラムで定義することにより、ブロードキャストレシーバーを登録するサンプル例が次のスニペットに示されています。
IntentFilter filter = new IntentFilter();
intentFilter.addAction(getPackageName() + "android.net.conn.CONNECTIVITY_CHANGE");
MyReceiver myReceiver = new MyReceiver();
registerReceiver(myReceiver, filter);
アクティビティのonStop()やonPause()メソッド内でブロードキャストレシーバーの登録を解除するには、以下のスニペットを使用することができます。
@Override
protected void onPause() {
unregisterReceiver(myReceiver);
super.onPause();
}
アクティビティからブロードキャストインテントを送信する。
関連するすべてのBroadcastReceiverにインテントを送信するために、以下のスニペットが使用されます。
Intent intent = new Intent();
intent.setAction("com.scdev.CUSTOM_INTENT");
sendBroadcast(intent);
マニフェストまたはプログラム上のインテントフィルタータグに上記のアクションを追加することを忘れないでください。ネットワーク変更イベントやカスタムインテントを聞き取るアプリケーションを開発しましょう。そして、データを適切に処理します。
Androidプロジェクト構造内のBroadcastReceiver
アンドロイドのブロードキャストレシーバーコード
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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.scdev.broadcastreceiver.MainActivity">
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/button"
android:text="Send Broadcast"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true" />
</RelativeLayout>
下記はMainActivity.javaです。
package com.scdev.broadcastreceiver;
import android.content.Intent;
import android.content.IntentFilter;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import butterknife.ButterKnife;
import butterknife.InjectView;
import butterknife.OnClick;
public class MainActivity extends AppCompatActivity {
ConnectionReceiver receiver;
IntentFilter intentFilter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ButterKnife.inject(this);
receiver = new ConnectionReceiver();
intentFilter = new IntentFilter("com.scdev.broadcastreceiver.SOME_ACTION");
}
@Override
protected void onResume() {
super.onResume();
registerReceiver(receiver, intentFilter);
}
@Override
protected void onDestroy() {
super.onDestroy();
unregisterReceiver(receiver);
}
@OnClick(R.id.button)
void someMethod() {
Intent intent = new Intent("com.scdev.broadcastreceiver.SOME_ACTION");
sendBroadcast(intent);
}
}
上記のコードでは、別のカスタムアクションをプログラムで登録しました。ConnectionReceiverは、以下のようにAndroidManifest.xmlファイルで定義されています。
<?xml version="1.0" encoding="utf-8"?>
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="https://schemas.android.com/apk/res/android"
package="com.scdev.broadcastreceiver">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
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=".ConnectionReceiver">
<intent-filter>
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</intent-filter>
</receiver>
</application>
</manifest>
以下には、ConnectionReceiver.javaクラスが定義されています。
public class ConnectionReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Log.d("API123",""+intent.getAction());
if(intent.getAction().equals("com.scdev.broadcastreceiver.SOME_ACTION"))
Toast.makeText(context, "SOME_ACTION is received", Toast.LENGTH_LONG).show();
else {
ConnectivityManager cm =
(ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo activeNetwork = cm.getActiveNetworkInfo();
boolean isConnected = activeNetwork != null &&
activeNetwork.isConnectedOrConnecting();
if (isConnected) {
try {
Toast.makeText(context, "Network is connected", Toast.LENGTH_LONG).show();
} catch (Exception e) {
e.printStackTrace();
}
} else {
Toast.makeText(context, "Network is changed or reconnected", Toast.LENGTH_LONG).show();
}
}
}
}
Androidブロードキャストレシーバープロジェクトをダウンロードする。