fix: default-video-quality patch crashing (#100)

This commit is contained in:
Canny1913 2022-07-26 20:32:53 +03:00 committed by GitHub
parent 17a291f430
commit c6b7528eae
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -14,22 +14,23 @@ import app.revanced.integrations.utils.LogHelper;
import app.revanced.integrations.utils.ReVancedUtils; import app.revanced.integrations.utils.ReVancedUtils;
public class VideoQualityPatch { public class VideoQualityPatch {
public static final int[] videoResolutions = {0, 144, 240, 360, 480, 720, 1080, 1440, 2160}; public static final int[] videoResolutions = {0, 144, 240, 360, 480, 720, 1080, 1440, 2160, 4320};
private static Boolean userChangedQuality = false;
public static int selectedQuality1 = -2; public static int selectedQuality1 = -2;
private static Boolean newVideo = false;
private static Boolean userChangedQuality = false;
public static void changeDefaultQuality(int defaultQuality) { public static void changeDefaultQuality(int defaultQuality) {
Context context = ReVancedUtils.getContext(); Context context = ReVancedUtils.getContext();
if (isConnectedWifi(context)) { if (isConnectedWifi(context)) {
SharedPreferences wifi = context.getSharedPreferences("revanced_prefs", 0); SharedPreferences wifi = context.getSharedPreferences("revanced_prefs", 0);
SharedPreferences.Editor wifieditor = wifi.edit(); SharedPreferences.Editor wifieditor = wifi.edit();
wifieditor.putInt("wifi_quality",defaultQuality); wifieditor.putInt("wifi_quality", defaultQuality);
wifieditor.apply(); wifieditor.apply();
LogHelper.debug(VideoQualityPatch.class, "Changing default Wi-Fi quality to: " + defaultQuality); LogHelper.debug(VideoQualityPatch.class, "Changing default Wi-Fi quality to: " + defaultQuality);
} else if (isConnectedMobile(context)) { } else if (isConnectedMobile(context)) {
SharedPreferences mobile = context.getSharedPreferences("revanced_prefs", 0); SharedPreferences mobile = context.getSharedPreferences("revanced_prefs", 0);
SharedPreferences.Editor mobileeditor = mobile.edit(); SharedPreferences.Editor mobileeditor = mobile.edit();
mobileeditor.putInt("mobile_quality",defaultQuality); mobileeditor.putInt("mobile_quality", defaultQuality);
mobileeditor.apply(); mobileeditor.apply();
LogHelper.debug(VideoQualityPatch.class, "Changing default mobile data quality to: " + defaultQuality); LogHelper.debug(VideoQualityPatch.class, "Changing default mobile data quality to: " + defaultQuality);
} else { } else {
@ -41,7 +42,7 @@ public class VideoQualityPatch {
public static int setVideoQuality(Object[] qualities, int quality, Object qInterface, String qIndexMethod) { public static int setVideoQuality(Object[] qualities, int quality, Object qInterface, String qIndexMethod) {
int preferredQuality; int preferredQuality;
Field[] fields; Field[] fields;
if (!ReVancedUtils.isNewVideoStarted() && !userChangedQuality || qInterface == null) { if (!(newVideo || userChangedQuality) || qInterface == null) {
return quality; return quality;
} }
Class<?> intType = Integer.TYPE; Class<?> intType = Integer.TYPE;
@ -72,7 +73,7 @@ public class VideoQualityPatch {
} }
} }
} }
ReVancedUtils.setNewVideo(false); newVideo = false;
LogHelper.debug(VideoQualityPatch.class, "Quality: " + quality); LogHelper.debug(VideoQualityPatch.class, "Quality: " + quality);
Context context = ReVancedUtils.getContext(); Context context = ReVancedUtils.getContext();
if (context == null) { if (context == null) {
@ -127,6 +128,9 @@ public class VideoQualityPatch {
userChangedQuality = true; userChangedQuality = true;
} }
public static void newVideoStarted(String videoId) {
newVideo = true;
}
private static NetworkInfo getNetworkInfo(Context context) { private static NetworkInfo getNetworkInfo(Context context) {
ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);