Update strings for charging optimization mode.
Update the battery settings summary and the charging string on the Battery settings page if charging optimization mode is applied. Bug: 329020954 Test: atest SettingsRoboTests Change-Id: Ie906a010d70bcef7fafe235f0287b289ea934705
This commit is contained in:
@@ -78,6 +78,21 @@ public class BatteryHeaderPreferenceController extends BasePreferenceController
|
||||
}
|
||||
|
||||
private CharSequence generateLabel(BatteryInfo info) {
|
||||
if (Utils.containsIncompatibleChargers(mContext, TAG)) {
|
||||
return mContext.getString(
|
||||
com.android.settingslib.R.string.battery_info_status_not_charging);
|
||||
}
|
||||
if (BatteryUtils.isBatteryDefenderOn(info)) {
|
||||
return mContext.getString(
|
||||
com.android.settingslib.R.string.battery_info_status_charging_on_hold);
|
||||
}
|
||||
if (info.remainingLabel == null
|
||||
|| info.batteryStatus == BatteryManager.BATTERY_STATUS_NOT_CHARGING) {
|
||||
return info.statusLabel;
|
||||
}
|
||||
if (mBatterySettingsFeatureProvider.isChargingOptimizationMode(mContext)) {
|
||||
return info.remainingLabel;
|
||||
}
|
||||
if (info.pluggedStatus == BatteryManager.BATTERY_PLUGGED_WIRELESS) {
|
||||
final CharSequence wirelessChargingLabel =
|
||||
mBatterySettingsFeatureProvider.getWirelessChargingLabel(mContext, info);
|
||||
@@ -85,18 +100,7 @@ public class BatteryHeaderPreferenceController extends BasePreferenceController
|
||||
return wirelessChargingLabel;
|
||||
}
|
||||
}
|
||||
|
||||
if (Utils.containsIncompatibleChargers(mContext, TAG)) {
|
||||
return mContext.getString(
|
||||
com.android.settingslib.R.string.battery_info_status_not_charging);
|
||||
} else if (BatteryUtils.isBatteryDefenderOn(info)) {
|
||||
return mContext.getString(
|
||||
com.android.settingslib.R.string.battery_info_status_charging_on_hold);
|
||||
} else if (info.remainingLabel == null
|
||||
|| info.batteryStatus == BatteryManager.BATTERY_STATUS_NOT_CHARGING) {
|
||||
// Present status only if no remaining time or status anomalous
|
||||
return info.statusLabel;
|
||||
} else if (info.statusLabel != null && !info.discharging) {
|
||||
if (info.statusLabel != null && !info.discharging) {
|
||||
// Charging state
|
||||
if (com.android.settingslib.fuelgauge.BatteryUtils.isChargingStringV2Enabled()) {
|
||||
return info.isFastCharging
|
||||
|
||||
@@ -319,6 +319,12 @@ public class BatteryInfo {
|
||||
info.isFastCharging =
|
||||
BatteryStatus.getChargingSpeed(context, batteryBroadcast)
|
||||
== BatteryStatus.CHARGING_FAST;
|
||||
if (info.isBatteryDefender) {
|
||||
info.isBatteryDefender =
|
||||
FeatureFactory.getFeatureFactory()
|
||||
.getPowerUsageFeatureProvider()
|
||||
.isBatteryDefend(info);
|
||||
}
|
||||
if (!info.mCharging) {
|
||||
updateBatteryInfoDischarging(context, shortString, estimate, info);
|
||||
} else {
|
||||
@@ -388,9 +394,10 @@ public class BatteryInfo {
|
||||
&& status != BatteryManager.BATTERY_STATUS_FULL
|
||||
&& dockDefenderMode == BatteryUtils.DockDefenderMode.DISABLED)
|
||||
|| dockDefenderMode == BatteryUtils.DockDefenderMode.TEMPORARILY_BYPASSED) {
|
||||
final BatterySettingsFeatureProvider featureProvider =
|
||||
FeatureFactory.getFeatureFactory().getBatterySettingsFeatureProvider();
|
||||
// Battery is charging to full
|
||||
info.remainingTimeUs = PowerUtil.convertMsToUs(chargeTimeMs);
|
||||
|
||||
int resId = getChargingDurationResId(info.isFastCharging);
|
||||
info.remainingLabel =
|
||||
chargeTimeMs <= 0
|
||||
@@ -400,7 +407,8 @@ public class BatteryInfo {
|
||||
chargeTimeMs,
|
||||
info.isFastCharging,
|
||||
info.pluggedStatus,
|
||||
currentTimeMs);
|
||||
currentTimeMs,
|
||||
featureProvider);
|
||||
|
||||
info.chargeLabel =
|
||||
chargeTimeMs <= 0
|
||||
@@ -411,7 +419,8 @@ public class BatteryInfo {
|
||||
info.batteryPercentString,
|
||||
chargeTimeMs,
|
||||
info.isFastCharging,
|
||||
currentTimeMs);
|
||||
currentTimeMs,
|
||||
featureProvider);
|
||||
} else if (dockDefenderMode == BatteryUtils.DockDefenderMode.FUTURE_BYPASS) {
|
||||
// Dock defender will be triggered in the future, charging will be optimized.
|
||||
info.chargeLabel =
|
||||
@@ -436,10 +445,17 @@ public class BatteryInfo {
|
||||
long chargeRemainingTimeMs,
|
||||
boolean isFastCharging,
|
||||
int pluggedStatus,
|
||||
long currentTimeMs) {
|
||||
long currentTimeMs,
|
||||
BatterySettingsFeatureProvider featureProvider) {
|
||||
if (featureProvider.isChargingOptimizationMode(context)) {
|
||||
final CharSequence chargingOptimizationRemainingLabel =
|
||||
featureProvider.getChargingOptimizationRemainingLabel(
|
||||
context, chargeRemainingTimeMs, currentTimeMs);
|
||||
if (chargingOptimizationRemainingLabel != null) {
|
||||
return chargingOptimizationRemainingLabel;
|
||||
}
|
||||
}
|
||||
if (pluggedStatus == BatteryManager.BATTERY_PLUGGED_WIRELESS) {
|
||||
BatterySettingsFeatureProvider featureProvider =
|
||||
FeatureFactory.getFeatureFactory().getBatterySettingsFeatureProvider();
|
||||
final CharSequence wirelessChargingRemainingLabel =
|
||||
featureProvider.getWirelessChargingRemainingLabel(
|
||||
context, chargeRemainingTimeMs, currentTimeMs);
|
||||
@@ -472,7 +488,16 @@ public class BatteryInfo {
|
||||
String batteryPercentString,
|
||||
long chargeTimeMs,
|
||||
boolean isFastCharging,
|
||||
long currentTimeMs) {
|
||||
long currentTimeMs,
|
||||
BatterySettingsFeatureProvider featureProvider) {
|
||||
if (featureProvider.isChargingOptimizationMode(context)) {
|
||||
final CharSequence chargingOptimizationChargeLabel =
|
||||
featureProvider.getChargingOptimizationChargeLabel(
|
||||
context, batteryPercentString, chargeTimeMs, currentTimeMs);
|
||||
if (chargingOptimizationChargeLabel != null) {
|
||||
return chargingOptimizationChargeLabel;
|
||||
}
|
||||
}
|
||||
if (com.android.settingslib.fuelgauge.BatteryUtils.isChargingStringV2Enabled()) {
|
||||
var timeString =
|
||||
PowerUtil.getTargetTimeShortString(context, chargeTimeMs, currentTimeMs);
|
||||
|
||||
@@ -53,4 +53,20 @@ public interface BatterySettingsFeatureProvider {
|
||||
@Nullable
|
||||
CharSequence getWirelessChargingRemainingLabel(
|
||||
@NonNull Context context, long remainingTimeMs, long currentTimeMs);
|
||||
|
||||
/** Return true if it's in the charging optimization mode. */
|
||||
boolean isChargingOptimizationMode(@NonNull Context context);
|
||||
|
||||
/** Return a charging remaining time label for charging optimization mode. */
|
||||
@Nullable
|
||||
CharSequence getChargingOptimizationRemainingLabel(
|
||||
@NonNull Context context, long chargeRemainingTimeMs, long currentTimeMs);
|
||||
|
||||
/** Return a charge label for charging optimization mode. */
|
||||
@Nullable
|
||||
CharSequence getChargingOptimizationChargeLabel(
|
||||
@NonNull Context context,
|
||||
@NonNull String batteryPercentageString,
|
||||
long chargeRemainingTimeMs,
|
||||
long currentTimeMs);
|
||||
}
|
||||
|
||||
@@ -67,4 +67,26 @@ public class BatterySettingsFeatureProviderImpl implements BatterySettingsFeatur
|
||||
@NonNull Context context, long remainingTimeMs, long currentTimeMs) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isChargingOptimizationMode(@NonNull Context context) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Nullable
|
||||
@Override
|
||||
public CharSequence getChargingOptimizationRemainingLabel(
|
||||
@NonNull Context context, long chargeRemainingTimeMs, long currentTimeMs) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Nullable
|
||||
@Override
|
||||
public CharSequence getChargingOptimizationChargeLabel(
|
||||
@NonNull Context context,
|
||||
@NonNull String batteryPercentageString,
|
||||
long chargeRemainingTimeMs,
|
||||
long currentTimeMs) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user