【大前端】【Android】获取手机的电池电量、充电状态

✅ 一、可获取的信息

通过 Android 的电池广播,你可以拿到:

信息 说明
当前电量 level 当前电量百分比
电量最大值 scale 一般 100
是否在充电 AC / USB / 无线充电
充电开始 / 充电结束 通过广播监听
电池健康状态 good、overheat 等
电池温度 部分机型支持

✅ 二、获取当前电量(无需注册广播)

Android 推荐方式:

复制代码
val batteryManager = context.getSystemService(Context.BATTERY_SERVICE) as BatteryManager
val batteryLevel = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CAPACITY)

batteryLevel 即为 0--100 的电量百分比

兼容 Android 5--16。


✅ 三、监听开始充电 / 结束充电(广播方式)

Android 使用以下广播:

ACTION_BATTERY_CHANGED(粘性广播,不需要手动注册)

ACTION_POWER_CONNECTED ------ 插上电源(开始充电)

ACTION_POWER_DISCONNECTED ------ 拔掉电源(停止充电)


🔥 四、实际可用代码(Kotlin)

1. 监听充电状态的 BroadcastReceiver

复制代码
class BatteryReceiver(private val callback: (BatteryEvent) -> Unit) : BroadcastReceiver() {

    override fun onReceive(context: Context, intent: Intent) {

        when (intent.action) {

            Intent.ACTION_POWER_CONNECTED -> {
                callback(BatteryEvent.ChargeStart)
            }

            Intent.ACTION_POWER_DISCONNECTED -> {
                callback(BatteryEvent.ChargeStop)
            }

            Intent.ACTION_BATTERY_CHANGED -> {
                val level = intent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1)
                val scale = intent.getIntExtra(BatteryManager.EXTRA_SCALE, 100)
                val status = intent.getIntExtra(BatteryManager.EXTRA_STATUS, -1)

                val isCharging = status == BatteryManager.BATTERY_STATUS_CHARGING ||
                                 status == BatteryManager.BATTERY_STATUS_FULL

                val percent = level * 100 / scale

                callback(BatteryEvent.BatteryInfo(percent, isCharging))
            }
        }
    }
}

sealed class BatteryEvent {
    data object ChargeStart : BatteryEvent()
    data object ChargeStop : BatteryEvent()
    data class BatteryInfo(val level: Int, val isCharging: Boolean) : BatteryEvent()
}

2. 在 Activity / Service 中注册

复制代码
val receiver = BatteryReceiver { event ->
    when (event) {
        is BatteryEvent.ChargeStart -> Log.d("Battery", "开始充电")
        is BatteryEvent.ChargeStop -> Log.d("Battery", "停止充电")
        is BatteryEvent.BatteryInfo -> Log.d("Battery", "电量=${event.level}%, 是否充电=${event.isCharging}")
    }
}

val filter = IntentFilter().apply {
    addAction(Intent.ACTION_BATTERY_CHANGED)
    addAction(Intent.ACTION_POWER_CONNECTED)
    addAction(Intent.ACTION_POWER_DISCONNECTED)
}

registerReceiver(receiver, filter)

🔥 五、Java 写法

复制代码
public class BatteryReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {

        String action = intent.getAction();

        if (Intent.ACTION_POWER_CONNECTED.equals(action)) {
            Log.d("Battery", "开始充电");
        } else if (Intent.ACTION_POWER_DISCONNECTED.equals(action)) {
            Log.d("Battery", "停止充电");
        } else if (Intent.ACTION_BATTERY_CHANGED.equals(action)) {

            int level = intent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1);
            int scale = intent.getIntExtra(BatteryManager.EXTRA_SCALE, 100);
            int status = intent.getIntExtra(BatteryManager.EXTRA_STATUS, -1);

            boolean isCharging = status == BatteryManager.BATTERY_STATUS_CHARGING ||
                                 status == BatteryManager.BATTERY_STATUS_FULL;

            int percent = level * 100 / scale;

            Log.d("Battery", "电量=" + percent + "% 是否充电=" + isCharging);
        }
    }
}

注册:

复制代码
IntentFilter filter = new IntentFilter();
filter.addAction(Intent.ACTION_BATTERY_CHANGED);
filter.addAction(Intent.ACTION_POWER_CONNECTED);
filter.addAction(Intent.ACTION_POWER_DISCONNECTED);

registerReceiver(new BatteryReceiver(), filter);

🟦 六、注意事项

✔ 无需权限

获取电量/充电状态 不需要任何危险权限

✔ ACTION_BATTERY_CHANGED 是粘性广播

不需要手动发送,一调用 registerReceiver() 就能拿到当前电量。

✔ Android 10--16 完全兼容

这些电池广播没有废弃,可直接用。


⭐ 七、如果你需要"首次进入页面就知道状态"

可以用:

复制代码
val intent = Context.registerReceiver(null, IntentFilter(Intent.ACTION_BATTERY_CHANGED))

即可直接拿:

复制代码
val level = intent?.getIntExtra(BatteryManager.EXTRA_LEVEL, -1)
val status = intent?.getIntExtra(BatteryManager.EXTRA_STATUS, -1)
相关推荐
草莓熊Lotso33 分钟前
Linux 文件描述符与重定向实战:从原理到 minishell 实现
android·linux·运维·服务器·数据库·c++·人工智能
恋猫de小郭39 分钟前
Flutter Zero 是什么?它的出现有什么意义?为什么你需要了解下?
android·前端·flutter
工程师老罗7 小时前
如何在Android工程中配置NDK版本
android
Libraeking10 小时前
破壁行动:在旧项目中丝滑嵌入 Compose(混合开发实战)
android·经验分享·android jetpack
市场部需要一个软件开发岗位11 小时前
JAVA开发常见安全问题:Cookie 中明文存储用户名、密码
android·java·安全
JMchen12313 小时前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
crmscs13 小时前
剪映永久解锁版/电脑版永久会员VIP/安卓SVIP手机永久版下载
android·智能手机·电脑
localbob13 小时前
杀戮尖塔 v6 MOD整合版(Slay the Spire)安卓+PC端免安装中文版分享 卡牌肉鸽神作!杀戮尖塔中文版,电脑和手机都能玩!杀戮尖塔.exe 杀戮尖塔.apk
android·杀戮尖塔apk·杀戮尖塔exe·游戏分享
机建狂魔13 小时前
手机秒变电影机:Blackmagic Camera + LUT滤镜包的专业级视频解决方案
android·拍照·摄影·lut滤镜·拍摄·摄像·录像
hudawei99613 小时前
flutter和Android动画的对比
android·flutter·动画