Skip to content

Most visited

Recently visited

navigation

バッテリー レベルと充電状態を監視する

バッテリー寿命への影響を抑えるためにバックグラウンド アップデートの頻度を変更する場合は、初めに現在のバッテリー レベルと充電状態をチェックすることをお勧めします。

アプリケーション アップデートの実行がバッテリー寿命に及ぼす影響は、端末のバッテリー レベルと充電状態によって異なります。 端末が AC 充電しているときにアップデートを実行することの影響はわずかであるため、ほとんどの場合、端末がウォール チャージャーに接続されているときはリフレッシュ レートを最大にすることができます。 逆に、端末が電池を使用しているときは、アップデート レートを下げるとバッテリー寿命を延ばすのに役立ちます。

同様に、バッテリー充電レベルをチェックして、バッテリーの充電がなくなりかけているときはアップデートの頻度を下げる(さらには停止する)ことができます。

現在の充電状態を特定する

初めに現在の充電状態を特定します。BatteryManager によってバッテリーと充電のすべての詳細がスティッキー Intent でブロードキャストされ、これには充電状態が含まれています。

これはスティッキー インテントであるため、BroadcastReceiver を登録する必要はありません。次のスニペットに示すように、registerReceiver を呼び出し、null をレシーバーとして渡すだけで、現在のバッテリー ステータス インテントが返されます。 ここで実際の BroadcastReceiver オブジェクトを渡すこともできますが、アップデートは後述のセクションで処理するため、これは必要ありません。

IntentFilter ifilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
Intent batteryStatus = context.registerReceiver(null, ifilter);

現在の充電状態と、端末が充電中の場合は USB 経由で充電しているか AC チャージャー経由で充電しているかを抽出できます。

// Are we charging / charged?
int status = batteryStatus.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
boolean isCharging = status == BatteryManager.BATTERY_STATUS_CHARGING ||
                     status == BatteryManager.BATTERY_STATUS_FULL;

// How are we charging?
int chargePlug = batteryStatus.getIntExtra(BatteryManager.EXTRA_PLUGGED, -1);
boolean usbCharge = chargePlug == BatteryManager.BATTERY_PLUGGED_USB;
boolean acCharge = chargePlug == BatteryManager.BATTERY_PLUGGED_AC;

一般的に、端末が AC チャージャーに接続されている場合はバックグラウンド アップデートのレートを最大にし、充電が USB 経由の場合はレートを下げ、バッテリーが使用されている場合はさらに下げます。

充電状態の変化を監視する

充電状態は端末を電源に接続するのと同じくらい簡単に変化するため、充電状態の変化を監視し、それに応じてリフレッシュ レートを変更することが重要です。

端末が電源に接続されるか切断されると、BatteryManager によってアクションがブロードキャストされます。 これらのイベントをアプリが実行されていないときでも受信することが重要です(特に、これらのイベントが、バックグラウンド アップデートを開始するためにアプリを起動する頻度に影響する場合)。したがって、BroadcastReceiver をマニフェストで登録し、ACTION_POWER_CONNECTEDACTION_POWER_DISCONNECTED をインテント フィルタ内で定義することで両方のイベントをリッスンする必要があります。

<receiver android:name=".PowerConnectionReceiver">
  <intent-filter>
    <action android:name="android.intent.action.ACTION_POWER_CONNECTED"/>
    <action android:name="android.intent.action.ACTION_POWER_DISCONNECTED"/>
  </intent-filter>
</receiver>

関連付けられた BroadcastReceiver 実装内で、前のステップで説明したように現在の充電状態および方法を抽出できます。

public class PowerConnectionReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        int status = intent.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
        boolean isCharging = status == BatteryManager.BATTERY_STATUS_CHARGING ||
                            status == BatteryManager.BATTERY_STATUS_FULL;

        int chargePlug = intent.getIntExtra(BatteryManager.EXTRA_PLUGGED, -1);
        boolean usbCharge = chargePlug == BatteryManager.BATTERY_PLUGGED_USB;
        boolean acCharge = chargePlug == BatteryManager.BATTERY_PLUGGED_AC;
    }
}

現在のバッテリー レベルを特定する

現在のバッテリー レベルを特定すると役に立つ場合もあります。バッテリーの充電が一定のレベルを下回った場合にバックグラウンド アップデートのレートを下げることができます。

現在のバッテリーの充電を調べるには、次に示すように、現在のバッテリー レベルと段階をバッテリー ステータス インテントから抽出します。

int level = batteryStatus.getIntExtra(BatteryManager.EXTRA_LEVEL, -1);
int scale = batteryStatus.getIntExtra(BatteryManager.EXTRA_SCALE, -1);

float batteryPct = level / (float)scale;

バッテリー レベルの大きな変化を監視する

バッテリーの状態を継続的に監視することは簡単ではありませんが、その必要はありません。

一般的に、バッテリー レベルを絶えず監視することのバッテリーへの影響はアプリの通常の動作よりも大きいため、バッテリー レベルの大きな変化のみを監視することをお勧めします。特に、端末がバッテリー残量の低下状態になったときやその状態が解消されたときです。

次に示すマニフェストのスニペットは、ブロードキャスト レシーバー内のインテント フィルタ要素から抽出されたものです。 レシーバーは、ACTION_BATTERY_LOWACTION_BATTERY_OKAY をリッスンすることで、端末のバッテリーが低下するか低下状態が解消されたときに呼び出されます。

<receiver android:name=".BatteryLevelReceiver">
<intent-filter>
  <action android:name="android.intent.action.ACTION_BATTERY_LOW"/>
  <action android:name="android.intent.action.ACTION_BATTERY_OKAY"/>
  </intent-filter>
</receiver>

一般的に、バッテリーが非常に低下してるときは、バックグラウンド アップデートをすべて無効にすることをお勧めします。 携帯端末の電源が切れて使用できなくなるような場合に、データの新しさは関係ありません。

多くの場合、端末の充電動作は端末をホルダーに置くのと同時に行われます。次のレッスンでは、現在のホルダー状態を特定し、端末の装着の変化を監視する方法について説明します。

This site uses cookies to store your preferences for site-specific language and display options.

Get the latest Android developer news and tips that will help you find success on Google Play.

* Required Fields

Hooray!

WeChat で Google Developers をフォローする

Browse this site in ?

You requested a page in , but your language preference for this site is .

Would you like to change your language preference and browse this site in ? If you want to change your language preference later, use the language menu at the bottom of each page.

This class requires API level or higher

This doc is hidden because your selected API level for the documentation is . You can change the documentation API level with the selector above the left navigation.

For more information about specifying the API level your app requires, read Supporting Different Platform Versions.

Take a short survey?
Help us improve the Android developer experience. (Dec 2017 Android Platform & Tools Survey)