feat: default-video-quality patch (#95)

This commit is contained in:
Canny1913 2022-07-24 23:28:38 +03:00 committed by GitHub
parent 234023f3f5
commit f3ee6cec26
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 64 additions and 42 deletions

View File

@ -1,6 +1,7 @@
package app.revanced.integrations.patches; package app.revanced.integrations.patches;
import android.content.Context; import android.content.Context;
import android.content.SharedPreferences;
import android.net.ConnectivityManager; import android.net.ConnectivityManager;
import android.net.NetworkInfo; import android.net.NetworkInfo;
@ -9,45 +10,38 @@ import java.lang.reflect.Method;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import app.revanced.integrations.settings.SettingsEnum;
import app.revanced.integrations.utils.LogHelper; 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};
private static Boolean userChangedQuality = false; private static Boolean userChangedQuality = false;
public static int selectedQuality1 = -2;
//ToDo: Write Patch for it. public static void changeDefaultQuality(int defaultQuality) {
//See https://drive.google.com/file/d/1goodaU0JWrO9BAOUn6El-Id1SNuMGHR9/view?usp=sharing for where it needs to be used. Context context = ReVancedUtils.getContext();
public static int setVideoQuality(Object[] qualities, int quality, Object qInterface) { if (isConnectedWifi(context)) {
int preferredQuality; SharedPreferences wifi = context.getSharedPreferences("revanced_prefs", 0);
Field[] fields; SharedPreferences.Editor wifieditor = wifi.edit();
if (!ReVancedUtils.isNewVideoStarted() || userChangedQuality || qInterface == null) { wifieditor.putInt("wifi_quality",defaultQuality);
if (SettingsEnum.DEBUG.getBoolean() && userChangedQuality) { wifieditor.apply();
LogHelper.debug(VideoQualityPatch.class, "Skipping quality change because user changed it: " + quality); LogHelper.debug(VideoQualityPatch.class, "Changing default Wi-Fi quality to: " + defaultQuality);
} else if (isConnectedMobile(context)) {
SharedPreferences mobile = context.getSharedPreferences("revanced_prefs", 0);
SharedPreferences.Editor mobileeditor = mobile.edit();
mobileeditor.putInt("mobile_quality",defaultQuality);
mobileeditor.apply();
LogHelper.debug(VideoQualityPatch.class, "Changing default mobile data quality to: " + defaultQuality);
} else {
LogHelper.debug(VideoQualityPatch.class, "No Internet connection, aborting default quality change.");
} }
userChangedQuality = false; userChangedQuality = false;
return quality;
} }
ReVancedUtils.setNewVideo(false);
LogHelper.debug(VideoQualityPatch.class, "Quality: " + quality); public static int setVideoQuality(Object[] qualities, int quality, Object qInterface, String qIndexMethod) {
Context context = ReVancedUtils.getContext(); int preferredQuality;
if (context == null) { Field[] fields;
LogHelper.printException(VideoQualityPatch.class, "Context is null or settings not initialized, returning quality: " + quality); if (!ReVancedUtils.isNewVideoStarted() && !userChangedQuality || qInterface == null) {
return quality;
}
if (isConnectedWifi(context)) {
preferredQuality = SettingsEnum.PREFERRED_RESOLUTION_WIFI.getInt();
LogHelper.debug(VideoQualityPatch.class, "Wi-Fi connection detected, preferred quality: " + preferredQuality);
} else if (isConnectedMobile(context)) {
preferredQuality = SettingsEnum.PREFERRED_RESOLUTION_MOBILE.getInt();
LogHelper.debug(VideoQualityPatch.class, "Mobile data connection detected, preferred quality: " + preferredQuality);
} else {
LogHelper.debug(VideoQualityPatch.class, "No Internet connection!");
return quality;
}
if (preferredQuality == -2) {
return quality; return quality;
} }
Class<?> intType = Integer.TYPE; Class<?> intType = Integer.TYPE;
@ -55,7 +49,7 @@ public class VideoQualityPatch {
try { try {
for (Object streamQuality : qualities) { for (Object streamQuality : qualities) {
for (Field field : streamQuality.getClass().getFields()) { for (Field field : streamQuality.getClass().getFields()) {
if (field.getType().isAssignableFrom(intType)) { if (field.getType().isAssignableFrom(intType)) { // converts quality index to actual readable resolution
int value = field.getInt(streamQuality); int value = field.getInt(streamQuality);
if (field.getName().length() <= 2) { if (field.getName().length() <= 2) {
iStreamQualities.add(value); iStreamQualities.add(value);
@ -67,6 +61,39 @@ public class VideoQualityPatch {
} }
Collections.sort(iStreamQualities); Collections.sort(iStreamQualities);
int index = 0; int index = 0;
if (userChangedQuality) {
for (int convertedQuality : iStreamQualities) {
int selectedQuality2 = qualities.length - selectedQuality1 + 1;
index++;
if (selectedQuality2 == index) {
LogHelper.debug(VideoQualityPatch.class, "Quality index is: " + index + " and corresponding value is: " + convertedQuality);
changeDefaultQuality(convertedQuality);
return selectedQuality2;
}
}
}
ReVancedUtils.setNewVideo(false);
LogHelper.debug(VideoQualityPatch.class, "Quality: " + quality);
Context context = ReVancedUtils.getContext();
if (context == null) {
LogHelper.printException(VideoQualityPatch.class, "Context is null or settings not initialized, returning quality: " + quality);
return quality;
}
if (isConnectedWifi(context)) {
SharedPreferences wifi = context.getSharedPreferences("revanced_prefs", 0);
preferredQuality = wifi.getInt("wifi_quality", -2);
LogHelper.debug(VideoQualityPatch.class, "Wi-Fi connection detected, preferred quality: " + preferredQuality);
} else if (isConnectedMobile(context)) {
SharedPreferences mobile = context.getSharedPreferences("revanced_prefs", 0);
preferredQuality = mobile.getInt("mobile_quality", -2);
LogHelper.debug(VideoQualityPatch.class, "Mobile data connection detected, preferred quality: " + preferredQuality);
} else {
LogHelper.debug(VideoQualityPatch.class, "No Internet connection!");
return quality;
}
if (preferredQuality == -2) {
return quality;
}
for (int streamQuality2 : iStreamQualities) { for (int streamQuality2 : iStreamQualities) {
LogHelper.debug(VideoQualityPatch.class, "Quality at index " + index + ": " + streamQuality2); LogHelper.debug(VideoQualityPatch.class, "Quality at index " + index + ": " + streamQuality2);
index++; index++;
@ -84,7 +111,8 @@ public class VideoQualityPatch {
LogHelper.debug(VideoQualityPatch.class, "Index of quality " + quality + " is " + qualityIndex); LogHelper.debug(VideoQualityPatch.class, "Index of quality " + quality + " is " + qualityIndex);
try { try {
Class<?> cl = qInterface.getClass(); Class<?> cl = qInterface.getClass();
Method m = cl.getMethod("x", Integer.TYPE); Method m = cl.getMethod(qIndexMethod, Integer.TYPE);
LogHelper.debug(VideoQualityPatch.class, "Method is: " + qIndexMethod);
m.invoke(qInterface, iStreamQualities.get(qualityIndex)); m.invoke(qInterface, iStreamQualities.get(qualityIndex));
LogHelper.debug(VideoQualityPatch.class, "Quality changed to: " + qualityIndex); LogHelper.debug(VideoQualityPatch.class, "Quality changed to: " + qualityIndex);
return qualityIndex; return qualityIndex;
@ -94,8 +122,8 @@ public class VideoQualityPatch {
} }
} }
//See https://drive.google.com/file/d/1_cgCf603XKk4gEbbsmWGtndNt5UJ0np7/view?usp=sharing for usage public static void userChangedQuality(int selectedQuality) {
public static void userChangedQuality() { selectedQuality1 = selectedQuality;
userChangedQuality = true; userChangedQuality = true;
} }

View File

@ -1,12 +1,7 @@
package app.revanced.integrations.utils; package app.revanced.integrations.utils;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context; import android.content.Context;
import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.content.res.Resources; import android.content.res.Resources;
import android.os.Build;
import android.os.Handler; import android.os.Handler;
import android.os.Looper; import android.os.Looper;
@ -17,7 +12,7 @@ import app.revanced.integrations.sponsorblock.player.PlayerType;
public class ReVancedUtils { public class ReVancedUtils {
private static PlayerType env; private static PlayerType env;
private static boolean newVideo = false; public static boolean newVideo = false;
//Used by Integrations patch //Used by Integrations patch
public static Context context; public static Context context;
@ -34,7 +29,6 @@ public class ReVancedUtils {
LogHelper.debug(ReVancedUtils.class, "New video started: " + started); LogHelper.debug(ReVancedUtils.class, "New video started: " + started);
newVideo = started; newVideo = started;
} }
public static boolean isNewVideoStarted() { public static boolean isNewVideoStarted() {
return newVideo; return newVideo;
} }