Skip to content

Commit

Permalink
Merge pull request #894
Browse files Browse the repository at this point in the history
Battery Bar: animate charging
  • Loading branch information
siavash79 authored Sep 29, 2024
2 parents c3991c0 + 201f5b3 commit f71551a
Show file tree
Hide file tree
Showing 5 changed files with 99 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,7 @@ public class StatusbarMods extends XposedModPack {
private static boolean indicateFastCharging = false;
private static boolean indicatePowerSave = false;
private static boolean BBarTransitColors = false;
private static boolean BBAnimateCharging = false;
//endregion

//region privacy chip
Expand Down Expand Up @@ -309,6 +310,7 @@ public void updatePrefs(String... Key) {
BBOpacity = Xprefs.getSliderInt( "BBOpacity", 100);
BBarHeight = Xprefs.getSliderInt( "BBarHeight", 50);
BBarTransitColors = Xprefs.getBoolean("BBarTransitColors", false);
BBAnimateCharging = Xprefs.getBoolean("BBAnimateCharging", false);

batteryLevels = Xprefs.getSliderValues("batteryWarningRange", 0);

Expand Down Expand Up @@ -1120,7 +1122,7 @@ private void setHeights() {

//region battery bar related
private void refreshBatteryBar(BatteryBarView instance) {
BatteryBarView.setStaticColor(batteryLevels, batteryColors, indicateCharging, chargingColor, indicateFastCharging, fastChargingColor, indicatePowerSave, powerSaveColor, BBarTransitColors);
BatteryBarView.setStaticColor(batteryLevels, batteryColors, indicateCharging, chargingColor, indicateFastCharging, fastChargingColor, indicatePowerSave, powerSaveColor, BBarTransitColors, BBAnimateCharging);
instance.setVisibility((BBarEnabled) ? VISIBLE : GONE);
instance.setColorful(BBarColorful);
instance.setOnlyWhileCharging(BBOnlyWhileCharging);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,20 @@

import android.annotation.SuppressLint;
import android.content.Context;
import android.content.res.Resources;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RadialGradient;
import android.graphics.Shader;
import android.graphics.drawable.ShapeDrawable;
import android.graphics.drawable.shapes.RectShape;
import android.os.Handler;
import android.text.TextUtils;
import android.util.DisplayMetrics;
import android.view.Gravity;
import android.view.ViewGroup;
import android.view.animation.LinearInterpolator;
import android.view.animation.TranslateAnimation;
import android.widget.FrameLayout;
import android.widget.ImageView;

Expand All @@ -34,6 +39,7 @@ public class BatteryBarView extends FrameLayout {
private static float[] shadeLevels = new float[0];
private final ShapeDrawable mDrawable = new ShapeDrawable();
FrameLayout maskLayout;
private final ImageView chargingIndicatorView;
private boolean colorful = false;
private int alphaPct = 100;
private int singleColorTone = Color.WHITE;
Expand All @@ -55,8 +61,13 @@ public class BatteryBarView extends FrameLayout {
private static boolean indicateFastCharging = false;
private static boolean indicatePowerSave = false;
private static boolean transitColors = false;
private static boolean animateCharging = false;
private static final int ANIM_DURATION = 1000;
private static final int ANIM_DELAY = 2000;
private final Handler animationHandler = new Handler();
private Runnable chargingAnimationRunnable;

public static void setStaticColor(List<Float> batteryLevels, int[] batteryColors, boolean indicateCharging, int chargingColor, boolean indicateFastCharging, int fastChargingColor, boolean indicatePowerSave, int powerSaveColor, boolean transitColors) {
public static void setStaticColor(List<Float> batteryLevels, int[] batteryColors, boolean indicateCharging, int chargingColor, boolean indicateFastCharging, int fastChargingColor, boolean indicatePowerSave, int powerSaveColor, boolean transitColors, boolean animate) {
BatteryBarView.transitColors = transitColors;
BatteryBarView.batteryLevels = batteryLevels;
BatteryBarView.batteryColors = batteryColors;
Expand All @@ -66,6 +77,7 @@ public static void setStaticColor(List<Float> batteryLevels, int[] batteryColors
BatteryBarView.powerSaveColor = powerSaveColor;
BatteryBarView.indicateCharging = indicateCharging;
BatteryBarView.indicateFastCharging = indicateFastCharging;
BatteryBarView.animateCharging = animate;
}

public void setOnTop(boolean onTop) {
Expand Down Expand Up @@ -93,9 +105,16 @@ public void refreshLayout() {
if (barView.getVisibility() == GONE) return;
maskLayout.setLayoutParams(maskLayoutParams());
barView.setLayoutParams(barLayoutParams());
chargingIndicatorView.setLayoutParams(charginLayoutParams());

refreshColors(barView.getWidth(), barView.getHeight());
mDrawable.invalidateSelf();

if (isCharging() && animateCharging) {
startChargingAnimation();
} else {
stopChargingAnimation();
}
}

private LayoutParams maskLayoutParams() {
Expand All @@ -111,6 +130,52 @@ public void onSizeChanged(int w, int h, int oldw, int oldh) {
refreshLayout();
}

private void startChargingAnimation() {
if (!isCharging() || !animateCharging) {
stopChargingAnimation();
return;
}

if (chargingAnimationRunnable == null) {
chargingAnimationRunnable = new Runnable() {
@Override
public void run() {
animateChargingIndicator();
animationHandler.postDelayed(this, ANIM_DELAY);
}
};
animationHandler.post(chargingAnimationRunnable);
}
}

private void stopChargingAnimation() {
if (chargingAnimationRunnable != null) {
animationHandler.removeCallbacks(chargingAnimationRunnable);
chargingIndicatorView.post(() -> chargingIndicatorView.setVisibility(GONE));
chargingAnimationRunnable = null;
}
}

private void animateChargingIndicator() {
chargingIndicatorView.post(() -> chargingIndicatorView.setVisibility(VISIBLE));
int screenWidth = Resources.getSystem().getDisplayMetrics().widthPixels;
float startX, endX;

if (RTL) {
startX = 0;
endX = getWidth() - Math.round(getWidth() * getCurrentLevel() / 100f);
} else {
startX = screenWidth;
endX = Math.round(getWidth() * getCurrentLevel() / 100f);
}
if (isCenterBased) endX = getWidth() / 2f + chargingIndicatorView.getWidth() / 2f;

TranslateAnimation animation = new TranslateAnimation(startX, endX, 0, 0);
animation.setDuration(ANIM_DURATION);
animation.setInterpolator(new LinearInterpolator());
chargingIndicatorView.startAnimation(animation);
}

public BatteryBarView(Context context) {
super(context);
instance = this;
Expand All @@ -123,12 +188,16 @@ public BatteryBarView(Context context) {
barView = new ImageView(context);
barView.setImageDrawable(mDrawable);

maskLayout = new FrameLayout(context);
chargingIndicatorView = new ImageView(context);
chargingIndicatorView.setLayoutParams(new LayoutParams(20, barHeight));
chargingIndicatorView.setBackgroundColor(singleColorTone);

maskLayout = new FrameLayout(context);
maskLayout.addView(barView);
maskLayout.setClipChildren(true);

this.addView(maskLayout);
this.addView(chargingIndicatorView);
this.setClipChildren(true);

RTL = (TextUtils.getLayoutDirectionFromLocale(Locale.getDefault()) == LAYOUT_DIRECTION_RTL);
Expand All @@ -155,6 +224,19 @@ private LayoutParams barLayoutParams() {
return result;
}

private LayoutParams charginLayoutParams() {
DisplayMetrics metrics = getContext().getResources().getDisplayMetrics();
float dp = 4f;
int pixels = (int) (metrics.density * dp + 0.5f);
LayoutParams result = new LayoutParams(pixels, barHeight);

result.gravity = (RTL) ? Gravity.CENTER : Gravity.START;

result.gravity |= (onTop) ? Gravity.TOP : Gravity.BOTTOM;

return result;
}

public void setBarHeight(int height) {
barHeight = height;
refreshLayout();
Expand All @@ -179,9 +261,11 @@ public void refreshColors(int lenX, int lenY) {
mDrawable.setIntrinsicHeight(lenY);
if (isFastCharging() && indicateFastCharging) //fast charging color
{
chargingIndicatorView.setBackgroundColor(fastChargingColor);
mPaint.setColor(fastChargingColor);
} else if (isCharging() && indicateCharging) //normal charging color
{
chargingIndicatorView.setBackgroundColor(chargingColor);
mPaint.setColor(chargingColor);
} else if (isPowerSaving() && indicatePowerSave) //power saving color
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,7 @@ public static boolean isVisible(String key) {
case "BBOpacity":
case "BBarHeight":
case "BBSetCentered":
case "BBAnimateCharging":
case "indicateCharging":
case "indicateFastCharging":
case "indicatePowerSave":
Expand Down
1 change: 1 addition & 0 deletions app/src/main/res/values/strings.xml
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,7 @@
<string name="BB_Opacity_title">Bar opacity</string>
<string name="BB_center_align_title">Center Aligned</string>
<string name="BB_Thickness_title">Bar thickness</string>
<string name="BB_animate_charging">Animate charging</string>
<string name="BB_indicate_charging">Indicate charging</string>
<string name="BB_indicate_fast_charging">Indicate fast charging</string>
<string name="BB_indicate_power_save">Indicate power save</string>
Expand Down
8 changes: 8 additions & 0 deletions app/src/main/res/xml/statusbar_batterybar_prefs.xml
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,14 @@
android:title="@string/BB_center_align_title"
app:iconSpaceReserved="false" />

<sh.siava.pixelxpert.ui.preferences.MaterialSwitchPreference
android:defaultValue="false"
android:key="BBAnimateCharging"
android:summaryOff="@string/general_off"
android:summaryOn="@string/general_on"
android:title="@string/BB_animate_charging"
app:iconSpaceReserved="false" />

<sh.siava.pixelxpert.ui.preferences.MaterialSwitchPreference
android:defaultValue="false"
android:key="indicateCharging"
Expand Down

0 comments on commit f71551a

Please sign in to comment.