diff --git a/CHANGELOG.md b/CHANGELOG.md
index fc3c125cce..2c17982849 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,79 @@
+# [5.3.0-dev.7](https://github.com/ReVanced/revanced-patches/compare/v5.3.0-dev.6...v5.3.0-dev.7) (2024-12-09)
+
+
+### Bug Fixes
+
+* **YouTube - Spoof video streams:** Add missing preferred language preference to the settings ([630633c](https://github.com/ReVanced/revanced-patches/commit/630633cf57c65c65e5578046413e17670ae336e8))
+
+# [5.3.0-dev.6](https://github.com/ReVanced/revanced-patches/compare/v5.3.0-dev.5...v5.3.0-dev.6) (2024-12-09)
+
+
+### Features
+
+* **YouTube - Spoof video streams:** Allow picking a default audio language track ([#4050](https://github.com/ReVanced/revanced-patches/issues/4050)) ([ede666b](https://github.com/ReVanced/revanced-patches/commit/ede666b5cb64fcbaa1334ad8bef79e2634ced113))
+
+# [5.3.0-dev.5](https://github.com/ReVanced/revanced-patches/compare/v5.3.0-dev.4...v5.3.0-dev.5) (2024-12-09)
+
+
+### Bug Fixes
+
+* **Change package name:** Prevent applying the patch to known incompatible apps ([#3943](https://github.com/ReVanced/revanced-patches/issues/3943)) ([44936e7](https://github.com/ReVanced/revanced-patches/commit/44936e71e846f72f7279950232a5dba37765ceb3))
+* **YouTube Music - Permanent shuffle:** Remove obsolete and non functional patch ([#4073](https://github.com/ReVanced/revanced-patches/issues/4073)) ([fbc6ab6](https://github.com/ReVanced/revanced-patches/commit/fbc6ab6a357b351f02d4d486ddc2072cf53199c3))
+
+
+### Features
+
+* **YouTube:** Add `Open videos fullscreen` patch ([#4069](https://github.com/ReVanced/revanced-patches/issues/4069)) ([296d63b](https://github.com/ReVanced/revanced-patches/commit/296d63bd42c338a01efbcb2df702e5822d05a5f1))
+
+# [5.3.0-dev.4](https://github.com/ReVanced/revanced-patches/compare/v5.3.0-dev.3...v5.3.0-dev.4) (2024-12-09)
+
+
+### Features
+
+* **Nyx:** Remove broken `Unlock pro` patch ([1fe8b16](https://github.com/ReVanced/revanced-patches/commit/1fe8b164eab0c4fa80ab2da2581977f5111a2858))
+
+# [5.3.0-dev.3](https://github.com/ReVanced/revanced-patches/compare/v5.3.0-dev.2...v5.3.0-dev.3) (2024-12-09)
+
+
+### Bug Fixes
+
+* **YouTube - Spoof video streams:** Update `Force AVC` client data ([#4064](https://github.com/ReVanced/revanced-patches/issues/4064)) ([7d537dd](https://github.com/ReVanced/revanced-patches/commit/7d537ddff4bb5421fa320741275131a66ef5c7bb))
+
+# [5.3.0-dev.2](https://github.com/ReVanced/revanced-patches/compare/v5.3.0-dev.1...v5.3.0-dev.2) (2024-12-08)
+
+
+### Bug Fixes
+
+* **Reddit:** Fix patches by using correct extension class ([70bdc68](https://github.com/ReVanced/revanced-patches/commit/70bdc6840d465399625aa1ae0259f49e72711955))
+
+# [5.3.0-dev.1](https://github.com/ReVanced/revanced-patches/compare/v5.2.4-dev.3...v5.3.0-dev.1) (2024-12-08)
+
+
+### Features
+
+* **YouTube Music:** Add `Spoof video streams` patch to fix playback ([#4065](https://github.com/ReVanced/revanced-patches/issues/4065)) ([cf3116a](https://github.com/ReVanced/revanced-patches/commit/cf3116a7583d09c25c798a85687a056f143656f0))
+
+## [5.2.4-dev.3](https://github.com/ReVanced/revanced-patches/compare/v5.2.4-dev.2...v5.2.4-dev.3) (2024-12-07)
+
+
+### Bug Fixes
+
+* **YouTube - Spoof video streams:** Enable opus codec by updating iOS client version ([#4063](https://github.com/ReVanced/revanced-patches/issues/4063)) ([0af156f](https://github.com/ReVanced/revanced-patches/commit/0af156f18972c5f089af4bb69824968d2a47d18f))
+
+## [5.2.4-dev.2](https://github.com/ReVanced/revanced-patches/compare/v5.2.4-dev.1...v5.2.4-dev.2) (2024-12-07)
+
+
+### Bug Fixes
+
+* **Sync for Reddit:** Fix patches by using correct extension name ([030093e](https://github.com/ReVanced/revanced-patches/commit/030093e913aab3fab43935eedbaeba0f6c0491bb))
+
+## [5.2.4-dev.1](https://github.com/ReVanced/revanced-patches/compare/v5.2.3...v5.2.4-dev.1) (2024-12-07)
+
+
+### Bug Fixes
+
+* **Twitter:** Merge correct extension by depending on correct extension patch ([8281cf6](https://github.com/ReVanced/revanced-patches/commit/8281cf6a3eead8cc25a277371e0b0ab2be982497))
+
## [5.2.3](https://github.com/ReVanced/revanced-patches/compare/v5.2.2...v5.2.3) (2024-12-06)
diff --git a/extensions/reddit/src/main/java/app/revanced/extension/patches/FilterPromotedLinksPatch.java b/extensions/reddit/src/main/java/app/revanced/extension/reddit/patches/FilterPromotedLinksPatch.java
similarity index 83%
rename from extensions/reddit/src/main/java/app/revanced/extension/patches/FilterPromotedLinksPatch.java
rename to extensions/reddit/src/main/java/app/revanced/extension/reddit/patches/FilterPromotedLinksPatch.java
index 5b3e61b2ae..12cdc88345 100644
--- a/extensions/reddit/src/main/java/app/revanced/extension/patches/FilterPromotedLinksPatch.java
+++ b/extensions/reddit/src/main/java/app/revanced/extension/reddit/patches/FilterPromotedLinksPatch.java
@@ -1,12 +1,16 @@
-package app.revanced.extension.patches;
+package app.revanced.extension.reddit.patches;
import com.reddit.domain.model.ILink;
import java.util.ArrayList;
import java.util.List;
+@SuppressWarnings("unused")
public final class FilterPromotedLinksPatch {
+
/**
+ * Injection point.
+ *
* Filters list from promoted links.
**/
public static List> filterChildren(final Iterable> links) {
diff --git a/extensions/shared/library/src/main/java/app/revanced/extension/shared/settings/BaseSettings.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/settings/BaseSettings.java
index 13be9547ca..9a62db4332 100644
--- a/extensions/shared/library/src/main/java/app/revanced/extension/shared/settings/BaseSettings.java
+++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/settings/BaseSettings.java
@@ -3,10 +3,14 @@
import static java.lang.Boolean.FALSE;
import static java.lang.Boolean.TRUE;
import static app.revanced.extension.shared.settings.Setting.parent;
+import static app.revanced.extension.shared.spoof.SpoofVideoStreamsPatch.ForceiOSAVCAvailability;
+
+import app.revanced.extension.shared.spoof.AudioStreamLanguage;
+import app.revanced.extension.shared.spoof.ClientType;
/**
* Settings shared across multiple apps.
- *
+ *
* To ensure this class is loaded when the UI is created, app specific setting bundles should extend
* or reference this class.
*/
@@ -16,4 +20,11 @@ public class BaseSettings {
public static final BooleanSetting DEBUG_TOAST_ON_ERROR = new BooleanSetting("revanced_debug_toast_on_error", TRUE, "revanced_debug_toast_on_error_user_dialog_message");
public static final IntegerSetting CHECK_ENVIRONMENT_WARNINGS_ISSUED = new IntegerSetting("revanced_check_environment_warnings_issued", 0, true, false);
+
+ public static final BooleanSetting SPOOF_VIDEO_STREAMS = new BooleanSetting("revanced_spoof_video_streams", TRUE, true, "revanced_spoof_video_streams_user_dialog_message");
+ public static final EnumSetting SPOOF_VIDEO_STREAMS_LANGUAGE = new EnumSetting<>("revanced_spoof_video_streams_language", AudioStreamLanguage.DEFAULT, parent(SPOOF_VIDEO_STREAMS));
+ public static final BooleanSetting SPOOF_VIDEO_STREAMS_IOS_FORCE_AVC = new BooleanSetting("revanced_spoof_video_streams_ios_force_avc", FALSE, true,
+ "revanced_spoof_video_streams_ios_force_avc_user_dialog_message", new ForceiOSAVCAvailability());
+ public static final EnumSetting SPOOF_VIDEO_STREAMS_CLIENT_TYPE = new EnumSetting<>("revanced_spoof_video_streams_client", ClientType.ANDROID_VR, true, parent(SPOOF_VIDEO_STREAMS));
+
}
diff --git a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/AudioStreamLanguage.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/AudioStreamLanguage.java
new file mode 100644
index 0000000000..0d9070e2fd
--- /dev/null
+++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/AudioStreamLanguage.java
@@ -0,0 +1,102 @@
+package app.revanced.extension.shared.spoof;
+
+import java.util.Locale;
+
+public enum AudioStreamLanguage {
+ DEFAULT,
+
+ // Language codes found in locale_config.xml
+ // Region specific variants of Chinese/English/Spanish/French have been removed.
+ AF,
+ AM,
+ AR,
+ AS,
+ AZ,
+ BE,
+ BG,
+ BN,
+ BS,
+ CA,
+ CS,
+ DA,
+ DE,
+ EL,
+ EN,
+ ES,
+ ET,
+ EU,
+ FA,
+ FI,
+ FR,
+ GL,
+ GU,
+ HI,
+ HE, // App uses obsolete 'IW' and 'HE' is modern ISO code.
+ HR,
+ HU,
+ HY,
+ ID,
+ IS,
+ IT,
+ JA,
+ KA,
+ KK,
+ KM,
+ KN,
+ KO,
+ KY,
+ LO,
+ LT,
+ LV,
+ MK,
+ ML,
+ MN,
+ MR,
+ MS,
+ MY,
+ NE,
+ NL,
+ NB,
+ OR,
+ PA,
+ PL,
+ PT_BR,
+ PT_PT,
+ RO,
+ RU,
+ SI,
+ SK,
+ SL,
+ SQ,
+ SR,
+ SV,
+ SW,
+ TA,
+ TE,
+ TH,
+ TL,
+ TR,
+ UK,
+ UR,
+ UZ,
+ VI,
+ ZH,
+ ZU;
+
+ private final String iso639_1;
+
+ AudioStreamLanguage() {
+ iso639_1 = name().replace('_', '-');
+ }
+
+ public String getIso639_1() {
+ // Changing the app language does not force the app to completely restart,
+ // so the default needs to be the current language and not a static field.
+ if (this == DEFAULT) {
+ // Android VR requires uppercase language code.
+ return Locale.getDefault().toLanguageTag().toUpperCase(Locale.US);
+ }
+
+ return iso639_1;
+ }
+}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/ClientType.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java
similarity index 66%
rename from extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/ClientType.java
rename to extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java
index 2c1f0d55f5..ddf170f78c 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/ClientType.java
+++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java
@@ -1,46 +1,49 @@
-package app.revanced.extension.youtube.patches.spoof;
-
-import static app.revanced.extension.youtube.patches.spoof.DeviceHardwareSupport.allowAV1;
-import static app.revanced.extension.youtube.patches.spoof.DeviceHardwareSupport.allowVP9;
+package app.revanced.extension.shared.spoof;
import android.os.Build;
import androidx.annotation.Nullable;
+import app.revanced.extension.shared.settings.BaseSettings;
+
public enum ClientType {
// Specific purpose for age restricted, or private videos, because the iOS client is not logged in.
+ // https://dumps.tadiphone.dev/dumps/oculus/eureka
ANDROID_VR(28,
"Quest 3",
"12",
"com.google.android.apps.youtube.vr.oculus/1.56.21 (Linux; U; Android 12; GB) gzip",
"32", // Android 12.1
"1.56.21",
- "ANDROID_VR",
true
),
// Specific for kids videos.
- // https://dumps.tadiphone.dev/dumps/oculus/eureka
IOS(5,
- // iPhone 15 supports AV1 hardware decoding.
- // Only use if this Android device also has hardware decoding.
- allowAV1()
- ? "iPhone16,2" // 15 Pro Max
- : "iPhone11,4", // XS Max
- // iOS 14+ forces VP9.
- allowVP9()
- ? "17.5.1.21F90"
- : "13.7.17H35",
- allowVP9()
- ? "com.google.ios.youtube/19.10.7 (iPhone; U; CPU iOS 17_5_1 like Mac OS X)"
- : "com.google.ios.youtube/19.10.7 (iPhone; U; CPU iOS 13_7 like Mac OS X)",
+ forceAVC()
+ ? "iPhone12,5" // 11 Pro Max (last device with iOS 13)
+ : "iPhone16,2", // 15 Pro Max
+ // iOS 13 and earlier uses only AVC. 14+ adds VP9 and AV1.
+ forceAVC()
+ ? "13.7.17H35" // Last release of iOS 13.
+ : "17.5.1.21F90",
+ forceAVC()
+ ? "com.google.ios.youtube/17.40.5 (iPhone; U; CPU iOS 13_7 like Mac OS X)"
+ : "com.google.ios.youtube/19.47.7 (iPhone; U; CPU iOS 17_5_1 like Mac OS X)",
null,
// Version number should be a valid iOS release.
// https://www.ipa4fun.com/history/185230
- "19.10.7",
- "IOS",
+ forceAVC()
+ // Some newer versions can also force AVC,
+ // but 17.40 is the last version that supports iOS 13.
+ ? "17.40.5"
+ : "19.47.7",
false
);
+ private static boolean forceAVC() {
+ return BaseSettings.SPOOF_VIDEO_STREAMS_IOS_FORCE_AVC.get();
+ }
+
/**
* YouTube
* client type
@@ -69,11 +72,6 @@ public enum ClientType {
@Nullable
public final String androidSdkVersion;
- /**
- * Client name.
- */
- public final String clientName;
-
/**
* App version.
*/
@@ -90,7 +88,6 @@ public enum ClientType {
String userAgent,
@Nullable String androidSdkVersion,
String clientVersion,
- String clientName,
boolean canLogin
) {
this.id = id;
@@ -99,7 +96,6 @@ public enum ClientType {
this.userAgent = userAgent;
this.androidSdkVersion = androidSdkVersion;
this.clientVersion = clientVersion;
- this.clientName = clientName;
this.canLogin = canLogin;
}
}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/SpoofVideoStreamsPatch.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java
similarity index 93%
rename from extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/SpoofVideoStreamsPatch.java
rename to extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java
index b50e3f4ffa..119b5306e5 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/SpoofVideoStreamsPatch.java
+++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java
@@ -1,4 +1,4 @@
-package app.revanced.extension.youtube.patches.spoof;
+package app.revanced.extension.shared.spoof;
import android.net.Uri;
@@ -12,20 +12,11 @@
import app.revanced.extension.shared.Utils;
import app.revanced.extension.shared.settings.BaseSettings;
import app.revanced.extension.shared.settings.Setting;
-import app.revanced.extension.youtube.patches.spoof.requests.StreamingDataRequest;
-import app.revanced.extension.youtube.settings.Settings;
+import app.revanced.extension.shared.spoof.requests.StreamingDataRequest;
@SuppressWarnings("unused")
public class SpoofVideoStreamsPatch {
- public static final class ForceiOSAVCAvailability implements Setting.Availability {
- @Override
- public boolean isAvailable() {
- return Settings.SPOOF_VIDEO_STREAMS.get() && Settings.SPOOF_VIDEO_STREAMS_CLIENT_TYPE.get() == ClientType.IOS;
- }
- }
-
- private static final boolean SPOOF_STREAMING_DATA = Settings.SPOOF_VIDEO_STREAMS.get();
-
+ private static final boolean SPOOF_STREAMING_DATA = BaseSettings.SPOOF_VIDEO_STREAMS.get();
/**
* Any unreachable ip address. Used to intentionally fail requests.
*/
@@ -165,4 +156,11 @@ public static byte[] removeVideoPlaybackPostBody(Uri uri, int method, byte[] pos
return postData;
}
+
+ public static final class ForceiOSAVCAvailability implements Setting.Availability {
+ @Override
+ public boolean isAvailable() {
+ return BaseSettings.SPOOF_VIDEO_STREAMS.get() && BaseSettings.SPOOF_VIDEO_STREAMS_CLIENT_TYPE.get() == ClientType.IOS;
+ }
+ }
}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/requests/PlayerRoutes.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/PlayerRoutes.java
similarity index 85%
rename from extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/requests/PlayerRoutes.java
rename to extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/PlayerRoutes.java
index f77288ccc3..6f6a6e7c52 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/requests/PlayerRoutes.java
+++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/PlayerRoutes.java
@@ -1,4 +1,4 @@
-package app.revanced.extension.youtube.patches.spoof.requests;
+package app.revanced.extension.shared.spoof.requests;
import org.json.JSONException;
import org.json.JSONObject;
@@ -7,10 +7,10 @@
import java.net.HttpURLConnection;
import app.revanced.extension.shared.Logger;
-import app.revanced.extension.shared.Utils;
import app.revanced.extension.shared.requests.Requester;
import app.revanced.extension.shared.requests.Route;
-import app.revanced.extension.youtube.patches.spoof.ClientType;
+import app.revanced.extension.shared.settings.BaseSettings;
+import app.revanced.extension.shared.spoof.ClientType;
final class PlayerRoutes {
static final Route.CompiledRoute GET_STREAMING_DATA = new Route(
@@ -25,9 +25,6 @@ final class PlayerRoutes {
*/
private static final int CONNECTION_TIMEOUT_MILLISECONDS = 10 * 1000; // 10 Seconds.
- private static final String LOCALE_LANGUAGE = Utils.getContext().getResources()
- .getConfiguration().locale.getLanguage();
-
private PlayerRoutes() {
}
@@ -38,8 +35,7 @@ static String createInnertubeBody(ClientType clientType) {
JSONObject context = new JSONObject();
JSONObject client = new JSONObject();
- // Required to use correct default audio channel with iOS.
- client.put("hl", LOCALE_LANGUAGE);
+ client.put("hl", BaseSettings.SPOOF_VIDEO_STREAMS_LANGUAGE.get().getIso639_1());
client.put("clientName", clientType.name());
client.put("clientVersion", clientType.clientVersion);
client.put("deviceModel", clientType.deviceModel);
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/requests/StreamingDataRequest.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java
similarity index 96%
rename from extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/requests/StreamingDataRequest.java
rename to extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java
index 0c09e0fa76..8853722303 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/requests/StreamingDataRequest.java
+++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java
@@ -1,6 +1,6 @@
-package app.revanced.extension.youtube.patches.spoof.requests;
+package app.revanced.extension.shared.spoof.requests;
-import static app.revanced.extension.youtube.patches.spoof.requests.PlayerRoutes.GET_STREAMING_DATA;
+import static app.revanced.extension.shared.spoof.requests.PlayerRoutes.GET_STREAMING_DATA;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
@@ -22,8 +22,7 @@
import app.revanced.extension.shared.Logger;
import app.revanced.extension.shared.Utils;
import app.revanced.extension.shared.settings.BaseSettings;
-import app.revanced.extension.youtube.patches.spoof.ClientType;
-import app.revanced.extension.youtube.settings.Settings;
+import app.revanced.extension.shared.spoof.ClientType;
/**
* Video streaming data. Fetching is tied to the behavior YT uses,
@@ -70,7 +69,7 @@ protected boolean removeEldestEntry(Entry eldest) {
static {
ClientType[] allClientTypes = ClientType.values();
- ClientType preferredClient = Settings.SPOOF_VIDEO_STREAMS_CLIENT_TYPE.get();
+ ClientType preferredClient = BaseSettings.SPOOF_VIDEO_STREAMS_CLIENT_TYPE.get();
CLIENT_ORDER_TO_USE = new ClientType[allClientTypes.length];
CLIENT_ORDER_TO_USE[0] = preferredClient;
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/FullscreenPanelsRemoverPatch.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/FullscreenPanelsRemoverPatch.java
deleted file mode 100644
index f454b361c0..0000000000
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/FullscreenPanelsRemoverPatch.java
+++ /dev/null
@@ -1,12 +0,0 @@
-package app.revanced.extension.youtube.patches;
-
-import android.view.View;
-
-import app.revanced.extension.youtube.settings.Settings;
-
-@SuppressWarnings("unused")
-public class FullscreenPanelsRemoverPatch {
- public static int getFullscreenPanelsVisibility() {
- return Settings.HIDE_FULLSCREEN_PANELS.get() ? View.GONE : View.VISIBLE;
- }
-}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/OpenVideosFullscreen.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/OpenVideosFullscreen.java
new file mode 100644
index 0000000000..a15d7f6414
--- /dev/null
+++ b/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/OpenVideosFullscreen.java
@@ -0,0 +1,14 @@
+package app.revanced.extension.youtube.patches;
+
+import app.revanced.extension.youtube.settings.Settings;
+
+@SuppressWarnings("unused")
+public class OpenVideosFullscreen {
+
+ /**
+ * Injection point.
+ */
+ public static boolean openVideoFullscreenPortrait(boolean original) {
+ return Settings.OPEN_VIDEOS_FULLSCREEN_PORTRAIT.get();
+ }
+}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/DeviceHardwareSupport.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/DeviceHardwareSupport.java
deleted file mode 100644
index 3adc6befb3..0000000000
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/spoof/DeviceHardwareSupport.java
+++ /dev/null
@@ -1,53 +0,0 @@
-package app.revanced.extension.youtube.patches.spoof;
-
-import android.media.MediaCodecInfo;
-import android.media.MediaCodecList;
-import android.os.Build;
-
-import app.revanced.extension.shared.Logger;
-import app.revanced.extension.youtube.settings.Settings;
-
-public class DeviceHardwareSupport {
- public static final boolean DEVICE_HAS_HARDWARE_DECODING_VP9;
- public static final boolean DEVICE_HAS_HARDWARE_DECODING_AV1;
-
- static {
- boolean vp9found = false;
- boolean av1found = false;
- MediaCodecList codecList = new MediaCodecList(MediaCodecList.ALL_CODECS);
- final boolean deviceIsAndroidTenOrLater = Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q;
-
- for (MediaCodecInfo codecInfo : codecList.getCodecInfos()) {
- final boolean isHardwareAccelerated = deviceIsAndroidTenOrLater
- ? codecInfo.isHardwareAccelerated()
- : !codecInfo.getName().startsWith("OMX.google"); // Software decoder.
- if (isHardwareAccelerated && !codecInfo.isEncoder()) {
- for (String type : codecInfo.getSupportedTypes()) {
- if (type.equalsIgnoreCase("video/x-vnd.on2.vp9")) {
- vp9found = true;
- } else if (type.equalsIgnoreCase("video/av01")) {
- av1found = true;
- }
- }
- }
- }
-
- DEVICE_HAS_HARDWARE_DECODING_VP9 = vp9found;
- DEVICE_HAS_HARDWARE_DECODING_AV1 = av1found;
-
- Logger.printDebug(() -> DEVICE_HAS_HARDWARE_DECODING_AV1
- ? "Device supports AV1 hardware decoding\n"
- : "Device does not support AV1 hardware decoding\n"
- + (DEVICE_HAS_HARDWARE_DECODING_VP9
- ? "Device supports VP9 hardware decoding"
- : "Device does not support VP9 hardware decoding"));
- }
-
- public static boolean allowVP9() {
- return DEVICE_HAS_HARDWARE_DECODING_VP9 && !Settings.SPOOF_VIDEO_STREAMS_IOS_FORCE_AVC.get();
- }
-
- public static boolean allowAV1() {
- return allowVP9() && DEVICE_HAS_HARDWARE_DECODING_AV1;
- }
-}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/theme/ThemePatch.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/theme/ThemePatch.java
index 0f8fb3304a..0a8dfda9bb 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/theme/ThemePatch.java
+++ b/extensions/youtube/src/main/java/app/revanced/extension/youtube/patches/theme/ThemePatch.java
@@ -55,7 +55,7 @@ private static boolean anyEquals(int value, int... of) {
/**
* Injection point.
*/
- public static boolean gradientLoadingScreenEnabled() {
+ public static boolean gradientLoadingScreenEnabled(boolean original) {
return GRADIENT_LOADING_SCREEN_ENABLED;
}
}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/Settings.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/Settings.java
index 4f11de9284..5f256fb960 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/Settings.java
+++ b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/Settings.java
@@ -2,25 +2,42 @@
import static java.lang.Boolean.FALSE;
import static java.lang.Boolean.TRUE;
-import static app.revanced.extension.shared.settings.Setting.*;
+import static app.revanced.extension.shared.settings.Setting.Availability;
+import static app.revanced.extension.shared.settings.Setting.migrateFromOldPreferences;
+import static app.revanced.extension.shared.settings.Setting.migrateOldSettingToNew;
+import static app.revanced.extension.shared.settings.Setting.parent;
+import static app.revanced.extension.shared.settings.Setting.parentsAny;
import static app.revanced.extension.youtube.patches.ChangeStartPagePatch.StartPage;
import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerHideExpandCloseAvailability;
import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerHorizontalDragAvailability;
import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType;
-import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.*;
+import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.MINIMAL;
+import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.MODERN_1;
+import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.MODERN_2;
+import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.MODERN_3;
+import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.MODERN_4;
+import static app.revanced.extension.youtube.patches.MiniplayerPatch.MiniplayerType.PHONE;
import static app.revanced.extension.youtube.patches.SeekbarThumbnailsPatch.SeekbarThumbnailsHighQualityAvailability;
import static app.revanced.extension.youtube.patches.VersionCheckPatch.IS_19_17_OR_GREATER;
-import static app.revanced.extension.youtube.sponsorblock.objects.CategoryBehaviour.*;
+import static app.revanced.extension.youtube.sponsorblock.objects.CategoryBehaviour.IGNORE;
+import static app.revanced.extension.youtube.sponsorblock.objects.CategoryBehaviour.MANUAL_SKIP;
+import static app.revanced.extension.youtube.sponsorblock.objects.CategoryBehaviour.SKIP_AUTOMATICALLY;
+import static app.revanced.extension.youtube.sponsorblock.objects.CategoryBehaviour.SKIP_AUTOMATICALLY_ONCE;
import app.revanced.extension.shared.Logger;
-import app.revanced.extension.shared.settings.*;
+import app.revanced.extension.shared.settings.BaseSettings;
+import app.revanced.extension.shared.settings.BooleanSetting;
+import app.revanced.extension.shared.settings.EnumSetting;
+import app.revanced.extension.shared.settings.FloatSetting;
+import app.revanced.extension.shared.settings.IntegerSetting;
+import app.revanced.extension.shared.settings.LongSetting;
+import app.revanced.extension.shared.settings.Setting;
+import app.revanced.extension.shared.settings.StringSetting;
import app.revanced.extension.shared.settings.preference.SharedPrefCategory;
import app.revanced.extension.youtube.patches.AlternativeThumbnailsPatch.DeArrowAvailability;
import app.revanced.extension.youtube.patches.AlternativeThumbnailsPatch.StillImagesAvailability;
import app.revanced.extension.youtube.patches.AlternativeThumbnailsPatch.ThumbnailOption;
import app.revanced.extension.youtube.patches.AlternativeThumbnailsPatch.ThumbnailStillTime;
-import app.revanced.extension.youtube.patches.spoof.ClientType;
-import app.revanced.extension.youtube.patches.spoof.SpoofVideoStreamsPatch;
import app.revanced.extension.youtube.sponsorblock.SponsorBlockSettings;
public class Settings extends BaseSettings {
@@ -37,17 +54,17 @@ public class Settings extends BaseSettings {
"0.25\n0.5\n0.75\n0.9\n0.95\n1.0\n1.05\n1.1\n1.25\n1.5\n1.75\n2.0\n3.0\n4.0\n5.0", true);
// Ads
- public static final BooleanSetting HIDE_FULLSCREEN_ADS = new BooleanSetting("revanced_hide_fullscreen_ads", TRUE);
public static final BooleanSetting HIDE_BUTTONED_ADS = new BooleanSetting("revanced_hide_buttoned_ads", TRUE);
+ public static final BooleanSetting HIDE_FULLSCREEN_ADS = new BooleanSetting("revanced_hide_fullscreen_ads", TRUE);
public static final BooleanSetting HIDE_GENERAL_ADS = new BooleanSetting("revanced_hide_general_ads", TRUE);
public static final BooleanSetting HIDE_GET_PREMIUM = new BooleanSetting("revanced_hide_get_premium", TRUE);
public static final BooleanSetting HIDE_HIDE_LATEST_POSTS = new BooleanSetting("revanced_hide_latest_posts_ads", TRUE);
public static final BooleanSetting HIDE_MERCHANDISE_BANNERS = new BooleanSetting("revanced_hide_merchandise_banners", TRUE);
public static final BooleanSetting HIDE_PAID_PROMOTION_LABEL = new BooleanSetting("revanced_hide_paid_promotion_label", TRUE);
- public static final BooleanSetting HIDE_PRODUCTS_BANNER = new BooleanSetting("revanced_hide_products_banner", TRUE);
public static final BooleanSetting HIDE_PLAYER_STORE_SHELF = new BooleanSetting("revanced_hide_player_store_shelf", TRUE);
- public static final BooleanSetting HIDE_SHOPPING_LINKS = new BooleanSetting("revanced_hide_shopping_links", TRUE);
+ public static final BooleanSetting HIDE_PRODUCTS_BANNER = new BooleanSetting("revanced_hide_products_banner", TRUE);
public static final BooleanSetting HIDE_SELF_SPONSOR = new BooleanSetting("revanced_hide_self_sponsor_ads", TRUE);
+ public static final BooleanSetting HIDE_SHOPPING_LINKS = new BooleanSetting("revanced_hide_shopping_links", TRUE);
public static final BooleanSetting HIDE_VIDEO_ADS = new BooleanSetting("revanced_hide_video_ads", TRUE, true);
public static final BooleanSetting HIDE_VISIT_STORE_BUTTON = new BooleanSetting("revanced_hide_visit_store_button", TRUE);
public static final BooleanSetting HIDE_WEB_SEARCH_RESULTS = new BooleanSetting("revanced_hide_web_search_results", TRUE);
@@ -55,9 +72,27 @@ public class Settings extends BaseSettings {
// Feed
public static final BooleanSetting HIDE_ALBUM_CARDS = new BooleanSetting("revanced_hide_album_cards", FALSE, true);
public static final BooleanSetting HIDE_ARTIST_CARDS = new BooleanSetting("revanced_hide_artist_cards", FALSE);
- public static final BooleanSetting HIDE_EXPANDABLE_CHIP = new BooleanSetting("revanced_hide_expandable_chip", TRUE);
+ public static final BooleanSetting HIDE_CHIPS_SHELF = new BooleanSetting("revanced_hide_chips_shelf", TRUE);
+ public static final BooleanSetting HIDE_COMMUNITY_POSTS = new BooleanSetting("revanced_hide_community_posts", FALSE);
+ public static final BooleanSetting HIDE_COMPACT_BANNER = new BooleanSetting("revanced_hide_compact_banner", TRUE);
+ public static final BooleanSetting HIDE_CROWDFUNDING_BOX = new BooleanSetting("revanced_hide_crowdfunding_box", FALSE, true);
public static final BooleanSetting HIDE_DOODLES = new BooleanSetting("revanced_hide_doodles", FALSE, true, "revanced_hide_doodles_user_dialog_message");
-
+ public static final BooleanSetting HIDE_EXPANDABLE_CHIP = new BooleanSetting("revanced_hide_expandable_chip", TRUE);
+ public static final BooleanSetting HIDE_FEED_SURVEY = new BooleanSetting("revanced_hide_feed_survey", TRUE);
+ public static final BooleanSetting HIDE_FILTER_BAR_FEED_IN_FEED = new BooleanSetting("revanced_hide_filter_bar_feed_in_feed", FALSE, true);
+ public static final BooleanSetting HIDE_FILTER_BAR_FEED_IN_RELATED_VIDEOS = new BooleanSetting("revanced_hide_filter_bar_feed_in_related_videos", FALSE, true);
+ public static final BooleanSetting HIDE_FILTER_BAR_FEED_IN_SEARCH = new BooleanSetting("revanced_hide_filter_bar_feed_in_search", FALSE, true);
+ public static final BooleanSetting HIDE_FLOATING_MICROPHONE_BUTTON = new BooleanSetting("revanced_hide_floating_microphone_button", TRUE, true);
+ public static final BooleanSetting HIDE_FOR_YOU_SHELF = new BooleanSetting("revanced_hide_for_you_shelf", TRUE);
+ public static final BooleanSetting HIDE_HORIZONTAL_SHELVES = new BooleanSetting("revanced_hide_horizontal_shelves", TRUE);
+ public static final BooleanSetting HIDE_IMAGE_SHELF = new BooleanSetting("revanced_hide_image_shelf", TRUE);
+ public static final BooleanSetting HIDE_MIX_PLAYLISTS = new BooleanSetting("revanced_hide_mix_playlists", TRUE);
+ public static final BooleanSetting HIDE_MOVIES_SECTION = new BooleanSetting("revanced_hide_movies_section", TRUE);
+ public static final BooleanSetting HIDE_NOTIFY_ME_BUTTON = new BooleanSetting("revanced_hide_notify_me_button", TRUE);
+ public static final BooleanSetting HIDE_PLAYABLES = new BooleanSetting("revanced_hide_playables", TRUE);
+ public static final BooleanSetting HIDE_SEARCH_RESULT_RECOMMENDATIONS = new BooleanSetting("revanced_hide_search_result_recommendations", TRUE);
+ public static final BooleanSetting HIDE_SEARCH_RESULT_SHELF_HEADER = new BooleanSetting("revanced_hide_search_result_shelf_header", FALSE);
+ public static final BooleanSetting HIDE_SHOW_MORE_BUTTON = new BooleanSetting("revanced_hide_show_more_button", TRUE, true);
// Alternative thumbnails
public static final EnumSetting ALT_THUMBNAIL_HOME = new EnumSetting<>("revanced_alt_thumbnail_home", ThumbnailOption.ORIGINAL);
public static final EnumSetting ALT_THUMBNAIL_SUBSCRIPTIONS = new EnumSetting<>("revanced_alt_thumbnail_subscription", ThumbnailOption.ORIGINAL);
@@ -69,7 +104,6 @@ public class Settings extends BaseSettings {
public static final BooleanSetting ALT_THUMBNAIL_DEARROW_CONNECTION_TOAST = new BooleanSetting("revanced_alt_thumbnail_dearrow_connection_toast", TRUE, new DeArrowAvailability());
public static final EnumSetting ALT_THUMBNAIL_STILLS_TIME = new EnumSetting<>("revanced_alt_thumbnail_stills_time", ThumbnailStillTime.MIDDLE, new StillImagesAvailability());
public static final BooleanSetting ALT_THUMBNAIL_STILLS_FAST = new BooleanSetting("revanced_alt_thumbnail_stills_fast", FALSE, new StillImagesAvailability());
-
// Hide keyword content
public static final BooleanSetting HIDE_KEYWORD_CONTENT_HOME = new BooleanSetting("revanced_hide_keyword_content_home", FALSE);
public static final BooleanSetting HIDE_KEYWORD_CONTENT_SUBSCRIPTIONS = new BooleanSetting("revanced_hide_keyword_content_subscriptions", FALSE);
@@ -77,61 +111,36 @@ public class Settings extends BaseSettings {
public static final StringSetting HIDE_KEYWORD_CONTENT_PHRASES = new StringSetting("revanced_hide_keyword_content_phrases", "",
parentsAny(HIDE_KEYWORD_CONTENT_HOME, HIDE_KEYWORD_CONTENT_SUBSCRIPTIONS, HIDE_KEYWORD_CONTENT_SEARCH));
- // Uncategorized layout related settings. Do not add to this section, and instead move these out and categorize them.
+ // Player
+ public static final BooleanSetting COPY_VIDEO_URL = new BooleanSetting("revanced_copy_video_url", FALSE);
+ public static final BooleanSetting COPY_VIDEO_URL_TIMESTAMP = new BooleanSetting("revanced_copy_video_url_timestamp", TRUE);
+ public static final BooleanSetting DISABLE_FULLSCREEN_AMBIENT_MODE = new BooleanSetting("revanced_disable_fullscreen_ambient_mode", TRUE, true);
+ public static final BooleanSetting DISABLE_LIKE_SUBSCRIBE_GLOW = new BooleanSetting("revanced_disable_like_subscribe_glow", FALSE);
+ public static final BooleanSetting DISABLE_ROLLING_NUMBER_ANIMATIONS = new BooleanSetting("revanced_disable_rolling_number_animations", FALSE);
public static final BooleanSetting DISABLE_SUGGESTED_VIDEO_END_SCREEN = new BooleanSetting("revanced_disable_suggested_video_end_screen", FALSE, true);
- public static final BooleanSetting GRADIENT_LOADING_SCREEN = new BooleanSetting("revanced_gradient_loading_screen", FALSE, true);
- public static final BooleanSetting HIDE_HORIZONTAL_SHELVES = new BooleanSetting("revanced_hide_horizontal_shelves", TRUE);
+ public static final BooleanSetting HIDE_AUTOPLAY_BUTTON = new BooleanSetting("revanced_hide_autoplay_button", TRUE, true);
public static final BooleanSetting HIDE_CAPTIONS_BUTTON = new BooleanSetting("revanced_hide_captions_button", FALSE);
+ public static final BooleanSetting HIDE_CAST_BUTTON = new BooleanSetting("revanced_hide_cast_button", TRUE, true);
public static final BooleanSetting HIDE_CHANNEL_BAR = new BooleanSetting("revanced_hide_channel_bar", FALSE);
public static final BooleanSetting HIDE_CHANNEL_MEMBER_SHELF = new BooleanSetting("revanced_hide_channel_member_shelf", TRUE);
- public static final BooleanSetting HIDE_CHIPS_SHELF = new BooleanSetting("revanced_hide_chips_shelf", TRUE);
public static final BooleanSetting HIDE_COMMUNITY_GUIDELINES = new BooleanSetting("revanced_hide_community_guidelines", TRUE);
- public static final BooleanSetting HIDE_COMMUNITY_POSTS = new BooleanSetting("revanced_hide_community_posts", FALSE);
- public static final BooleanSetting HIDE_COMPACT_BANNER = new BooleanSetting("revanced_hide_compact_banner", TRUE);
- public static final BooleanSetting HIDE_CROWDFUNDING_BOX = new BooleanSetting("revanced_hide_crowdfunding_box", FALSE, true);
public static final BooleanSetting HIDE_EMERGENCY_BOX = new BooleanSetting("revanced_hide_emergency_box", TRUE);
public static final BooleanSetting HIDE_ENDSCREEN_CARDS = new BooleanSetting("revanced_hide_endscreen_cards", FALSE);
- public static final BooleanSetting HIDE_FEED_SURVEY = new BooleanSetting("revanced_hide_feed_survey", TRUE);
- public static final BooleanSetting HIDE_FILTER_BAR_FEED_IN_FEED = new BooleanSetting("revanced_hide_filter_bar_feed_in_feed", FALSE, true);
- public static final BooleanSetting HIDE_FILTER_BAR_FEED_IN_RELATED_VIDEOS = new BooleanSetting("revanced_hide_filter_bar_feed_in_related_videos", FALSE, true);
- public static final BooleanSetting HIDE_FILTER_BAR_FEED_IN_SEARCH = new BooleanSetting("revanced_hide_filter_bar_feed_in_search", FALSE, true);
- public static final BooleanSetting HIDE_FLOATING_MICROPHONE_BUTTON = new BooleanSetting("revanced_hide_floating_microphone_button", TRUE, true);
- public static final BooleanSetting HIDE_FULLSCREEN_PANELS = new BooleanSetting("revanced_hide_fullscreen_panels", TRUE, true);
public static final BooleanSetting HIDE_HIDE_CHANNEL_GUIDELINES = new BooleanSetting("revanced_hide_channel_guidelines", TRUE);
public static final BooleanSetting HIDE_HIDE_INFO_PANELS = new BooleanSetting("revanced_hide_info_panels", TRUE);
- public static final BooleanSetting HIDE_IMAGE_SHELF = new BooleanSetting("revanced_hide_image_shelf", TRUE);
public static final BooleanSetting HIDE_INFO_CARDS = new BooleanSetting("revanced_hide_info_cards", FALSE);
public static final BooleanSetting HIDE_JOIN_MEMBERSHIP_BUTTON = new BooleanSetting("revanced_hide_join_membership_button", TRUE);
- public static final BooleanSetting HIDE_SHOW_MORE_BUTTON = new BooleanSetting("revanced_hide_show_more_button", TRUE, true);
public static final BooleanSetting HIDE_MEDICAL_PANELS = new BooleanSetting("revanced_hide_medical_panels", TRUE);
- public static final BooleanSetting HIDE_MIX_PLAYLISTS = new BooleanSetting("revanced_hide_mix_playlists", TRUE);
- public static final BooleanSetting HIDE_MOVIES_SECTION = new BooleanSetting("revanced_hide_movies_section", TRUE);
- public static final BooleanSetting HIDE_NOTIFY_ME_BUTTON = new BooleanSetting("revanced_hide_notify_me_button", TRUE);
- public static final BooleanSetting HIDE_PLAYABLES = new BooleanSetting("revanced_hide_playables", TRUE);
+ public static final BooleanSetting HIDE_PLAYER_PREVIOUS_NEXT_BUTTONS = new BooleanSetting("revanced_hide_player_previous_next_buttons", FALSE, true);
public static final BooleanSetting HIDE_QUICK_ACTIONS = new BooleanSetting("revanced_hide_quick_actions", FALSE);
public static final BooleanSetting HIDE_RELATED_VIDEOS = new BooleanSetting("revanced_hide_related_videos", FALSE);
- public static final BooleanSetting HIDE_SEARCH_RESULT_SHELF_HEADER = new BooleanSetting("revanced_hide_search_result_shelf_header", FALSE);
public static final BooleanSetting HIDE_SUBSCRIBERS_COMMUNITY_GUIDELINES = new BooleanSetting("revanced_hide_subscribers_community_guidelines", TRUE);
public static final BooleanSetting HIDE_TIMED_REACTIONS = new BooleanSetting("revanced_hide_timed_reactions", TRUE);
- public static final BooleanSetting HIDE_TIMESTAMP = new BooleanSetting("revanced_hide_timestamp", FALSE);
public static final BooleanSetting HIDE_VIDEO_CHANNEL_WATERMARK = new BooleanSetting("revanced_hide_channel_watermark", TRUE);
- public static final BooleanSetting HIDE_FOR_YOU_SHELF = new BooleanSetting("revanced_hide_for_you_shelf", TRUE);
- public static final BooleanSetting HIDE_SEARCH_RESULT_RECOMMENDATIONS = new BooleanSetting("revanced_hide_search_result_recommendations", TRUE);
- public static final IntegerSetting PLAYER_OVERLAY_OPACITY = new IntegerSetting("revanced_player_overlay_opacity",100, true);
- public static final BooleanSetting PLAYER_POPUP_PANELS = new BooleanSetting("revanced_hide_player_popup_panels", FALSE);
-
- // Player
- public static final BooleanSetting DISABLE_FULLSCREEN_AMBIENT_MODE = new BooleanSetting("revanced_disable_fullscreen_ambient_mode", TRUE, true);
- public static final BooleanSetting DISABLE_ROLLING_NUMBER_ANIMATIONS = new BooleanSetting("revanced_disable_rolling_number_animations", FALSE);
- public static final BooleanSetting DISABLE_LIKE_SUBSCRIBE_GLOW = new BooleanSetting("revanced_disable_like_subscribe_glow", FALSE);
- public static final BooleanSetting HIDE_AUTOPLAY_BUTTON = new BooleanSetting("revanced_hide_autoplay_button", TRUE, true);
- public static final BooleanSetting HIDE_CAST_BUTTON = new BooleanSetting("revanced_hide_cast_button", TRUE, true);
- public static final BooleanSetting HIDE_PLAYER_PREVIOUS_NEXT_BUTTONS = new BooleanSetting("revanced_hide_player_previous_next_buttons", FALSE, true);
- private static final BooleanSetting DEPRECATED_HIDE_PLAYER_BUTTONS = new BooleanSetting("revanced_hide_player_buttons", FALSE, true);
- public static final BooleanSetting COPY_VIDEO_URL = new BooleanSetting("revanced_copy_video_url", FALSE);
- public static final BooleanSetting COPY_VIDEO_URL_TIMESTAMP = new BooleanSetting("revanced_copy_video_url_timestamp", TRUE);
public static final BooleanSetting PLAYBACK_SPEED_DIALOG_BUTTON = new BooleanSetting("revanced_playback_speed_dialog_button", FALSE);
-
+ public static final BooleanSetting PLAYER_POPUP_PANELS = new BooleanSetting("revanced_hide_player_popup_panels", FALSE);
+ public static final IntegerSetting PLAYER_OVERLAY_OPACITY = new IntegerSetting("revanced_player_overlay_opacity", 100, true);
+ public static final BooleanSetting OPEN_VIDEOS_FULLSCREEN_PORTRAIT = new BooleanSetting("revanced_open_videos_fullscreen_portrait", FALSE);
// Miniplayer
public static final EnumSetting MINIPLAYER_TYPE = new EnumSetting<>("revanced_miniplayer_type", MiniplayerType.ORIGINAL, true);
private static final Availability MINIPLAYER_ANY_MODERN = MINIPLAYER_TYPE.availability(MODERN_1, MODERN_2, MODERN_3, MODERN_4);
@@ -144,21 +153,18 @@ public class Settings extends BaseSettings {
public static final BooleanSetting MINIPLAYER_ROUNDED_CORNERS = new BooleanSetting("revanced_miniplayer_rounded_corners", TRUE, true, MINIPLAYER_ANY_MODERN);
public static final IntegerSetting MINIPLAYER_WIDTH_DIP = new IntegerSetting("revanced_miniplayer_width_dip", 192, true, MINIPLAYER_ANY_MODERN);
public static final IntegerSetting MINIPLAYER_OPACITY = new IntegerSetting("revanced_miniplayer_opacity", 100, true, MINIPLAYER_TYPE.availability(MODERN_1));
-
// External downloader
public static final BooleanSetting EXTERNAL_DOWNLOADER = new BooleanSetting("revanced_external_downloader", FALSE);
public static final BooleanSetting EXTERNAL_DOWNLOADER_ACTION_BUTTON = new BooleanSetting("revanced_external_downloader_action_button", FALSE);
public static final StringSetting EXTERNAL_DOWNLOADER_PACKAGE_NAME = new StringSetting("revanced_external_downloader_name",
"org.schabi.newpipe" /* NewPipe */, parentsAny(EXTERNAL_DOWNLOADER, EXTERNAL_DOWNLOADER_ACTION_BUTTON));
-
// Comments
public static final BooleanSetting HIDE_COMMENTS_BY_MEMBERS_HEADER = new BooleanSetting("revanced_hide_comments_by_members_header", FALSE);
- public static final BooleanSetting HIDE_COMMENTS_SECTION = new BooleanSetting("revanced_hide_comments_section", FALSE);
public static final BooleanSetting HIDE_COMMENTS_CREATE_A_SHORT_BUTTON = new BooleanSetting("revanced_hide_comments_create_a_short_button", TRUE);
public static final BooleanSetting HIDE_COMMENTS_PREVIEW_COMMENT = new BooleanSetting("revanced_hide_comments_preview_comment", FALSE);
+ public static final BooleanSetting HIDE_COMMENTS_SECTION = new BooleanSetting("revanced_hide_comments_section", FALSE);
public static final BooleanSetting HIDE_COMMENTS_THANKS_BUTTON = new BooleanSetting("revanced_hide_comments_thanks_button", TRUE);
public static final BooleanSetting HIDE_COMMENTS_TIMESTAMP_AND_EMOJI_BUTTONS = new BooleanSetting("revanced_hide_comments_timestamp_and_emoji_buttons", TRUE);
-
// Description
public static final BooleanSetting HIDE_ATTRIBUTES_SECTION = new BooleanSetting("revanced_hide_attributes_section", FALSE);
public static final BooleanSetting HIDE_CHAPTERS_SECTION = new BooleanSetting("revanced_hide_chapters_section", TRUE);
@@ -166,47 +172,43 @@ public class Settings extends BaseSettings {
public static final BooleanSetting HIDE_KEY_CONCEPTS_SECTION = new BooleanSetting("revanced_hide_key_concepts_section", FALSE);
public static final BooleanSetting HIDE_PODCAST_SECTION = new BooleanSetting("revanced_hide_podcast_section", TRUE);
public static final BooleanSetting HIDE_TRANSCRIPT_SECTION = new BooleanSetting("revanced_hide_transcript_section", TRUE);
-
// Action buttons
+ public static final BooleanSetting HIDE_CLIP_BUTTON = new BooleanSetting("revanced_hide_clip_button", TRUE);
+ public static final BooleanSetting HIDE_DOWNLOAD_BUTTON = new BooleanSetting("revanced_hide_download_button", FALSE);
public static final BooleanSetting HIDE_LIKE_DISLIKE_BUTTON = new BooleanSetting("revanced_hide_like_dislike_button", FALSE);
- public static final BooleanSetting HIDE_SHARE_BUTTON = new BooleanSetting("revanced_hide_share_button", FALSE);
- public static final BooleanSetting HIDE_REPORT_BUTTON = new BooleanSetting("revanced_hide_report_button", FALSE);
+ public static final BooleanSetting HIDE_PLAYLIST_BUTTON = new BooleanSetting("revanced_hide_playlist_button", FALSE);
public static final BooleanSetting HIDE_REMIX_BUTTON = new BooleanSetting("revanced_hide_remix_button", TRUE);
- public static final BooleanSetting HIDE_DOWNLOAD_BUTTON = new BooleanSetting("revanced_hide_download_button", FALSE);
+ public static final BooleanSetting HIDE_REPORT_BUTTON = new BooleanSetting("revanced_hide_report_button", FALSE);
+ public static final BooleanSetting HIDE_SHARE_BUTTON = new BooleanSetting("revanced_hide_share_button", FALSE);
public static final BooleanSetting HIDE_THANKS_BUTTON = new BooleanSetting("revanced_hide_thanks_button", TRUE);
- public static final BooleanSetting HIDE_CLIP_BUTTON = new BooleanSetting("revanced_hide_clip_button", TRUE);
- public static final BooleanSetting HIDE_PLAYLIST_BUTTON = new BooleanSetting("revanced_hide_playlist_button", FALSE);
-
// Player flyout menu items
- public static final BooleanSetting HIDE_PLAYER_FLYOUT_CAPTIONS = new BooleanSetting("revanced_hide_player_flyout_captions", FALSE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_ADDITIONAL_SETTINGS = new BooleanSetting("revanced_hide_player_flyout_additional_settings", FALSE);
- public static final BooleanSetting HIDE_PLAYER_FLYOUT_LOOP_VIDEO = new BooleanSetting("revanced_hide_player_flyout_loop_video", FALSE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_AMBIENT_MODE = new BooleanSetting("revanced_hide_player_flyout_ambient_mode", FALSE);
+ public static final BooleanSetting HIDE_PLAYER_FLYOUT_AUDIO_TRACK = new BooleanSetting("revanced_hide_player_flyout_audio_track", FALSE);
+ public static final BooleanSetting HIDE_PLAYER_FLYOUT_CAPTIONS = new BooleanSetting("revanced_hide_player_flyout_captions", FALSE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_HELP = new BooleanSetting("revanced_hide_player_flyout_help", TRUE);
- public static final BooleanSetting HIDE_PLAYER_FLYOUT_SPEED = new BooleanSetting("revanced_hide_player_flyout_speed", FALSE);
- public static final BooleanSetting HIDE_PLAYER_FLYOUT_MORE_INFO = new BooleanSetting("revanced_hide_player_flyout_more_info", TRUE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_LOCK_SCREEN = new BooleanSetting("revanced_hide_player_flyout_lock_screen", FALSE);
- public static final BooleanSetting HIDE_PLAYER_FLYOUT_AUDIO_TRACK = new BooleanSetting("revanced_hide_player_flyout_audio_track", FALSE);
+ public static final BooleanSetting HIDE_PLAYER_FLYOUT_LOOP_VIDEO = new BooleanSetting("revanced_hide_player_flyout_loop_video", FALSE);
+ public static final BooleanSetting HIDE_PLAYER_FLYOUT_MORE_INFO = new BooleanSetting("revanced_hide_player_flyout_more_info", TRUE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_SLEEP_TIMER = new BooleanSetting("revanced_hide_player_flyout_sleep_timer", FALSE);
+ public static final BooleanSetting HIDE_PLAYER_FLYOUT_SPEED = new BooleanSetting("revanced_hide_player_flyout_speed", FALSE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_STABLE_VOLUME = new BooleanSetting("revanced_hide_player_flyout_stable_volume", FALSE);
- public static final BooleanSetting HIDE_PLAYER_FLYOUT_WATCH_IN_VR = new BooleanSetting("revanced_hide_player_flyout_watch_in_vr", TRUE);
- private static final BooleanSetting DEPRECATED_HIDE_PLAYER_FLYOUT_VIDEO_QUALITY_FOOTER = new BooleanSetting("revanced_hide_video_quality_menu_footer", FALSE);
public static final BooleanSetting HIDE_PLAYER_FLYOUT_VIDEO_QUALITY_FOOTER = new BooleanSetting("revanced_hide_player_flyout_video_quality_footer", FALSE);
+ public static final BooleanSetting HIDE_PLAYER_FLYOUT_WATCH_IN_VR = new BooleanSetting("revanced_hide_player_flyout_watch_in_vr", TRUE);
// General layout
- public static final EnumSetting CHANGE_START_PAGE = new EnumSetting<>("revanced_change_start_page", StartPage.ORIGINAL, true);
- public static final BooleanSetting SPOOF_APP_VERSION = new BooleanSetting("revanced_spoof_app_version", FALSE, true, "revanced_spoof_app_version_user_dialog_message");
- public static final StringSetting SPOOF_APP_VERSION_TARGET = new StringSetting("revanced_spoof_app_version_target", IS_19_17_OR_GREATER ? "19.35.36" : "17.33.42", true, parent(SPOOF_APP_VERSION));
- public static final BooleanSetting TABLET_LAYOUT = new BooleanSetting("revanced_tablet_layout", FALSE, true, "revanced_tablet_layout_user_dialog_message");
- public static final BooleanSetting WIDE_SEARCHBAR = new BooleanSetting("revanced_wide_searchbar", FALSE, true);
public static final BooleanSetting BYPASS_IMAGE_REGION_RESTRICTIONS = new BooleanSetting("revanced_bypass_image_region_restrictions", FALSE, true);
+ public static final BooleanSetting GRADIENT_LOADING_SCREEN = new BooleanSetting("revanced_gradient_loading_screen", FALSE, true);
public static final BooleanSetting REMOVE_VIEWER_DISCRETION_DIALOG = new BooleanSetting("revanced_remove_viewer_discretion_dialog", FALSE,
"revanced_remove_viewer_discretion_dialog_user_dialog_message");
-
+ public static final BooleanSetting SPOOF_APP_VERSION = new BooleanSetting("revanced_spoof_app_version", FALSE, true, "revanced_spoof_app_version_user_dialog_message");
+ public static final BooleanSetting TABLET_LAYOUT = new BooleanSetting("revanced_tablet_layout", FALSE, true, "revanced_tablet_layout_user_dialog_message");
+ public static final BooleanSetting WIDE_SEARCHBAR = new BooleanSetting("revanced_wide_searchbar", FALSE, true);
+ public static final EnumSetting CHANGE_START_PAGE = new EnumSetting<>("revanced_change_start_page", StartPage.ORIGINAL, true);
+ public static final StringSetting SPOOF_APP_VERSION_TARGET = new StringSetting("revanced_spoof_app_version_target", IS_19_17_OR_GREATER ? "19.35.36" : "17.33.42", true, parent(SPOOF_APP_VERSION));
// Custom filter
public static final BooleanSetting CUSTOM_FILTER = new BooleanSetting("revanced_custom_filter", FALSE);
public static final StringSetting CUSTOM_FILTER_STRINGS = new StringSetting("revanced_custom_filter_strings", "", true, parent(CUSTOM_FILTER));
-
// Navigation buttons
public static final BooleanSetting HIDE_HOME_BUTTON = new BooleanSetting("revanced_hide_home_button", FALSE, true);
public static final BooleanSetting HIDE_CREATE_BUTTON = new BooleanSetting("revanced_hide_create_button", TRUE, true);
@@ -216,71 +218,67 @@ public class Settings extends BaseSettings {
public static final BooleanSetting SWITCH_CREATE_WITH_NOTIFICATIONS_BUTTON = new BooleanSetting("revanced_switch_create_with_notifications_button", TRUE, true);
// Shorts
- public static final BooleanSetting DISABLE_SHORTS_BACKGROUND_PLAYBACK = new BooleanSetting("revanced_shorts_disable_background_playback", FALSE);
public static final BooleanSetting DISABLE_RESUMING_SHORTS_PLAYER = new BooleanSetting("revanced_disable_resuming_shorts_player", FALSE);
+ public static final BooleanSetting DISABLE_SHORTS_BACKGROUND_PLAYBACK = new BooleanSetting("revanced_shorts_disable_background_playback", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_CHANNEL_BAR = new BooleanSetting("revanced_hide_shorts_channel_bar", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_COMMENTS_BUTTON = new BooleanSetting("revanced_hide_shorts_comments_button", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_DISLIKE_BUTTON = new BooleanSetting("revanced_hide_shorts_dislike_button", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_FULL_VIDEO_LINK_LABEL = new BooleanSetting("revanced_hide_shorts_full_video_link_label", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_GREEN_SCREEN_BUTTON = new BooleanSetting("revanced_hide_shorts_green_screen_button", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_HASHTAG_BUTTON = new BooleanSetting("revanced_hide_shorts_hashtag_button", TRUE);
public static final BooleanSetting HIDE_SHORTS_HOME = new BooleanSetting("revanced_hide_shorts_home", FALSE);
- public static final BooleanSetting HIDE_SHORTS_SUBSCRIPTIONS = new BooleanSetting("revanced_hide_shorts_subscriptions", FALSE);
- public static final BooleanSetting HIDE_SHORTS_SEARCH = new BooleanSetting("revanced_hide_shorts_search", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_INFO_PANEL = new BooleanSetting("revanced_hide_shorts_info_panel", TRUE);
public static final BooleanSetting HIDE_SHORTS_JOIN_BUTTON = new BooleanSetting("revanced_hide_shorts_join_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_SUBSCRIBE_BUTTON = new BooleanSetting("revanced_hide_shorts_subscribe_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_PAUSED_OVERLAY_BUTTONS = new BooleanSetting("revanced_hide_shorts_paused_overlay_buttons", FALSE);
- public static final BooleanSetting HIDE_SHORTS_SHOP_BUTTON = new BooleanSetting("revanced_hide_shorts_shop_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_TAGGED_PRODUCTS = new BooleanSetting("revanced_hide_shorts_tagged_products", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_LIKE_BUTTON = new BooleanSetting("revanced_hide_shorts_like_button", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_LIKE_FOUNTAIN = new BooleanSetting("revanced_hide_shorts_like_fountain", TRUE);
public static final BooleanSetting HIDE_SHORTS_LOCATION_LABEL = new BooleanSetting("revanced_hide_shorts_location_label", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_NAVIGATION_BAR = new BooleanSetting("revanced_hide_shorts_navigation_bar", FALSE, true);
+ public static final BooleanSetting HIDE_SHORTS_PAUSED_OVERLAY_BUTTONS = new BooleanSetting("revanced_hide_shorts_paused_overlay_buttons", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_REMIX_BUTTON = new BooleanSetting("revanced_hide_shorts_remix_button", TRUE);
public static final BooleanSetting HIDE_SHORTS_SAVE_SOUND_BUTTON = new BooleanSetting("revanced_hide_shorts_save_sound_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_USE_TEMPLATE_BUTTON = new BooleanSetting("revanced_hide_shorts_use_template_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_UPCOMING_BUTTON = new BooleanSetting("revanced_hide_shorts_upcoming_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_GREEN_SCREEN_BUTTON = new BooleanSetting("revanced_hide_shorts_green_screen_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_HASHTAG_BUTTON = new BooleanSetting("revanced_hide_shorts_hashtag_button", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_SEARCH = new BooleanSetting("revanced_hide_shorts_search", FALSE);
public static final BooleanSetting HIDE_SHORTS_SEARCH_SUGGESTIONS = new BooleanSetting("revanced_hide_shorts_search_suggestions", TRUE);
- public static final BooleanSetting HIDE_SHORTS_STICKERS = new BooleanSetting("revanced_hide_shorts_stickers", TRUE);
- public static final BooleanSetting HIDE_SHORTS_SUPER_THANKS_BUTTON = new BooleanSetting("revanced_hide_shorts_super_thanks_button", TRUE);
- public static final BooleanSetting HIDE_SHORTS_LIKE_FOUNTAIN = new BooleanSetting("revanced_hide_shorts_like_fountain", TRUE);
- public static final BooleanSetting HIDE_SHORTS_LIKE_BUTTON = new BooleanSetting("revanced_hide_shorts_like_button", FALSE);
- public static final BooleanSetting HIDE_SHORTS_DISLIKE_BUTTON = new BooleanSetting("revanced_hide_shorts_dislike_button", FALSE);
- public static final BooleanSetting HIDE_SHORTS_COMMENTS_BUTTON = new BooleanSetting("revanced_hide_shorts_comments_button", FALSE);
- public static final BooleanSetting HIDE_SHORTS_REMIX_BUTTON = new BooleanSetting("revanced_hide_shorts_remix_button", TRUE);
public static final BooleanSetting HIDE_SHORTS_SHARE_BUTTON = new BooleanSetting("revanced_hide_shorts_share_button", FALSE);
- public static final BooleanSetting HIDE_SHORTS_INFO_PANEL = new BooleanSetting("revanced_hide_shorts_info_panel", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_SHOP_BUTTON = new BooleanSetting("revanced_hide_shorts_shop_button", TRUE);
public static final BooleanSetting HIDE_SHORTS_SOUND_BUTTON = new BooleanSetting("revanced_hide_shorts_sound_button", FALSE);
- public static final BooleanSetting HIDE_SHORTS_CHANNEL_BAR = new BooleanSetting("revanced_hide_shorts_channel_bar", FALSE);
- public static final BooleanSetting HIDE_SHORTS_VIDEO_TITLE = new BooleanSetting("revanced_hide_shorts_video_title", FALSE);
public static final BooleanSetting HIDE_SHORTS_SOUND_METADATA_LABEL = new BooleanSetting("revanced_hide_shorts_sound_metadata_label", FALSE);
- public static final BooleanSetting HIDE_SHORTS_FULL_VIDEO_LINK_LABEL = new BooleanSetting("revanced_hide_shorts_full_video_link_label", FALSE);
- public static final BooleanSetting HIDE_SHORTS_NAVIGATION_BAR = new BooleanSetting("revanced_hide_shorts_navigation_bar", FALSE, true);
+ public static final BooleanSetting HIDE_SHORTS_STICKERS = new BooleanSetting("revanced_hide_shorts_stickers", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_SUBSCRIBE_BUTTON = new BooleanSetting("revanced_hide_shorts_subscribe_button", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_SUBSCRIPTIONS = new BooleanSetting("revanced_hide_shorts_subscriptions", FALSE);
+ public static final BooleanSetting HIDE_SHORTS_SUPER_THANKS_BUTTON = new BooleanSetting("revanced_hide_shorts_super_thanks_button", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_TAGGED_PRODUCTS = new BooleanSetting("revanced_hide_shorts_tagged_products", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_UPCOMING_BUTTON = new BooleanSetting("revanced_hide_shorts_upcoming_button", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_USE_TEMPLATE_BUTTON = new BooleanSetting("revanced_hide_shorts_use_template_button", TRUE);
+ public static final BooleanSetting HIDE_SHORTS_VIDEO_TITLE = new BooleanSetting("revanced_hide_shorts_video_title", FALSE);
public static final BooleanSetting SHORTS_AUTOPLAY = new BooleanSetting("revanced_shorts_autoplay", FALSE);
public static final BooleanSetting SHORTS_AUTOPLAY_BACKGROUND = new BooleanSetting("revanced_shorts_autoplay_background", TRUE);
// Seekbar
+
public static final BooleanSetting DISABLE_PRECISE_SEEKING_GESTURE = new BooleanSetting("revanced_disable_precise_seeking_gesture", TRUE);
- public static final BooleanSetting SEEKBAR_TAPPING = new BooleanSetting("revanced_seekbar_tapping", TRUE);
- public static final BooleanSetting SLIDE_TO_SEEK = new BooleanSetting("revanced_slide_to_seek", FALSE, true);
- public static final BooleanSetting RESTORE_OLD_SEEKBAR_THUMBNAILS = new BooleanSetting("revanced_restore_old_seekbar_thumbnails", TRUE);
- public static final BooleanSetting SEEKBAR_THUMBNAILS_HIGH_QUALITY = new BooleanSetting("revanced_seekbar_thumbnails_high_quality", FALSE, true,
- "revanced_seekbar_thumbnails_high_quality_dialog_message", new SeekbarThumbnailsHighQualityAvailability());
public static final BooleanSetting HIDE_SEEKBAR = new BooleanSetting("revanced_hide_seekbar", FALSE, true);
public static final BooleanSetting HIDE_SEEKBAR_THUMBNAIL = new BooleanSetting("revanced_hide_seekbar_thumbnail", FALSE);
+ public static final BooleanSetting HIDE_TIMESTAMP = new BooleanSetting("revanced_hide_timestamp", FALSE);
+ public static final BooleanSetting RESTORE_OLD_SEEKBAR_THUMBNAILS = new BooleanSetting("revanced_restore_old_seekbar_thumbnails", TRUE);
public static final BooleanSetting SEEKBAR_CUSTOM_COLOR = new BooleanSetting("revanced_seekbar_custom_color", FALSE, true);
+ public static final BooleanSetting SEEKBAR_TAPPING = new BooleanSetting("revanced_seekbar_tapping", TRUE);
+ public static final BooleanSetting SEEKBAR_THUMBNAILS_HIGH_QUALITY = new BooleanSetting("revanced_seekbar_thumbnails_high_quality", FALSE, true,
+ "revanced_seekbar_thumbnails_high_quality_dialog_message", new SeekbarThumbnailsHighQualityAvailability());
+ public static final BooleanSetting SLIDE_TO_SEEK = new BooleanSetting("revanced_slide_to_seek", FALSE, true);
public static final StringSetting SEEKBAR_CUSTOM_COLOR_VALUE = new StringSetting("revanced_seekbar_custom_color_value", "#FF0033", true, parent(SEEKBAR_CUSTOM_COLOR));
// Misc
+ public static final BooleanSetting ANNOUNCEMENTS = new BooleanSetting("revanced_announcements", TRUE);
+ public static final IntegerSetting ANNOUNCEMENT_LAST_ID = new IntegerSetting("revanced_announcement_last_id", -1, false, false);
public static final BooleanSetting AUTO_CAPTIONS = new BooleanSetting("revanced_auto_captions", FALSE);
- public static final BooleanSetting DISABLE_ZOOM_HAPTICS = new BooleanSetting("revanced_disable_zoom_haptics", TRUE);
- public static final BooleanSetting EXTERNAL_BROWSER = new BooleanSetting("revanced_external_browser", TRUE, true);
public static final BooleanSetting AUTO_REPEAT = new BooleanSetting("revanced_auto_repeat", FALSE);
- public static final BooleanSetting SPOOF_DEVICE_DIMENSIONS = new BooleanSetting("revanced_spoof_device_dimensions", FALSE, true,
- "revanced_spoof_device_dimensions_user_dialog_message");
public static final BooleanSetting BYPASS_URL_REDIRECTS = new BooleanSetting("revanced_bypass_url_redirects", TRUE);
- public static final BooleanSetting ANNOUNCEMENTS = new BooleanSetting("revanced_announcements", TRUE);
- public static final BooleanSetting SPOOF_VIDEO_STREAMS = new BooleanSetting("revanced_spoof_video_streams", TRUE, true,"revanced_spoof_video_streams_user_dialog_message");
- public static final BooleanSetting SPOOF_VIDEO_STREAMS_IOS_FORCE_AVC = new BooleanSetting("revanced_spoof_video_streams_ios_force_avc", FALSE, true,
- "revanced_spoof_video_streams_ios_force_avc_user_dialog_message", new SpoofVideoStreamsPatch.ForceiOSAVCAvailability());
- public static final EnumSetting SPOOF_VIDEO_STREAMS_CLIENT_TYPE = new EnumSetting<>("revanced_spoof_video_streams_client", ClientType.ANDROID_VR, true, parent(SPOOF_VIDEO_STREAMS));
- public static final IntegerSetting ANNOUNCEMENT_LAST_ID = new IntegerSetting("revanced_announcement_last_id", -1, false, false);
public static final BooleanSetting CHECK_WATCH_HISTORY_DOMAIN_NAME = new BooleanSetting("revanced_check_watch_history_domain_name", TRUE, false, false);
+ public static final BooleanSetting DISABLE_ZOOM_HAPTICS = new BooleanSetting("revanced_disable_zoom_haptics", TRUE);
+ public static final BooleanSetting EXTERNAL_BROWSER = new BooleanSetting("revanced_external_browser", TRUE, true);
public static final BooleanSetting REMOVE_TRACKING_QUERY_PARAMETER = new BooleanSetting("revanced_remove_tracking_query_parameter", TRUE);
-
- // Debugging
+ public static final BooleanSetting SPOOF_DEVICE_DIMENSIONS = new BooleanSetting("revanced_spoof_device_dimensions", FALSE, true,
+ "revanced_spoof_device_dimensions_user_dialog_message");
/**
* When enabled, share the debug logs with care.
* The buffer contains select user data, including the client ip address and information that could identify the end user.
@@ -298,6 +296,8 @@ public class Settings extends BaseSettings {
parentsAny(SWIPE_BRIGHTNESS, SWIPE_VOLUME));
public static final IntegerSetting SWIPE_OVERLAY_BACKGROUND_ALPHA = new IntegerSetting("revanced_swipe_overlay_background_alpha", 127, true,
parentsAny(SWIPE_BRIGHTNESS, SWIPE_VOLUME));
+
+ // Debugging
public static final IntegerSetting SWIPE_OVERLAY_TEXT_SIZE = new IntegerSetting("revanced_swipe_text_overlay_size", 22, true,
parentsAny(SWIPE_BRIGHTNESS, SWIPE_VOLUME));
public static final LongSetting SWIPE_OVERLAY_TIMEOUT = new LongSetting("revanced_swipe_overlay_timeout", 500L, true,
@@ -320,7 +320,6 @@ public class Settings extends BaseSettings {
* Do not use directly, instead use {@link SponsorBlockSettings}
*/
public static final StringSetting SB_PRIVATE_USER_ID = new StringSetting("sb_private_user_id_Do_Not_Share", "");
- public static final StringSetting DEPRECATED_SB_UUID_OLD_MIGRATION_SETTING = new StringSetting("uuid", ""); // Delete sometime in 2024
public static final IntegerSetting SB_CREATE_NEW_SEGMENT_STEP = new IntegerSetting("sb_create_new_segment_step", 150, parent(SB_ENABLED));
public static final BooleanSetting SB_VOTING_BUTTON = new BooleanSetting("sb_voting_button", FALSE, parent(SB_ENABLED));
public static final BooleanSetting SB_CREATE_NEW_SEGMENT = new BooleanSetting("sb_create_new_segment", FALSE, parent(SB_ENABLED));
@@ -331,34 +330,38 @@ public class Settings extends BaseSettings {
public static final BooleanSetting SB_TRACK_SKIP_COUNT = new BooleanSetting("sb_track_skip_count", TRUE, parent(SB_ENABLED));
public static final FloatSetting SB_SEGMENT_MIN_DURATION = new FloatSetting("sb_min_segment_duration", 0F, parent(SB_ENABLED));
public static final BooleanSetting SB_VIDEO_LENGTH_WITHOUT_SEGMENTS = new BooleanSetting("sb_video_length_without_segments", TRUE, parent(SB_ENABLED));
- public static final StringSetting SB_API_URL = new StringSetting("sb_api_url","https://sponsor.ajay.app");
+ public static final StringSetting SB_API_URL = new StringSetting("sb_api_url", "https://sponsor.ajay.app");
public static final BooleanSetting SB_USER_IS_VIP = new BooleanSetting("sb_user_is_vip", FALSE);
public static final IntegerSetting SB_LOCAL_TIME_SAVED_NUMBER_SEGMENTS = new IntegerSetting("sb_local_time_saved_number_segments", 0);
public static final LongSetting SB_LOCAL_TIME_SAVED_MILLISECONDS = new LongSetting("sb_local_time_saved_milliseconds", 0L);
public static final LongSetting SB_LAST_VIP_CHECK = new LongSetting("sb_last_vip_check", 0L, false, false);
public static final BooleanSetting SB_HIDE_EXPORT_WARNING = new BooleanSetting("sb_hide_export_warning", FALSE, false, false);
public static final BooleanSetting SB_SEEN_GUIDELINES = new BooleanSetting("sb_seen_guidelines", FALSE, false, false);
-
public static final StringSetting SB_CATEGORY_SPONSOR = new StringSetting("sb_sponsor", SKIP_AUTOMATICALLY_ONCE.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_SPONSOR_COLOR = new StringSetting("sb_sponsor_color","#00D400");
+ public static final StringSetting SB_CATEGORY_SPONSOR_COLOR = new StringSetting("sb_sponsor_color", "#00D400");
public static final StringSetting SB_CATEGORY_SELF_PROMO = new StringSetting("sb_selfpromo", MANUAL_SKIP.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_SELF_PROMO_COLOR = new StringSetting("sb_selfpromo_color","#FFFF00");
+ public static final StringSetting SB_CATEGORY_SELF_PROMO_COLOR = new StringSetting("sb_selfpromo_color", "#FFFF00");
public static final StringSetting SB_CATEGORY_INTERACTION = new StringSetting("sb_interaction", MANUAL_SKIP.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_INTERACTION_COLOR = new StringSetting("sb_interaction_color","#CC00FF");
+ public static final StringSetting SB_CATEGORY_INTERACTION_COLOR = new StringSetting("sb_interaction_color", "#CC00FF");
public static final StringSetting SB_CATEGORY_HIGHLIGHT = new StringSetting("sb_highlight", MANUAL_SKIP.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_HIGHLIGHT_COLOR = new StringSetting("sb_highlight_color","#FF1684");
+ public static final StringSetting SB_CATEGORY_HIGHLIGHT_COLOR = new StringSetting("sb_highlight_color", "#FF1684");
public static final StringSetting SB_CATEGORY_INTRO = new StringSetting("sb_intro", MANUAL_SKIP.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_INTRO_COLOR = new StringSetting("sb_intro_color","#00FFFF");
+ public static final StringSetting SB_CATEGORY_INTRO_COLOR = new StringSetting("sb_intro_color", "#00FFFF");
public static final StringSetting SB_CATEGORY_OUTRO = new StringSetting("sb_outro", MANUAL_SKIP.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_OUTRO_COLOR = new StringSetting("sb_outro_color","#0202ED");
+ public static final StringSetting SB_CATEGORY_OUTRO_COLOR = new StringSetting("sb_outro_color", "#0202ED");
public static final StringSetting SB_CATEGORY_PREVIEW = new StringSetting("sb_preview", IGNORE.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_PREVIEW_COLOR = new StringSetting("sb_preview_color","#008FD6");
+ public static final StringSetting SB_CATEGORY_PREVIEW_COLOR = new StringSetting("sb_preview_color", "#008FD6");
public static final StringSetting SB_CATEGORY_FILLER = new StringSetting("sb_filler", IGNORE.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_FILLER_COLOR = new StringSetting("sb_filler_color","#7300FF");
+ public static final StringSetting SB_CATEGORY_FILLER_COLOR = new StringSetting("sb_filler_color", "#7300FF");
public static final StringSetting SB_CATEGORY_MUSIC_OFFTOPIC = new StringSetting("sb_music_offtopic", MANUAL_SKIP.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_MUSIC_OFFTOPIC_COLOR = new StringSetting("sb_music_offtopic_color","#FF9900");
+ public static final StringSetting SB_CATEGORY_MUSIC_OFFTOPIC_COLOR = new StringSetting("sb_music_offtopic_color", "#FF9900");
public static final StringSetting SB_CATEGORY_UNSUBMITTED = new StringSetting("sb_unsubmitted", SKIP_AUTOMATICALLY.reVancedKeyValue);
- public static final StringSetting SB_CATEGORY_UNSUBMITTED_COLOR = new StringSetting("sb_unsubmitted_color","#FFFFFF");
+ public static final StringSetting SB_CATEGORY_UNSUBMITTED_COLOR = new StringSetting("sb_unsubmitted_color", "#FFFFFF");
+
+ // Deprecated migrations
+ public static final StringSetting DEPRECATED_SB_UUID_OLD_MIGRATION_SETTING = new StringSetting("uuid", ""); // Delete sometime in 2024
+ private static final BooleanSetting DEPRECATED_HIDE_PLAYER_BUTTONS = new BooleanSetting("revanced_hide_player_buttons", FALSE, true);
+ private static final BooleanSetting DEPRECATED_HIDE_PLAYER_FLYOUT_VIDEO_QUALITY_FOOTER = new BooleanSetting("revanced_hide_video_quality_menu_footer", FALSE);
static {
// region Migration
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ForceAVCSpoofingPreference.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ForceAVCSpoofingPreference.java
deleted file mode 100644
index 5581756758..0000000000
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ForceAVCSpoofingPreference.java
+++ /dev/null
@@ -1,61 +0,0 @@
-package app.revanced.extension.youtube.settings.preference;
-
-import static app.revanced.extension.shared.StringRef.str;
-import static app.revanced.extension.youtube.patches.spoof.DeviceHardwareSupport.DEVICE_HAS_HARDWARE_DECODING_VP9;
-
-import android.content.Context;
-import android.preference.SwitchPreference;
-import android.util.AttributeSet;
-
-@SuppressWarnings({"unused", "deprecation"})
-public class ForceAVCSpoofingPreference extends SwitchPreference {
- {
- if (!DEVICE_HAS_HARDWARE_DECODING_VP9) {
- setSummaryOn(str("revanced_spoof_video_streams_ios_force_avc_no_hardware_vp9_summary_on"));
- }
- }
-
- public ForceAVCSpoofingPreference(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
- super(context, attrs, defStyleAttr, defStyleRes);
- }
- public ForceAVCSpoofingPreference(Context context, AttributeSet attrs, int defStyleAttr) {
- super(context, attrs, defStyleAttr);
- }
- public ForceAVCSpoofingPreference(Context context, AttributeSet attrs) {
- super(context, attrs);
- }
- public ForceAVCSpoofingPreference(Context context) {
- super(context);
- }
-
- private void updateUI() {
- if (DEVICE_HAS_HARDWARE_DECODING_VP9) {
- return;
- }
-
- // Temporarily remove the preference key to allow changing this preference without
- // causing the settings UI listeners from showing reboot dialogs by the changes made here.
- String key = getKey();
- setKey(null);
-
- // This setting cannot be changed by the user.
- super.setEnabled(false);
- super.setChecked(true);
-
- setKey(key);
- }
-
- @Override
- public void setEnabled(boolean enabled) {
- super.setEnabled(enabled);
-
- updateUI();
- }
-
- @Override
- public void setChecked(boolean checked) {
- super.setChecked(checked);
-
- updateUI();
- }
-}
diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ReVancedPreferenceFragment.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ReVancedPreferenceFragment.java
index 9e6cdeeeb7..ed4502aef4 100644
--- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ReVancedPreferenceFragment.java
+++ b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/ReVancedPreferenceFragment.java
@@ -10,6 +10,7 @@
import android.preference.ListPreference;
import android.preference.Preference;
import android.preference.PreferenceScreen;
+import android.util.Pair;
import android.util.TypedValue;
import android.view.ViewGroup;
import android.view.WindowInsets;
@@ -18,6 +19,10 @@
import androidx.annotation.RequiresApi;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
import app.revanced.extension.shared.Logger;
import app.revanced.extension.shared.Utils;
import app.revanced.extension.shared.settings.preference.AbstractPreferenceFragment;
@@ -41,6 +46,46 @@ public static Drawable getBackButtonDrawable() {
return Utils.getContext().getResources().getDrawable(backButtonResource);
}
+ /**
+ * Sorts a preference list by menu entries, but preserves the first value as the first entry.
+ */
+ private static void sortListPreferenceByValues(ListPreference listPreference) {
+ CharSequence[] entries = listPreference.getEntries();
+ CharSequence[] entryValues = listPreference.getEntryValues();
+ final int entrySize = entries.length;
+
+ if (entrySize != entryValues.length) {
+ throw new IllegalStateException();
+ }
+
+ // Ensure the first entry remains the first after sorting.
+ CharSequence firstEntry = entries[0];
+ CharSequence firstEntryValue = entryValues[0];
+
+ List> entryPairs = new ArrayList<>(entrySize);
+ for (int i = 1; i < entrySize; i++) {
+ entryPairs.add(new Pair<>(entries[i].toString(), entryValues[i].toString()));
+ }
+
+ Collections.sort(entryPairs, (pair1, pair2) -> pair1.first.compareToIgnoreCase(pair2.first));
+
+ CharSequence[] sortedEntries = new CharSequence[entrySize];
+ CharSequence[] sortedEntryValues = new CharSequence[entrySize];
+
+ sortedEntries[0] = firstEntry;
+ sortedEntryValues[0] = firstEntryValue;
+
+ int i = 1;
+ for (Pair pair : entryPairs) {
+ sortedEntries[i] = pair.first;
+ sortedEntryValues[i] = pair.second;
+ i++;
+ }
+
+ listPreference.setEntries(sortedEntries);
+ listPreference.setEntryValues(sortedEntryValues);
+ }
+
@RequiresApi(api = Build.VERSION_CODES.O)
@Override
protected void initialize() {
@@ -50,9 +95,14 @@ protected void initialize() {
setPreferenceScreenToolbar(getPreferenceScreen());
// If the preference was included, then initialize it based on the available playback speed.
- Preference defaultSpeedPreference = findPreference(Settings.PLAYBACK_SPEED_DEFAULT.key);
- if (defaultSpeedPreference instanceof ListPreference) {
- CustomPlaybackSpeedPatch.initializeListPreference((ListPreference) defaultSpeedPreference);
+ Preference preference = findPreference(Settings.PLAYBACK_SPEED_DEFAULT.key);
+ if (preference instanceof ListPreference playbackPreference) {
+ CustomPlaybackSpeedPatch.initializeListPreference(playbackPreference);
+ }
+
+ preference = findPreference(Settings.SPOOF_VIDEO_STREAMS_LANGUAGE.key);
+ if (preference instanceof ListPreference languagePreference) {
+ sortListPreferenceByValues(languagePreference);
}
} catch (Exception ex) {
Logger.printException(() -> "initialize failure", ex);
diff --git a/gradle.properties b/gradle.properties
index 36f565f893..7cfad748fa 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -3,4 +3,4 @@ org.gradle.jvmargs = -Xms512M -Xmx2048M
org.gradle.parallel = true
android.useAndroidX = true
kotlin.code.style = official
-version = 5.2.3
+version = 5.3.0-dev.7
diff --git a/patches/api/patches.api b/patches/api/patches.api
index 1c601b5515..36a925df87 100644
--- a/patches/api/patches.api
+++ b/patches/api/patches.api
@@ -320,6 +320,10 @@ public final class app/revanced/patches/music/misc/gms/GmsCoreSupportPatchKt {
public static final fun getGmsCoreSupportPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
}
+public final class app/revanced/patches/music/misc/spoof/SpoofVideoStreamsPatchKt {
+ public static final fun getSpoofVideoStreamsPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
+}
+
public final class app/revanced/patches/myexpenses/misc/pro/UnlockProPatchKt {
public static final fun getUnlockProPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
}
@@ -753,6 +757,11 @@ public final class app/revanced/patches/shared/misc/settings/preference/TextPref
public fun serialize (Lorg/w3c/dom/Document;Lkotlin/jvm/functions/Function1;)Lorg/w3c/dom/Element;
}
+public final class app/revanced/patches/shared/misc/spoof/SpoofVideoStreamsPatchKt {
+ public static final fun spoofVideoStreamsPatch (Lkotlin/jvm/functions/Function1;Lkotlin/jvm/functions/Function1;)Lapp/revanced/patcher/patch/BytecodePatch;
+ public static synthetic fun spoofVideoStreamsPatch$default (Lkotlin/jvm/functions/Function1;Lkotlin/jvm/functions/Function1;ILjava/lang/Object;)Lapp/revanced/patcher/patch/BytecodePatch;
+}
+
public final class app/revanced/patches/solidexplorer2/functionality/filesize/RemoveFileSizeLimitPatchKt {
public static final fun getRemoveFileSizeLimitPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
}
@@ -1155,6 +1164,10 @@ public final class app/revanced/patches/youtube/layout/player/background/PlayerC
public static final fun getPlayerControlsBackgroundPatch ()Lapp/revanced/patcher/patch/ResourcePatch;
}
+public final class app/revanced/patches/youtube/layout/player/fullscreen/OpenVideosFullscreenKt {
+ public static final fun getOpenVideosFullscreenPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
+}
+
public final class app/revanced/patches/youtube/layout/player/overlay/CustomPlayerOverlayOpacityPatchKt {
public static final fun getCustomPlayerOverlayOpacityPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
}
@@ -1359,6 +1372,14 @@ public final class app/revanced/patches/youtube/misc/settings/SettingsPatchKt {
public static final fun newIntent (Ljava/lang/String;)Lapp/revanced/patches/shared/misc/settings/preference/IntentPreference$Intent;
}
+public final class app/revanced/patches/youtube/misc/spoof/SpoofVideoStreamsPatchKt {
+ public static final fun getSpoofVideoStreamsPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
+}
+
+public final class app/revanced/patches/youtube/misc/spoof/UserAgentClientSpoofPatchKt {
+ public static final fun getUserAgentClientSpoofPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
+}
+
public final class app/revanced/patches/youtube/misc/zoomhaptics/ZoomHapticsPatchKt {
public static final fun getZoomHapticsPatch ()Lapp/revanced/patcher/patch/BytecodePatch;
}
diff --git a/patches/src/main/kotlin/app/revanced/patches/all/misc/packagename/ChangePackageNamePatch.kt b/patches/src/main/kotlin/app/revanced/patches/all/misc/packagename/ChangePackageNamePatch.kt
index 48f9516335..4c0bd71b27 100644
--- a/patches/src/main/kotlin/app/revanced/patches/all/misc/packagename/ChangePackageNamePatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/all/misc/packagename/ChangePackageNamePatch.kt
@@ -4,6 +4,7 @@ import app.revanced.patcher.patch.Option
import app.revanced.patcher.patch.resourcePatch
import app.revanced.patcher.patch.stringOption
import org.w3c.dom.Element
+import java.util.logging.Logger
lateinit var packageNameOption: Option
@@ -41,18 +42,38 @@ val changePackageNamePatch = resourcePatch(
it == "Default" || it!!.matches(Regex("^[a-z]\\w*(\\.[a-z]\\w*)+\$"))
}
+ /**
+ * Apps that are confirmed to not work correctly with this patch.
+ * This is not an exhaustive list, and is only the apps with
+ * ReVanced specific patches and are confirmed incompatible with this patch.
+ */
+ val incompatibleAppPackages = setOf(
+ // Cannot login, settings menu is broken.
+ "com.reddit.frontpage",
+
+ // Patches and installs but crashes on launch.
+ "com.duolingo",
+ "com.twitter.android",
+ "tv.twitch.android.app",
+ )
+
finalize {
document("AndroidManifest.xml").use { document ->
+ val manifest = document.getElementsByTagName("manifest").item(0) as Element
+ val originalPackageName = manifest.getAttribute("package")
- val replacementPackageName = packageNameOption.value
+ if (incompatibleAppPackages.contains(originalPackageName)) {
+ return@finalize Logger.getLogger(this::class.java.name).severe(
+ "'$originalPackageName' does not work correctly with \"Change package name\"")
+ }
- val manifest = document.getElementsByTagName("manifest").item(0) as Element
+ val replacementPackageName = packageNameOption.value
manifest.setAttribute(
"package",
if (replacementPackageName != packageNameOption.default) {
replacementPackageName
} else {
- "${manifest.getAttribute("package")}.revanced"
+ "${originalPackageName}.revanced"
},
)
}
diff --git a/patches/src/main/kotlin/app/revanced/patches/music/interaction/permanentshuffle/PermanentShufflePatch.kt b/patches/src/main/kotlin/app/revanced/patches/music/interaction/permanentshuffle/PermanentShufflePatch.kt
index 8d044de2c2..e27749495b 100644
--- a/patches/src/main/kotlin/app/revanced/patches/music/interaction/permanentshuffle/PermanentShufflePatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/music/interaction/permanentshuffle/PermanentShufflePatch.kt
@@ -3,9 +3,9 @@ package app.revanced.patches.music.interaction.permanentshuffle
import app.revanced.patcher.extensions.InstructionExtensions.addInstruction
import app.revanced.patcher.patch.bytecodePatch
+@Deprecated("This patch no longer works and will be removed in the future.")
@Suppress("unused")
val permanentShufflePatch = bytecodePatch(
- name = "Permanent shuffle",
description = "Permanently remember your shuffle preference " +
"even if the playlist ends or another track is played.",
use = false,
diff --git a/patches/src/main/kotlin/app/revanced/patches/music/misc/gms/GmsCoreSupportPatch.kt b/patches/src/main/kotlin/app/revanced/patches/music/misc/gms/GmsCoreSupportPatch.kt
index e38ca6015c..0fa223b235 100644
--- a/patches/src/main/kotlin/app/revanced/patches/music/misc/gms/GmsCoreSupportPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/music/misc/gms/GmsCoreSupportPatch.kt
@@ -4,6 +4,7 @@ import app.revanced.patcher.patch.Option
import app.revanced.patches.music.misc.extension.sharedExtensionPatch
import app.revanced.patches.music.misc.gms.Constants.MUSIC_PACKAGE_NAME
import app.revanced.patches.music.misc.gms.Constants.REVANCED_MUSIC_PACKAGE_NAME
+import app.revanced.patches.music.misc.spoof.spoofVideoStreamsPatch
import app.revanced.patches.shared.castContextFetchFingerprint
import app.revanced.patches.shared.misc.gms.gmsCoreSupportPatch
import app.revanced.patches.shared.primeMethodFingerprint
@@ -20,6 +21,8 @@ val gmsCoreSupportPatch = gmsCoreSupportPatch(
extensionPatch = sharedExtensionPatch,
gmsCoreSupportResourcePatchFactory = ::gmsCoreSupportResourcePatch,
) {
+ dependsOn(spoofVideoStreamsPatch)
+
compatibleWith(MUSIC_PACKAGE_NAME)
}
diff --git a/patches/src/main/kotlin/app/revanced/patches/music/misc/spoof/SpoofVideoStreamsPatch.kt b/patches/src/main/kotlin/app/revanced/patches/music/misc/spoof/SpoofVideoStreamsPatch.kt
new file mode 100644
index 0000000000..862bc3f227
--- /dev/null
+++ b/patches/src/main/kotlin/app/revanced/patches/music/misc/spoof/SpoofVideoStreamsPatch.kt
@@ -0,0 +1,7 @@
+package app.revanced.patches.music.misc.spoof
+
+import app.revanced.patches.shared.misc.spoof.spoofVideoStreamsPatch
+
+val spoofVideoStreamsPatch = spoofVideoStreamsPatch({
+ compatibleWith("com.google.android.apps.youtube.music")
+})
diff --git a/patches/src/main/kotlin/app/revanced/patches/nyx/misc/pro/UnlockProPatch.kt b/patches/src/main/kotlin/app/revanced/patches/nyx/misc/pro/UnlockProPatch.kt
index 65040b32a3..179e745e08 100644
--- a/patches/src/main/kotlin/app/revanced/patches/nyx/misc/pro/UnlockProPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/nyx/misc/pro/UnlockProPatch.kt
@@ -3,10 +3,9 @@ package app.revanced.patches.nyx.misc.pro
import app.revanced.patcher.extensions.InstructionExtensions.addInstructions
import app.revanced.patcher.patch.bytecodePatch
+@Deprecated("This patch will be removed in the future.")
@Suppress("unused")
-val unlockProPatch = bytecodePatch(
- name = "Unlock pro",
-) {
+val unlockProPatch = bytecodePatch {
compatibleWith("com.awedea.nyx")
execute {
diff --git a/patches/src/main/kotlin/app/revanced/patches/reddit/customclients/sync/syncforreddit/extension/SharedExtensionPatch.kt b/patches/src/main/kotlin/app/revanced/patches/reddit/customclients/sync/syncforreddit/extension/SharedExtensionPatch.kt
index 7f50bdf7ef..e5eeaef21c 100644
--- a/patches/src/main/kotlin/app/revanced/patches/reddit/customclients/sync/syncforreddit/extension/SharedExtensionPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/reddit/customclients/sync/syncforreddit/extension/SharedExtensionPatch.kt
@@ -3,4 +3,4 @@ package app.revanced.patches.reddit.customclients.sync.syncforreddit.extension
import app.revanced.patches.reddit.customclients.sync.syncforreddit.extension.hooks.initHook
import app.revanced.patches.shared.misc.extension.sharedExtensionPatch
-val sharedExtensionPatch = sharedExtensionPatch("sync", initHook)
+val sharedExtensionPatch = sharedExtensionPatch("syncforreddit", initHook)
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/Fingerprints.kt b/patches/src/main/kotlin/app/revanced/patches/shared/misc/spoof/Fingerprints.kt
similarity index 97%
rename from patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/Fingerprints.kt
rename to patches/src/main/kotlin/app/revanced/patches/shared/misc/spoof/Fingerprints.kt
index 1862a79aa8..3976d03e7e 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/Fingerprints.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/shared/misc/spoof/Fingerprints.kt
@@ -1,4 +1,4 @@
-package app.revanced.patches.youtube.misc.fix.playback
+package app.revanced.patches.shared.misc.spoof
import app.revanced.patcher.fingerprint
import com.android.tools.smali.dexlib2.AccessFlags
@@ -27,7 +27,6 @@ internal val buildPlayerRequestURIFingerprint = fingerprint {
Opcode.RETURN_OBJECT,
)
strings(
- "youtubei/v1",
"key",
"asig",
)
diff --git a/patches/src/main/kotlin/app/revanced/patches/shared/misc/spoof/SpoofVideoStreamsPatch.kt b/patches/src/main/kotlin/app/revanced/patches/shared/misc/spoof/SpoofVideoStreamsPatch.kt
new file mode 100644
index 0000000000..0e9e831261
--- /dev/null
+++ b/patches/src/main/kotlin/app/revanced/patches/shared/misc/spoof/SpoofVideoStreamsPatch.kt
@@ -0,0 +1,206 @@
+package app.revanced.patches.shared.misc.spoof
+
+import app.revanced.patcher.extensions.InstructionExtensions.addInstruction
+import app.revanced.patcher.extensions.InstructionExtensions.addInstructions
+import app.revanced.patcher.extensions.InstructionExtensions.addInstructionsWithLabels
+import app.revanced.patcher.extensions.InstructionExtensions.getInstruction
+import app.revanced.patcher.extensions.InstructionExtensions.instructions
+import app.revanced.patcher.patch.BytecodePatchBuilder
+import app.revanced.patcher.patch.BytecodePatchContext
+import app.revanced.patcher.patch.bytecodePatch
+import app.revanced.patcher.util.proxy.mutableTypes.MutableMethod.Companion.toMutable
+import app.revanced.patches.all.misc.resources.addResourcesPatch
+import app.revanced.util.getReference
+import app.revanced.util.indexOfFirstInstructionOrThrow
+import com.android.tools.smali.dexlib2.AccessFlags
+import com.android.tools.smali.dexlib2.Opcode
+import com.android.tools.smali.dexlib2.builder.MutableMethodImplementation
+import com.android.tools.smali.dexlib2.iface.instruction.FiveRegisterInstruction
+import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
+import com.android.tools.smali.dexlib2.iface.instruction.TwoRegisterInstruction
+import com.android.tools.smali.dexlib2.iface.reference.FieldReference
+import com.android.tools.smali.dexlib2.iface.reference.MethodReference
+import com.android.tools.smali.dexlib2.immutable.ImmutableMethod
+import com.android.tools.smali.dexlib2.immutable.ImmutableMethodParameter
+
+private const val EXTENSION_CLASS_DESCRIPTOR =
+ "Lapp/revanced/extension/shared/spoof/SpoofVideoStreamsPatch;"
+
+fun spoofVideoStreamsPatch(
+ block: BytecodePatchBuilder.() -> Unit = {},
+ executeBlock: BytecodePatchContext.() -> Unit = {},
+) = bytecodePatch(
+ name = "Spoof video streams",
+ description = "Spoofs the client video streams to fix playback.",
+) {
+ block()
+
+ dependsOn(addResourcesPatch)
+
+ execute {
+ // region Block /initplayback requests to fall back to /get_watch requests.
+
+ val moveUriStringIndex = buildInitPlaybackRequestFingerprint.patternMatch!!.startIndex
+
+ buildInitPlaybackRequestFingerprint.method.apply {
+ val targetRegister = getInstruction(moveUriStringIndex).registerA
+
+ addInstructions(
+ moveUriStringIndex + 1,
+ """
+ invoke-static { v$targetRegister }, $EXTENSION_CLASS_DESCRIPTOR->blockInitPlaybackRequest(Ljava/lang/String;)Ljava/lang/String;
+ move-result-object v$targetRegister
+ """,
+ )
+ }
+
+ // endregion
+
+ // region Block /get_watch requests to fall back to /player requests.
+
+ val invokeToStringIndex = buildPlayerRequestURIFingerprint.patternMatch!!.startIndex
+
+ buildPlayerRequestURIFingerprint.method.apply {
+ val uriRegister = getInstruction(invokeToStringIndex).registerC
+
+ addInstructions(
+ invokeToStringIndex,
+ """
+ invoke-static { v$uriRegister }, $EXTENSION_CLASS_DESCRIPTOR->blockGetWatchRequest(Landroid/net/Uri;)Landroid/net/Uri;
+ move-result-object v$uriRegister
+ """,
+ )
+ }
+
+ // endregion
+
+ // region Get replacement streams at player requests.
+
+ buildRequestFingerprint.method.apply {
+ val newRequestBuilderIndex = indexOfFirstInstructionOrThrow {
+ opcode == Opcode.INVOKE_VIRTUAL &&
+ getReference()?.name == "newUrlRequestBuilder"
+ }
+ val urlRegister = getInstruction(newRequestBuilderIndex).registerD
+ val freeRegister = getInstruction(newRequestBuilderIndex + 1).registerA
+
+ addInstructions(
+ newRequestBuilderIndex,
+ """
+ move-object v$freeRegister, p1
+ invoke-static { v$urlRegister, v$freeRegister }, $EXTENSION_CLASS_DESCRIPTOR->fetchStreams(Ljava/lang/String;Ljava/util/Map;)V
+ """,
+ )
+ }
+
+ // endregion
+
+ // region Replace the streaming data with the replacement streams.
+
+ createStreamingDataFingerprint.method.apply {
+ val setStreamDataMethodName = "patch_setStreamingData"
+ val resultMethodType = createStreamingDataFingerprint.classDef.type
+ val videoDetailsIndex = createStreamingDataFingerprint.patternMatch!!.endIndex
+ val videoDetailsRegister = getInstruction(videoDetailsIndex).registerA
+ val videoDetailsClass = getInstruction(videoDetailsIndex).getReference()!!.type
+
+ addInstruction(
+ videoDetailsIndex + 1,
+ "invoke-direct { p0, v$videoDetailsRegister }, " +
+ "$resultMethodType->$setStreamDataMethodName($videoDetailsClass)V",
+ )
+
+ val protobufClass = protobufClassParseByteBufferFingerprint.method.definingClass
+ val setStreamingDataIndex = createStreamingDataFingerprint.patternMatch!!.startIndex
+
+ val playerProtoClass = getInstruction(setStreamingDataIndex + 1)
+ .getReference()!!.definingClass
+
+ val setStreamingDataField = getInstruction(setStreamingDataIndex).getReference()
+
+ val getStreamingDataField = getInstruction(
+ indexOfFirstInstructionOrThrow {
+ opcode == Opcode.IGET_OBJECT && getReference()?.definingClass == playerProtoClass
+ },
+ ).getReference()
+
+ // Use a helper method to avoid the need of picking out multiple free registers from the hooked code.
+ createStreamingDataFingerprint.classDef.methods.add(
+ ImmutableMethod(
+ resultMethodType,
+ setStreamDataMethodName,
+ listOf(ImmutableMethodParameter(videoDetailsClass, null, "videoDetails")),
+ "V",
+ AccessFlags.PRIVATE.value or AccessFlags.FINAL.value,
+ null,
+ null,
+ MutableMethodImplementation(9),
+ ).toMutable().apply {
+ addInstructionsWithLabels(
+ 0,
+ """
+ invoke-static { }, $EXTENSION_CLASS_DESCRIPTOR->isSpoofingEnabled()Z
+ move-result v0
+ if-eqz v0, :disabled
+
+ # Get video id.
+ iget-object v2, p1, $videoDetailsClass->c:Ljava/lang/String;
+ if-eqz v2, :disabled
+
+ # Get streaming data.
+ invoke-static { v2 }, $EXTENSION_CLASS_DESCRIPTOR->getStreamingData(Ljava/lang/String;)Ljava/nio/ByteBuffer;
+ move-result-object v3
+ if-eqz v3, :disabled
+
+ # Parse streaming data.
+ sget-object v4, $playerProtoClass->a:$playerProtoClass
+ invoke-static { v4, v3 }, $protobufClass->parseFrom(${protobufClass}Ljava/nio/ByteBuffer;)$protobufClass
+ move-result-object v5
+ check-cast v5, $playerProtoClass
+
+ # Set streaming data.
+ iget-object v6, v5, $getStreamingDataField
+ if-eqz v6, :disabled
+ iput-object v6, p0, $setStreamingDataField
+
+ :disabled
+ return-void
+ """,
+ )
+ },
+ )
+ }
+
+ // endregion
+
+ // region Remove /videoplayback request body to fix playback.
+ // It is assumed, YouTube makes a request with a body tuned for Android.
+ // Requesting streams intended for other platforms with a body tuned for Android could be the cause of 400 errors.
+ // A proper fix may include modifying the request body to match the platforms expected body.
+
+ buildMediaDataSourceFingerprint.method.apply {
+ val targetIndex = instructions.lastIndex
+
+ // Instructions are added just before the method returns,
+ // so there's no concern of clobbering in-use registers.
+ addInstructions(
+ targetIndex,
+ """
+ # Field a: Stream uri.
+ # Field c: Http method.
+ # Field d: Post data.
+ move-object v0, p0 # method has over 15 registers and must copy p0 to a lower register.
+ iget-object v1, v0, $definingClass->a:Landroid/net/Uri;
+ iget v2, v0, $definingClass->c:I
+ iget-object v3, v0, $definingClass->d:[B
+ invoke-static { v1, v2, v3 }, $EXTENSION_CLASS_DESCRIPTOR->removeVideoPlaybackPostBody(Landroid/net/Uri;I[B)[B
+ move-result-object v1
+ iput-object v1, v0, $definingClass->d:[B
+ """,
+ )
+ }
+ // endregion
+
+ executeBlock()
+ }
+}
diff --git a/patches/src/main/kotlin/app/revanced/patches/twitter/misc/hook/json/JsonHookPatch.kt b/patches/src/main/kotlin/app/revanced/patches/twitter/misc/hook/json/JsonHookPatch.kt
index 08d18d3aec..56785cae4c 100644
--- a/patches/src/main/kotlin/app/revanced/patches/twitter/misc/hook/json/JsonHookPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/twitter/misc/hook/json/JsonHookPatch.kt
@@ -5,7 +5,7 @@ import app.revanced.patcher.extensions.InstructionExtensions.removeInstructions
import app.revanced.patcher.patch.BytecodePatchContext
import app.revanced.patcher.patch.PatchException
import app.revanced.patcher.patch.bytecodePatch
-import app.revanced.patches.reddit.misc.extension.sharedExtensionPatch
+import app.revanced.patches.twitter.misc.extension.sharedExtensionPatch
import java.io.InvalidClassException
/**
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/miniplayer/MiniplayerPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/miniplayer/MiniplayerPatch.kt
index 2112c1b40f..57d40a6c52 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/miniplayer/MiniplayerPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/miniplayer/MiniplayerPatch.kt
@@ -240,14 +240,14 @@ val miniplayerPatch = bytecodePatch(
),
)
- fun MutableMethod.insertBooleanOverride(index: Int, methodName: String) {
+ fun MutableMethod.insertMiniplayerBooleanOverride(index: Int, methodName: String) {
val register = getInstruction(index).registerA
addInstructions(
index,
"""
- invoke-static {v$register}, $EXTENSION_CLASS_DESCRIPTOR->$methodName(Z)Z
- move-result v$register
- """,
+ invoke-static {v$register}, $EXTENSION_CLASS_DESCRIPTOR->$methodName(Z)Z
+ move-result v$register
+ """
)
}
@@ -257,29 +257,25 @@ val miniplayerPatch = bytecodePatch(
* Adds an override to force legacy tablet miniplayer to be used or not used.
*/
fun MutableMethod.insertLegacyTabletMiniplayerOverride(index: Int) {
- insertBooleanOverride(index, "getLegacyTabletMiniplayerOverride")
+ insertMiniplayerBooleanOverride(index, "getLegacyTabletMiniplayerOverride")
}
/**
* Adds an override to force modern miniplayer to be used or not used.
*/
fun MutableMethod.insertModernMiniplayerOverride(index: Int) {
- insertBooleanOverride(index, "getModernMiniplayerOverride")
+ insertMiniplayerBooleanOverride(index, "getModernMiniplayerOverride")
}
- fun Fingerprint.insertLiteralValueBooleanOverride(
+ fun Fingerprint.insertMiniplayerFeatureFlagBooleanOverride(
literal: Long,
extensionMethod: String,
- ) {
- method.apply {
- val literalIndex = indexOfFirstLiteralInstructionOrThrow(literal)
- val targetIndex = indexOfFirstInstructionOrThrow(literalIndex, Opcode.MOVE_RESULT)
-
- insertBooleanOverride(targetIndex + 1, extensionMethod)
- }
- }
+ ) = method.insertFeatureFlagBooleanOverride(
+ literal,
+ "$EXTENSION_CLASS_DESCRIPTOR->$extensionMethod(Z)Z"
+ )
- fun Fingerprint.insertLiteralValueFloatOverride(
+ fun Fingerprint.insertMiniplayerFeatureFlagFloatOverride(
literal: Long,
extensionMethod: String,
) {
@@ -370,24 +366,24 @@ val miniplayerPatch = bytecodePatch(
}
if (is_19_23_or_greater) {
- miniplayerModernConstructorFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerModernConstructorFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_DRAG_DROP_FEATURE_KEY,
"enableMiniplayerDragAndDrop",
)
}
if (is_19_25_or_greater) {
- miniplayerModernConstructorFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerModernConstructorFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_MODERN_FEATURE_LEGACY_KEY,
"getModernMiniplayerOverride",
)
- miniplayerModernConstructorFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerModernConstructorFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_MODERN_FEATURE_KEY,
"getModernFeatureFlagsActiveOverride",
)
- miniplayerModernConstructorFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerModernConstructorFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_DOUBLE_TAP_FEATURE_KEY,
"enableMiniplayerDoubleTapAction",
)
@@ -426,19 +422,19 @@ val miniplayerPatch = bytecodePatch(
}
if (is_19_36_or_greater) {
- miniplayerModernConstructorFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerModernConstructorFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_ROUNDED_CORNERS_FEATURE_KEY,
"setRoundedCorners",
)
}
if (is_19_43_or_greater) {
- miniplayerOnCloseHandlerFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerOnCloseHandlerFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_DISABLED_FEATURE_KEY,
"getMiniplayerOnCloseHandler"
)
- miniplayerModernConstructorFingerprint.insertLiteralValueBooleanOverride(
+ miniplayerModernConstructorFingerprint.insertMiniplayerFeatureFlagBooleanOverride(
MINIPLAYER_HORIZONTAL_DRAG_FEATURE_KEY,
"setHorizontalDrag",
)
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/player/fullscreen/Fingerprints.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/player/fullscreen/Fingerprints.kt
new file mode 100644
index 0000000000..d188d8442b
--- /dev/null
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/player/fullscreen/Fingerprints.kt
@@ -0,0 +1,16 @@
+package app.revanced.patches.youtube.layout.player.fullscreen
+
+import app.revanced.patcher.fingerprint
+import app.revanced.util.literal
+import com.android.tools.smali.dexlib2.AccessFlags
+
+internal const val OPEN_VIDEOS_FULLSCREEN_PORTRAIT_FEATURE_FLAG = 45666112L
+
+internal val openVideosFullscreenPortraitFingerprint = fingerprint {
+ accessFlags(AccessFlags.PUBLIC, AccessFlags.FINAL)
+ returns("V")
+ parameters("L", "Lj\$/util/Optional;")
+ literal {
+ OPEN_VIDEOS_FULLSCREEN_PORTRAIT_FEATURE_FLAG
+ }
+}
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/player/fullscreen/OpenVideosFullscreen.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/player/fullscreen/OpenVideosFullscreen.kt
new file mode 100644
index 0000000000..621381ae5c
--- /dev/null
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/player/fullscreen/OpenVideosFullscreen.kt
@@ -0,0 +1,46 @@
+package app.revanced.patches.youtube.layout.player.fullscreen
+
+import app.revanced.patcher.patch.bytecodePatch
+import app.revanced.patches.all.misc.resources.addResources
+import app.revanced.patches.all.misc.resources.addResourcesPatch
+import app.revanced.patches.shared.misc.settings.preference.SwitchPreference
+import app.revanced.patches.youtube.misc.extension.sharedExtensionPatch
+import app.revanced.patches.youtube.misc.settings.PreferenceScreen
+import app.revanced.patches.youtube.misc.settings.settingsPatch
+import app.revanced.util.insertFeatureFlagBooleanOverride
+
+private const val EXTENSION_CLASS_DESCRIPTOR =
+ "Lapp/revanced/extension/youtube/patches/OpenVideosFullscreen;"
+
+@Suppress("unused")
+val openVideosFullscreenPatch = bytecodePatch(
+ name = "Open videos fullscreen",
+ description = "Adds an option to open videos in full screen portrait mode.",
+) {
+ dependsOn(
+ sharedExtensionPatch,
+ settingsPatch,
+ addResourcesPatch,
+ )
+
+ compatibleWith(
+ "com.google.android.youtube"(
+ "19.46.42",
+ )
+ )
+
+ execute {
+ openVideosFullscreenPortraitFingerprint.method.insertFeatureFlagBooleanOverride(
+ OPEN_VIDEOS_FULLSCREEN_PORTRAIT_FEATURE_FLAG,
+ "$EXTENSION_CLASS_DESCRIPTOR->openVideoFullscreenPortrait(Z)Z"
+ )
+
+ // Add resources and setting last, in case the user force patches an old incompatible version.
+
+ addResources("youtube", "layout.player.fullscreen.openVideosFullscreen")
+
+ PreferenceScreen.PLAYER.addPreferences(
+ SwitchPreference("revanced_open_videos_fullscreen_portrait")
+ )
+ }
+}
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/seekbar/SeekbarColorPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/seekbar/SeekbarColorPatch.kt
index a2f0797928..a9f347ad08 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/seekbar/SeekbarColorPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/seekbar/SeekbarColorPatch.kt
@@ -24,6 +24,7 @@ import app.revanced.util.getReference
import app.revanced.util.indexOfFirstInstructionOrThrow
import app.revanced.util.indexOfFirstLiteralInstructionOrThrow
import app.revanced.util.inputStreamFromBundledResource
+import app.revanced.util.insertFeatureFlagBooleanOverride
import com.android.tools.smali.dexlib2.Opcode
import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
import com.android.tools.smali.dexlib2.iface.instruction.TwoRegisterInstruction
@@ -228,19 +229,10 @@ val seekbarColorPatch = bytecodePatch(
// 19.25+ changes
- playerSeekbarGradientConfigFingerprint.method.apply {
- val literalIndex = indexOfFirstLiteralInstructionOrThrow(PLAYER_SEEKBAR_GRADIENT_FEATURE_FLAG)
- val resultIndex = indexOfFirstInstructionOrThrow(literalIndex, Opcode.MOVE_RESULT)
- val register = getInstruction(resultIndex).registerA
-
- addInstructions(
- resultIndex + 1,
- """
- invoke-static { v$register }, $EXTENSION_CLASS_DESCRIPTOR->playerSeekbarGradientEnabled(Z)Z
- move-result v$register
- """
- )
- }
+ playerSeekbarGradientConfigFingerprint.method.insertFeatureFlagBooleanOverride(
+ PLAYER_SEEKBAR_GRADIENT_FEATURE_FLAG,
+ "$EXTENSION_CLASS_DESCRIPTOR->playerSeekbarGradientEnabled(Z)Z"
+ )
lithoLinearGradientFingerprint.method.addInstruction(
0,
@@ -255,19 +247,10 @@ val seekbarColorPatch = bytecodePatch(
launchScreenLayoutTypeFingerprint,
mainActivityOnCreateFingerprint
).forEach { fingerprint ->
- fingerprint.method.apply {
- val literalIndex = indexOfFirstLiteralInstructionOrThrow(launchScreenLayoutTypeLotteFeatureFlag)
- val resultIndex = indexOfFirstInstructionOrThrow(literalIndex, Opcode.MOVE_RESULT)
- val register = getInstruction(resultIndex).registerA
-
- addInstructions(
- resultIndex + 1,
- """
- invoke-static { v$register }, $EXTENSION_CLASS_DESCRIPTOR->useLotteLaunchSplashScreen(Z)Z
- move-result v$register
- """
- )
- }
+ fingerprint.method.insertFeatureFlagBooleanOverride(
+ launchScreenLayoutTypeLotteFeatureFlag,
+ "$EXTENSION_CLASS_DESCRIPTOR->useLotteLaunchSplashScreen(Z)Z"
+ )
}
// Hook the splash animation drawable to set the a seekbar color theme.
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/theme/ThemePatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/theme/ThemePatch.kt
index c658ee676d..a5835d727f 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/layout/theme/ThemePatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/layout/theme/ThemePatch.kt
@@ -1,7 +1,6 @@
package app.revanced.patches.youtube.layout.theme
import app.revanced.patcher.extensions.InstructionExtensions.addInstructions
-import app.revanced.patcher.extensions.InstructionExtensions.getInstruction
import app.revanced.patcher.patch.PatchException
import app.revanced.patcher.patch.bytecodePatch
import app.revanced.patcher.patch.resourcePatch
@@ -17,10 +16,7 @@ import app.revanced.patches.youtube.misc.extension.sharedExtensionPatch
import app.revanced.patches.youtube.misc.settings.PreferenceScreen
import app.revanced.patches.youtube.misc.settings.settingsPatch
import app.revanced.util.forEachChildElement
-import app.revanced.util.indexOfFirstInstructionOrThrow
-import app.revanced.util.indexOfFirstLiteralInstructionOrThrow
-import com.android.tools.smali.dexlib2.Opcode
-import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
+import app.revanced.util.insertFeatureFlagBooleanOverride
import org.w3c.dom.Element
private const val EXTENSION_CLASS_DESCRIPTOR =
@@ -212,19 +208,10 @@ val themePatch = bytecodePatch(
SwitchPreference("revanced_gradient_loading_screen"),
)
- useGradientLoadingScreenFingerprint.method.apply {
- val literalIndex = indexOfFirstLiteralInstructionOrThrow(GRADIENT_LOADING_SCREEN_AB_CONSTANT)
- val isEnabledIndex = indexOfFirstInstructionOrThrow(literalIndex, Opcode.MOVE_RESULT)
- val isEnabledRegister = getInstruction(isEnabledIndex).registerA
-
- addInstructions(
- isEnabledIndex + 1,
- """
- invoke-static { }, $EXTENSION_CLASS_DESCRIPTOR->gradientLoadingScreenEnabled()Z
- move-result v$isEnabledRegister
- """,
- )
- }
+ useGradientLoadingScreenFingerprint.method.insertFeatureFlagBooleanOverride(
+ GRADIENT_LOADING_SCREEN_AB_CONSTANT,
+ "$EXTENSION_CLASS_DESCRIPTOR->gradientLoadingScreenEnabled(Z)Z"
+ )
mapOf(
themeHelperLightColorFingerprint to lightThemeBackgroundColor,
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/cairo/DisableCairoSettingsPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/cairo/DisableCairoSettingsPatch.kt
index d6fafe5398..cd058ca590 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/cairo/DisableCairoSettingsPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/cairo/DisableCairoSettingsPatch.kt
@@ -34,10 +34,7 @@ internal val disableCairoSettingsPatch = bytecodePatch(
* uYouPlus#1468.
*/
cairoFragmentConfigFingerprint.method.apply {
- val literalIndex = indexOfFirstLiteralInstructionOrThrow(
- CAIRO_CONFIG_LITERAL_VALUE,
- )
-
+ val literalIndex = indexOfFirstLiteralInstructionOrThrow(CAIRO_CONFIG_LITERAL_VALUE)
val resultIndex = indexOfFirstInstructionOrThrow(literalIndex, Opcode.MOVE_RESULT)
val register = getInstruction(resultIndex).registerA
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/SpoofVideoStreamsPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/SpoofVideoStreamsPatch.kt
index 515536b8f5..89e7cc08f8 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/SpoofVideoStreamsPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/SpoofVideoStreamsPatch.kt
@@ -1,243 +1,9 @@
package app.revanced.patches.youtube.misc.fix.playback
-import app.revanced.patcher.extensions.InstructionExtensions.addInstruction
-import app.revanced.patcher.extensions.InstructionExtensions.addInstructions
-import app.revanced.patcher.extensions.InstructionExtensions.addInstructionsWithLabels
-import app.revanced.patcher.extensions.InstructionExtensions.getInstruction
-import app.revanced.patcher.extensions.InstructionExtensions.instructions
import app.revanced.patcher.patch.bytecodePatch
-import app.revanced.patcher.util.proxy.mutableTypes.MutableMethod.Companion.toMutable
-import app.revanced.patches.all.misc.resources.addResources
-import app.revanced.patches.all.misc.resources.addResourcesPatch
-import app.revanced.patches.shared.misc.settings.preference.ListPreference
-import app.revanced.patches.shared.misc.settings.preference.NonInteractivePreference
-import app.revanced.patches.shared.misc.settings.preference.PreferenceScreenPreference
-import app.revanced.patches.shared.misc.settings.preference.SwitchPreference
-import app.revanced.patches.youtube.misc.settings.PreferenceScreen
-import app.revanced.patches.youtube.misc.settings.settingsPatch
-import app.revanced.util.getReference
-import app.revanced.util.indexOfFirstInstructionOrThrow
-import com.android.tools.smali.dexlib2.AccessFlags
-import com.android.tools.smali.dexlib2.Opcode
-import com.android.tools.smali.dexlib2.builder.MutableMethodImplementation
-import com.android.tools.smali.dexlib2.iface.instruction.FiveRegisterInstruction
-import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
-import com.android.tools.smali.dexlib2.iface.instruction.TwoRegisterInstruction
-import com.android.tools.smali.dexlib2.iface.reference.FieldReference
-import com.android.tools.smali.dexlib2.iface.reference.MethodReference
-import com.android.tools.smali.dexlib2.immutable.ImmutableMethod
-import com.android.tools.smali.dexlib2.immutable.ImmutableMethodParameter
-private const val EXTENSION_CLASS_DESCRIPTOR =
- "Lapp/revanced/extension/youtube/patches/spoof/SpoofVideoStreamsPatch;"
-
-val spoofVideoStreamsPatch = bytecodePatch(
- name = "Spoof video streams",
- description = "Spoofs the client video streams to allow video playback.",
-) {
- compatibleWith(
- "com.google.android.youtube"(
- "18.38.44",
- "18.49.37",
- "19.16.39",
- "19.25.37",
- "19.34.42",
- "19.43.41",
- "19.45.38",
- "19.46.42",
- ),
- )
-
- dependsOn(
- settingsPatch,
- addResourcesPatch,
- userAgentClientSpoofPatch,
- )
-
- execute {
- addResources("youtube", "misc.fix.playback.spoofVideoStreamsPatch")
-
- PreferenceScreen.MISC.addPreferences(
- PreferenceScreenPreference(
- key = "revanced_spoof_video_streams_screen",
- sorting = PreferenceScreenPreference.Sorting.UNSORTED,
- preferences = setOf(
- SwitchPreference("revanced_spoof_video_streams"),
- ListPreference(
- "revanced_spoof_video_streams_client",
- summaryKey = null,
- ),
- SwitchPreference(
- "revanced_spoof_video_streams_ios_force_avc",
- tag = "app.revanced.extension.youtube.settings.preference.ForceAVCSpoofingPreference",
- ),
- NonInteractivePreference("revanced_spoof_video_streams_about_android_vr"),
- NonInteractivePreference("revanced_spoof_video_streams_about_ios"),
- ),
- ),
- )
-
- // region Block /initplayback requests to fall back to /get_watch requests.
-
- val moveUriStringIndex = buildInitPlaybackRequestFingerprint.patternMatch!!.startIndex
-
- buildInitPlaybackRequestFingerprint.method.apply {
- val targetRegister = getInstruction(moveUriStringIndex).registerA
-
- addInstructions(
- moveUriStringIndex + 1,
- """
- invoke-static { v$targetRegister }, $EXTENSION_CLASS_DESCRIPTOR->blockInitPlaybackRequest(Ljava/lang/String;)Ljava/lang/String;
- move-result-object v$targetRegister
- """,
- )
- }
-
- // endregion
-
- // region Block /get_watch requests to fall back to /player requests.
-
- val invokeToStringIndex = buildPlayerRequestURIFingerprint.patternMatch!!.startIndex
-
- buildPlayerRequestURIFingerprint.method.apply {
- val uriRegister = getInstruction(invokeToStringIndex).registerC
-
- addInstructions(
- invokeToStringIndex,
- """
- invoke-static { v$uriRegister }, $EXTENSION_CLASS_DESCRIPTOR->blockGetWatchRequest(Landroid/net/Uri;)Landroid/net/Uri;
- move-result-object v$uriRegister
- """,
- )
- }
-
- // endregion
-
- // region Get replacement streams at player requests.
-
- buildRequestFingerprint.method.apply {
- val newRequestBuilderIndex = indexOfFirstInstructionOrThrow {
- opcode == Opcode.INVOKE_VIRTUAL &&
- getReference()?.name == "newUrlRequestBuilder"
- }
- val urlRegister = getInstruction(newRequestBuilderIndex).registerD
- val freeRegister = getInstruction(newRequestBuilderIndex + 1).registerA
-
- addInstructions(
- newRequestBuilderIndex,
- """
- move-object v$freeRegister, p1
- invoke-static { v$urlRegister, v$freeRegister }, $EXTENSION_CLASS_DESCRIPTOR->fetchStreams(Ljava/lang/String;Ljava/util/Map;)V
- """,
- )
- }
-
- // endregion
-
- // region Replace the streaming data with the replacement streams.
-
- createStreamingDataFingerprint.method.apply {
- val setStreamDataMethodName = "patch_setStreamingData"
- val resultMethodType = createStreamingDataFingerprint.classDef.type
- val videoDetailsIndex = createStreamingDataFingerprint.patternMatch!!.endIndex
- val videoDetailsRegister = getInstruction(videoDetailsIndex).registerA
- val videoDetailsClass = getInstruction(videoDetailsIndex).getReference()!!.type
-
- addInstruction(
- videoDetailsIndex + 1,
- "invoke-direct { p0, v$videoDetailsRegister }, " +
- "$resultMethodType->$setStreamDataMethodName($videoDetailsClass)V",
- )
-
- val protobufClass = protobufClassParseByteBufferFingerprint.method.definingClass
- val setStreamingDataIndex = createStreamingDataFingerprint.patternMatch!!.startIndex
-
- val playerProtoClass = getInstruction(setStreamingDataIndex + 1)
- .getReference()!!.definingClass
-
- val setStreamingDataField = getInstruction(setStreamingDataIndex).getReference()
-
- val getStreamingDataField = getInstruction(
- indexOfFirstInstructionOrThrow {
- opcode == Opcode.IGET_OBJECT && getReference()?.definingClass == playerProtoClass
- },
- ).getReference()
-
- // Use a helper method to avoid the need of picking out multiple free registers from the hooked code.
- createStreamingDataFingerprint.classDef.methods.add(
- ImmutableMethod(
- resultMethodType,
- setStreamDataMethodName,
- listOf(ImmutableMethodParameter(videoDetailsClass, null, "videoDetails")),
- "V",
- AccessFlags.PRIVATE.value or AccessFlags.FINAL.value,
- null,
- null,
- MutableMethodImplementation(9),
- ).toMutable().apply {
- addInstructionsWithLabels(
- 0,
- """
- invoke-static { }, $EXTENSION_CLASS_DESCRIPTOR->isSpoofingEnabled()Z
- move-result v0
- if-eqz v0, :disabled
-
- # Get video id.
- iget-object v2, p1, $videoDetailsClass->c:Ljava/lang/String;
- if-eqz v2, :disabled
-
- # Get streaming data.
- invoke-static { v2 }, $EXTENSION_CLASS_DESCRIPTOR->getStreamingData(Ljava/lang/String;)Ljava/nio/ByteBuffer;
- move-result-object v3
- if-eqz v3, :disabled
-
- # Parse streaming data.
- sget-object v4, $playerProtoClass->a:$playerProtoClass
- invoke-static { v4, v3 }, $protobufClass->parseFrom(${protobufClass}Ljava/nio/ByteBuffer;)$protobufClass
- move-result-object v5
- check-cast v5, $playerProtoClass
-
- # Set streaming data.
- iget-object v6, v5, $getStreamingDataField
- if-eqz v6, :disabled
- iput-object v6, p0, $setStreamingDataField
-
- :disabled
- return-void
- """,
- )
- },
- )
- }
-
- // endregion
-
- // region Remove /videoplayback request body to fix playback.
- // It is assumed, YouTube makes a request with a body tuned for Android.
- // Requesting streams intended for other platforms with a body tuned for Android could be the cause of 400 errors.
- // A proper fix may include modifying the request body to match the platforms expected body.
-
- buildMediaDataSourceFingerprint.method.apply {
- val targetIndex = instructions.lastIndex
-
- // Instructions are added just before the method returns,
- // so there's no concern of clobbering in-use registers.
- addInstructions(
- targetIndex,
- """
- # Field a: Stream uri.
- # Field c: Http method.
- # Field d: Post data.
- move-object v0, p0 # method has over 15 registers and must copy p0 to a lower register.
- iget-object v1, v0, $definingClass->a:Landroid/net/Uri;
- iget v2, v0, $definingClass->c:I
- iget-object v3, v0, $definingClass->d:[B
- invoke-static { v1, v2, v3 }, $EXTENSION_CLASS_DESCRIPTOR->removeVideoPlaybackPostBody(Landroid/net/Uri;I[B)[B
- move-result-object v1
- iput-object v1, v0, $definingClass->d:[B
- """,
- )
- }
- // endregion
- }
+@Deprecated("Use app.revanced.patches.youtube.misc.spoof.spoofVideoStreamsPatch instead.")
+@Suppress("unused")
+val spoofVideoStreamsPatch = bytecodePatch {
+ dependsOn(app.revanced.patches.youtube.misc.spoof.spoofVideoStreamsPatch)
}
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/UserAgentClientSpoofPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/UserAgentClientSpoofPatch.kt
index 8bbd0ec778..eb4c9492be 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/UserAgentClientSpoofPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/UserAgentClientSpoofPatch.kt
@@ -1,82 +1,9 @@
package app.revanced.patches.youtube.misc.fix.playback
-import app.revanced.patcher.extensions.InstructionExtensions.getInstruction
-import app.revanced.patcher.extensions.InstructionExtensions.replaceInstruction
-import app.revanced.patches.all.misc.transformation.IMethodCall
-import app.revanced.patches.all.misc.transformation.filterMapInstruction35c
-import app.revanced.patches.all.misc.transformation.transformInstructionsPatch
-import app.revanced.util.getReference
-import app.revanced.util.indexOfFirstInstruction
-import com.android.tools.smali.dexlib2.Opcode
-import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
-import com.android.tools.smali.dexlib2.iface.reference.MethodReference
-import com.android.tools.smali.dexlib2.iface.reference.StringReference
-
-private const val ORIGINAL_PACKAGE_NAME = "com.google.android.youtube"
-private const val USER_AGENT_STRING_BUILDER_APPEND_METHOD_REFERENCE =
- "Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;"
-
-val userAgentClientSpoofPatch = transformInstructionsPatch(
- filterMap = { classDef, _, instruction, instructionIndex ->
- filterMapInstruction35c(
- "Lapp/revanced/extension",
- classDef,
- instruction,
- instructionIndex,
- )
- },
- transform = transform@{ mutableMethod, entry ->
- val (_, _, instructionIndex) = entry
-
- // Replace the result of context.getPackageName(), if it is used in a user agent string.
- mutableMethod.apply {
- // After context.getPackageName() the result is moved to a register.
- val targetRegister = (
- getInstruction(instructionIndex + 1)
- as? OneRegisterInstruction ?: return@transform
- ).registerA
-
- // IndexOutOfBoundsException is technically possible here,
- // but no such occurrences are present in the app.
- val referee = getInstruction(instructionIndex + 2).getReference()?.toString()
-
- // Only replace string builder usage.
- if (referee != USER_AGENT_STRING_BUILDER_APPEND_METHOD_REFERENCE) {
- return@transform
- }
-
- // Do not change the package name in methods that use resources, or for methods that use GmsCore.
- // Changing these package names will result in playback limitations,
- // particularly Android VR background audio only playback.
- val resourceOrGmsStringInstructionIndex = indexOfFirstInstruction {
- val reference = getReference()
- opcode == Opcode.CONST_STRING &&
- (reference?.string == "android.resource://" || reference?.string == "gcore_")
- }
- if (resourceOrGmsStringInstructionIndex >= 0) {
- return@transform
- }
-
- // Overwrite the result of context.getPackageName() with the original package name.
- replaceInstruction(
- instructionIndex + 1,
- "const-string v$targetRegister, \"$ORIGINAL_PACKAGE_NAME\"",
- )
- }
- },
-)
+import app.revanced.patcher.patch.bytecodePatch
+@Deprecated("Use app.revanced.patches.youtube.misc.spoof.userAgentClientSpoofPatch instead.")
@Suppress("unused")
-private enum class MethodCall(
- override val definedClassName: String,
- override val methodName: String,
- override val methodParams: Array,
- override val returnType: String,
-) : IMethodCall {
- GetPackageName(
- "Landroid/content/Context;",
- "getPackageName",
- emptyArray(),
- "Ljava/lang/String;",
- ),
+val userAgentClientSpoofPatch = bytecodePatch {
+ dependsOn(app.revanced.patches.youtube.misc.spoof.userAgentClientSpoofPatch)
}
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/gms/GmsCoreSupportPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/gms/GmsCoreSupportPatch.kt
index bb86b663f9..dc73116ebf 100644
--- a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/gms/GmsCoreSupportPatch.kt
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/gms/GmsCoreSupportPatch.kt
@@ -9,11 +9,11 @@ import app.revanced.patches.shared.misc.settings.preference.IntentPreference
import app.revanced.patches.shared.primeMethodFingerprint
import app.revanced.patches.youtube.layout.buttons.overlay.hidePlayerOverlayButtonsPatch
import app.revanced.patches.youtube.misc.extension.sharedExtensionPatch
-import app.revanced.patches.youtube.misc.fix.playback.spoofVideoStreamsPatch
import app.revanced.patches.youtube.misc.gms.Constants.REVANCED_YOUTUBE_PACKAGE_NAME
import app.revanced.patches.youtube.misc.gms.Constants.YOUTUBE_PACKAGE_NAME
import app.revanced.patches.youtube.misc.settings.PreferenceScreen
import app.revanced.patches.youtube.misc.settings.settingsPatch
+import app.revanced.patches.youtube.misc.spoof.spoofVideoStreamsPatch
import app.revanced.patches.youtube.shared.mainActivityOnCreateFingerprint
@Suppress("unused")
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/spoof/SpoofVideoStreamsPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/spoof/SpoofVideoStreamsPatch.kt
new file mode 100644
index 0000000000..7d740b1c03
--- /dev/null
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/spoof/SpoofVideoStreamsPatch.kt
@@ -0,0 +1,53 @@
+package app.revanced.patches.youtube.misc.spoof
+
+import app.revanced.patches.all.misc.resources.addResources
+import app.revanced.patches.shared.misc.settings.preference.ListPreference
+import app.revanced.patches.shared.misc.settings.preference.NonInteractivePreference
+import app.revanced.patches.shared.misc.settings.preference.PreferenceScreenPreference
+import app.revanced.patches.shared.misc.settings.preference.SwitchPreference
+import app.revanced.patches.shared.misc.spoof.spoofVideoStreamsPatch
+import app.revanced.patches.youtube.misc.settings.PreferenceScreen
+import app.revanced.patches.youtube.misc.settings.settingsPatch
+
+val spoofVideoStreamsPatch = spoofVideoStreamsPatch({
+ compatibleWith(
+ "com.google.android.youtube"(
+ "18.38.44",
+ "18.49.37",
+ "19.16.39",
+ "19.25.37",
+ "19.34.42",
+ "19.43.41",
+ "19.45.38",
+ "19.46.42",
+ ),
+ )
+
+ dependsOn(
+ userAgentClientSpoofPatch,
+ settingsPatch,
+ )
+}, {
+ addResources("youtube", "misc.fix.playback.spoofVideoStreamsPatch")
+
+ PreferenceScreen.MISC.addPreferences(
+ PreferenceScreenPreference(
+ key = "revanced_spoof_video_streams_screen",
+ sorting = PreferenceScreenPreference.Sorting.UNSORTED,
+ preferences = setOf(
+ SwitchPreference("revanced_spoof_video_streams"),
+ ListPreference(
+ "revanced_spoof_video_streams_client",
+ summaryKey = null,
+ ),
+ ListPreference(
+ "revanced_spoof_video_streams_language",
+ summaryKey = null
+ ),
+ SwitchPreference("revanced_spoof_video_streams_ios_force_avc"),
+ NonInteractivePreference("revanced_spoof_video_streams_about_android_vr"),
+ NonInteractivePreference("revanced_spoof_video_streams_about_ios"),
+ ),
+ ),
+ )
+})
diff --git a/patches/src/main/kotlin/app/revanced/patches/youtube/misc/spoof/UserAgentClientSpoofPatch.kt b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/spoof/UserAgentClientSpoofPatch.kt
new file mode 100644
index 0000000000..d9b6596138
--- /dev/null
+++ b/patches/src/main/kotlin/app/revanced/patches/youtube/misc/spoof/UserAgentClientSpoofPatch.kt
@@ -0,0 +1,82 @@
+package app.revanced.patches.youtube.misc.spoof
+
+import app.revanced.patcher.extensions.InstructionExtensions.getInstruction
+import app.revanced.patcher.extensions.InstructionExtensions.replaceInstruction
+import app.revanced.patches.all.misc.transformation.IMethodCall
+import app.revanced.patches.all.misc.transformation.filterMapInstruction35c
+import app.revanced.patches.all.misc.transformation.transformInstructionsPatch
+import app.revanced.util.getReference
+import app.revanced.util.indexOfFirstInstruction
+import com.android.tools.smali.dexlib2.Opcode
+import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
+import com.android.tools.smali.dexlib2.iface.reference.MethodReference
+import com.android.tools.smali.dexlib2.iface.reference.StringReference
+
+private const val ORIGINAL_PACKAGE_NAME = "com.google.android.youtube"
+private const val USER_AGENT_STRING_BUILDER_APPEND_METHOD_REFERENCE =
+ "Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;"
+
+val userAgentClientSpoofPatch = transformInstructionsPatch(
+ filterMap = { classDef, _, instruction, instructionIndex ->
+ filterMapInstruction35c(
+ "Lapp/revanced/extension",
+ classDef,
+ instruction,
+ instructionIndex,
+ )
+ },
+ transform = transform@{ mutableMethod, entry ->
+ val (_, _, instructionIndex) = entry
+
+ // Replace the result of context.getPackageName(), if it is used in a user agent string.
+ mutableMethod.apply {
+ // After context.getPackageName() the result is moved to a register.
+ val targetRegister = (
+ getInstruction(instructionIndex + 1)
+ as? OneRegisterInstruction ?: return@transform
+ ).registerA
+
+ // IndexOutOfBoundsException is technically possible here,
+ // but no such occurrences are present in the app.
+ val referee = getInstruction(instructionIndex + 2).getReference()?.toString()
+
+ // Only replace string builder usage.
+ if (referee != USER_AGENT_STRING_BUILDER_APPEND_METHOD_REFERENCE) {
+ return@transform
+ }
+
+ // Do not change the package name in methods that use resources, or for methods that use GmsCore.
+ // Changing these package names will result in playback limitations,
+ // particularly Android VR background audio only playback.
+ val resourceOrGmsStringInstructionIndex = indexOfFirstInstruction {
+ val reference = getReference()
+ opcode == Opcode.CONST_STRING &&
+ (reference?.string == "android.resource://" || reference?.string == "gcore_")
+ }
+ if (resourceOrGmsStringInstructionIndex >= 0) {
+ return@transform
+ }
+
+ // Overwrite the result of context.getPackageName() with the original package name.
+ replaceInstruction(
+ instructionIndex + 1,
+ "const-string v$targetRegister, \"$ORIGINAL_PACKAGE_NAME\"",
+ )
+ }
+ },
+)
+
+@Suppress("unused")
+private enum class MethodCall(
+ override val definedClassName: String,
+ override val methodName: String,
+ override val methodParams: Array,
+ override val returnType: String,
+) : IMethodCall {
+ GetPackageName(
+ "Landroid/content/Context;",
+ "getPackageName",
+ emptyArray(),
+ "Ljava/lang/String;",
+ ),
+}
diff --git a/patches/src/main/kotlin/app/revanced/util/BytecodeUtils.kt b/patches/src/main/kotlin/app/revanced/util/BytecodeUtils.kt
index ec75cb0a5d..8e5a85056a 100644
--- a/patches/src/main/kotlin/app/revanced/util/BytecodeUtils.kt
+++ b/patches/src/main/kotlin/app/revanced/util/BytecodeUtils.kt
@@ -17,6 +17,7 @@ import app.revanced.patches.shared.misc.mapping.resourceMappings
import com.android.tools.smali.dexlib2.Opcode
import com.android.tools.smali.dexlib2.iface.Method
import com.android.tools.smali.dexlib2.iface.instruction.Instruction
+import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
import com.android.tools.smali.dexlib2.iface.instruction.ReferenceInstruction
import com.android.tools.smali.dexlib2.iface.instruction.WideLiteralInstruction
import com.android.tools.smali.dexlib2.iface.reference.Reference
@@ -402,6 +403,20 @@ fun Method.findInstructionIndicesReversedOrThrow(opcode: Opcode): List {
return instructions
}
+internal fun MutableMethod.insertFeatureFlagBooleanOverride(literal: Long, extensionsMethod: String) {
+ val literalIndex = indexOfFirstLiteralInstructionOrThrow(literal)
+ val index = indexOfFirstInstructionOrThrow(literalIndex, Opcode.MOVE_RESULT)
+ val register = getInstruction(index).registerA
+
+ addInstructions(
+ index + 1,
+ """
+ invoke-static { v$register }, $extensionsMethod
+ move-result v$register
+ """
+ )
+}
+
/**
* Called for _all_ instructions with the given literal value.
*/
diff --git a/patches/src/main/resources/addresources/values-af-rZA/strings.xml b/patches/src/main/resources/addresources/values-af-rZA/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-af-rZA/strings.xml
+++ b/patches/src/main/resources/addresources/values-af-rZA/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-am-rET/strings.xml b/patches/src/main/resources/addresources/values-am-rET/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-am-rET/strings.xml
+++ b/patches/src/main/resources/addresources/values-am-rET/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ar-rSA/strings.xml b/patches/src/main/resources/addresources/values-ar-rSA/strings.xml
index 513462cd6a..548086e9b9 100644
--- a/patches/src/main/resources/addresources/values-ar-rSA/strings.xml
+++ b/patches/src/main/resources/addresources/values-ar-rSA/strings.xml
@@ -709,6 +709,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
تم إخفاء لوحات المشغل المنبثقة
يتم عرض لوحات المشغل المنبثقة
+
+ فتح مقاطع الفيديو في ملء الشاشة
+ الفيديو فتح ملء الشاشة
+ الفيديو لا تفتح ملء الشاشة
+
شفافية تراكب المشغل
قيمة الشفافية بين 0-100، حيث يكون 0 شفاف
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
إيقاف تشغيل هذا الإعداد قد يسبب مشاكل في تشغيل الفيديو.
العميل الافتراضي
فرض AVC (H.264)
- ترميز الفيديو هو AVC (H.264)
- ترميز الفيديو هو VP9 أو AV1
- لا يحتوي جهازك على فك تشفير الأجهزة VP9، وهذا الإعداد يعمل دائما عند تمكين تزييف العميل
- قد يؤدي تمكين هذا إلى تحسين عمر البطارية وإصلاح مشكلة تقطيع التشغيل.\n\nيتمتع تنسيق AVC بدقة قصوى تبلغ 1080P، وسيستخدم تشغيل الفيديو المزيد من بيانات الإنترنت مقارنةً بتنسيق VP9 أو AV1.
+ كود الفيديو مرغم على AVC (H.264)
+ يتم تحديد رمز الفيديو تلقائياً
+ تمكين هذا قد يحسّن عمر البطارية وإصلاح تشغيل التشغيل.\n\nAVC لها حد أقصى قدره 1080p، رمز الصوت Opus غير متوفر. وسيستخدم تشغيل الفيديو بيانات إنترنت أكثر من VP9 أو AV1.
التأثيرات الجانبية لمحاكاة iOS
- • قد لا يتم تشغيل فيديوهات الأطفال الخاصة\n• تبدأ البثوث المباشر من البداية\n• قد تنتهي الفيديوهات قبل النهاية بثانية واحدة\n• لا يوجد ترميز الصوت opus
+ • قد لا يتم تشغيل فيديوهات الأطفال الخاصة\n• تبدأ البثوث المباشرة من البداية\n• قد تنتهي الفيديوهات قبل النهاية بثانية واحدة
التأثيرات الجانبية لمحاكاة Android VR
• قد لا يتم تشغيل فيديوهات الأطفال\n• قائمة المقطع الصوتي مفقودة\n• مستوى الصوت الثابت غير متوفر
+ يتم تزييف تدفقات الفيديو
+ لغة البث الصوتي المفضلة
+ لغة التطبيق
+ العربية
+ الأذربيجانية
+ البلغاري
+ البنغالي
+ الكاتالونية
+ التشيكية
+ الدانماركية
+ الألمانية
+ اليونانية
+ الإنجليزية
+ الإسبانية
+ الإستونية
+ الفارسية
+ الفنلندية
+ الفرنسية
+ Gujarati
+ الهندية
+ الكرواتية
+ الهنغارية
+ الإندونيسية
+ الإيطالية
+ يابانية
+ Kazakh
+ الكورية
+ ليتوانية
+ لاتفيا
+ مقدونية
+ منغولي
+ الماراثي
+ الملايو
+ Burmese
+ الهولندية
+ Odia
+ Punjabi
+ البولندية
+ البرتغالية (البرازيل)
+ البرتغالية (البرتغال)
+ الرومانية
+ الروسية
+ السلوفاكية
+ Slovene
+ الصربية
+ السويدية
+ سواحيلية
+ Tamil
+ Telugu
+ التايلندية
+ تركية
+ أوكراني
+ الأردو
+ Vietnamese
+ الصينية
diff --git a/patches/src/main/resources/addresources/values-as-rIN/strings.xml b/patches/src/main/resources/addresources/values-as-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-as-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-as-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-az-rAZ/strings.xml b/patches/src/main/resources/addresources/values-az-rAZ/strings.xml
index 5535931800..a0ead0fda4 100644
--- a/patches/src/main/resources/addresources/values-az-rAZ/strings.xml
+++ b/patches/src/main/resources/addresources/values-az-rAZ/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Oynadıcı açılan pəncərə panelləri gizlidir
Oynadıcı açılan pəncərə panelləri göstərilir
+
+
Oynadıcı örtüyünün qeyri-şəffaflığı
0-100 arasında qeyri-şəffaflıq dəyəri, burada 0 şəffafdır
@@ -1200,14 +1202,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Bu seçimi bağlamaq, video oynatma problemlərinə səbəb olar.
İlkin qəbuledici
Məcburi AVC (H.264)
- Video kodlaşdırma: AVC (H.264)
- Video kodlaşdırma / VP9 və ya AV1
- Cihazınızın VP9 hardware decoding\'i yoxdur və bu seçim, \"Qəbuledicini saxtalaşdırma\" aktivləşdikdə həmişəlikdir
- Bunu aktivləşdirmə batareya ömrünü yaxşılaşdıra və oynatma donmasını düzəldə bilər.\n\nAVC maksimum 1080p görüntü imkanına malikdir və video oynadılması VP9 və ya AV1-dən daha çox internet məlumatı istifadə edəcək.
iOS saxtakarlığı yan təsirləri
- • Şəxsi uşaq videoları oynadılmaya bilər\n• Canlı yayımlar başdan başlayır\n• Videolar 1 saniyə tez bitə bilər\n• Opus səs kodlama yoxdur
+ • Uşaq videoları oxudulmaya bilər\n• Canlı yayımlar başdan başlayır\n• Videolar 1 saniyə tez bitə bilər
Android VR saxtakarlığı yan təsirləri
• Uşaq videoları oynadılmaya bilər\n• Səs treki menyusu əskikdir\n• Sabit səs həcmi əlçatan deyil
+ Video yayımları saxtalaşdırılır
diff --git a/patches/src/main/resources/addresources/values-be-rBY/strings.xml b/patches/src/main/resources/addresources/values-be-rBY/strings.xml
index 82bdf5da1c..b780dee186 100644
--- a/patches/src/main/resources/addresources/values-be-rBY/strings.xml
+++ b/patches/src/main/resources/addresources/values-be-rBY/strings.xml
@@ -637,6 +637,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Усплывальныя панэлі прайгравальніка схаваныя
Паказваюцца ўсплывальныя панэлі прайгравальніка
+
+
Непразрыстасць накладання прайгравальніка
Значэнне непразрыстасці паміж 0-100, дзе 0 - празрысты
diff --git a/patches/src/main/resources/addresources/values-bg-rBG/strings.xml b/patches/src/main/resources/addresources/values-bg-rBG/strings.xml
index 757eff2e5e..8433934700 100644
--- a/patches/src/main/resources/addresources/values-bg-rBG/strings.xml
+++ b/patches/src/main/resources/addresources/values-bg-rBG/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Изскачащите панели на плейъра са скрити
Изскачащите панели на плейъра се показват
+
+
Прозрачност на настройките в Плеара
Стойност на прозрачност между 0-100, където 0 е прозрачно
@@ -1200,14 +1202,10 @@ This is because Crowdin requires temporarily flattening this file and removing t
Деактивирането на тази настройка ще доведе до проблеми с възпроизвеждането на видео.
Клиент по подразбиране
Принудително AVC (H.264)
- Видеокодека е AVC (H.264)
- Видеокодека е VP9 или AV1
- Вашето устройство няма хардуерно VP9 декодиране и тази настройка винаги е активирана, когато е активно подправяне на клиента
- Активирането на това може да подобри живота на батерията и да коригира прекъсванията при възпроизвеждане.\n\nAVC има максимална разделителна способност от 1080p и възпроизвеждането на видео ще използва повече интернет данни от VP9 или AV1.
Cтранични ефекти от подмяната на iOS
- • Платените видеоклипове за деца може да не се възпроизвеждат\n• Потоците на живо започват отначало\n• Видеоклиповете може да завършват 1 секунда по-рано\n• Няма аудиокодек Opus
Странични ефекти от подправяне на Android VR
• Детските видеоклипове може да не се възпроизвеждат\n• Липсва менюто за аудио запис\n• Не е налична стабилна сила на звука
+ Видео потоците са подправени
diff --git a/patches/src/main/resources/addresources/values-bn-rBD/strings.xml b/patches/src/main/resources/addresources/values-bn-rBD/strings.xml
index 11426af23f..7e92decee3 100644
--- a/patches/src/main/resources/addresources/values-bn-rBD/strings.xml
+++ b/patches/src/main/resources/addresources/values-bn-rBD/strings.xml
@@ -629,6 +629,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
প্লেয়ার পপআপ প্যানেলগুলো লুকিয়ে রয়েছে
প্লেয়ার পপআপ প্যানেলগুলো প্রদর্শিত হয়েছে
+
+
প্লেয়ার ওভারলে অস্বচ্ছতা
অসচ্ছতা মান ০-১০০ এর মধ্যে, যেখানে ০ হল সম্পূর্ণ স্বচ্ছ
@@ -1066,8 +1068,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
এই সেটিংটি বন্ধ করার ফলে ভিডিও প্লেব্যাক ত্রুটি হতে পারে।
ডিফল্ট ক্লায়েন্ট
AVC (H.264) ফোর্স করুন
- ভিডিও কোডেক AVC (H.264) ব্যবহৃত হচ্ছে
- ভিডিও কোডেক VP9 বা AV1 ব্যবহৃত হচ্ছে
+ ভিডিও স্ট্রিম স্পুফ করা হয়েছে
diff --git a/patches/src/main/resources/addresources/values-bs-rBA/strings.xml b/patches/src/main/resources/addresources/values-bs-rBA/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-bs-rBA/strings.xml
+++ b/patches/src/main/resources/addresources/values-bs-rBA/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ca-rES/strings.xml b/patches/src/main/resources/addresources/values-ca-rES/strings.xml
index 650ad2a72c..3168d47370 100644
--- a/patches/src/main/resources/addresources/values-ca-rES/strings.xml
+++ b/patches/src/main/resources/addresources/values-ca-rES/strings.xml
@@ -149,6 +149,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-cs-rCZ/strings.xml b/patches/src/main/resources/addresources/values-cs-rCZ/strings.xml
index 89ea7b4dbc..d1a344ece3 100644
--- a/patches/src/main/resources/addresources/values-cs-rCZ/strings.xml
+++ b/patches/src/main/resources/addresources/values-cs-rCZ/strings.xml
@@ -710,6 +710,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Vyskakovací panely přehrávače jsou skryty
Zobrazí se vyskakovací panely přehrávače
+
+ Otevřít videa na výšku na celou obrazovku
+ Videa otevřená na celou obrazovku
+ Videa neotevírají celou obrazovku
+
Neprůhlednost překrytí přehrávače
Neprůhlednost mezi 0-100, kde 0 je průhledná
@@ -1201,14 +1206,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Vypnutí tohoto nastavení může způsobit problémy při přehrávání videa.
Výchozí klient
Síla AVC (H.264)
- Video kodek je AVC (H.264)
- Video kodek je VP9 nebo AV1
- Vaše zařízení nemá hardwarové dekódování VP9 a toto nastavení je vždy zapnuto, když je aktivní spoofování klienta
- Povolení této funkce může zlepšit životnost baterie a opravit stahování přehrávání.\n\nAVC má maximální rozlišení 1080p a video přehrávání bude používat více dat než VP9 nebo AV1.
+ Kodek videa je nucen k AVC (H.264)
+ Kodek videa je určen automaticky
+ Povolení této funkce může zlepšit životnost baterie a opravit stahování přehrávání.\n\nAVC má maximální rozlišení 1080p, Opus audio kodek není k dispozici, a přehrávání videa bude používat více dat na internetu než VP9 nebo AV1.
Boční efekty iOS
- • Soukromá dětská videa nemusí přehrávat\n• Živočišná zvířata začínající od začátku\n• Videa mohou skončit 1 sekundu na začátku\n• Žádný opus zvukový kodek
+ • Soukromé děti videa nemusí přehrávat\n• Živočišné rekony začínající od začátku\n• Videa mohou skončit 1 sekundu
Boční efekty Android VR
• Dětská videa nemusí přehrát\n• Menu zvukové stopy chybí\n• Stabilní hlasitost není k dispozici
+ Video streamy jsou falešné
+ Preferovaný jazyk audio streamu
+ Jazyk aplikace
+ Arabština
+ Ázerbájdžán
+ Bulharština
+ bengálština
+ Katalánština
+ Čeština
+ Dánština
+ Němčina
+ Řečtina
+ Angličtina
+ Španělština
+ Estonština
+ Perština
+ Finština
+ Francouzština
+ Gujarati
+ Hindština
+ Chorvatština
+ Maďarština
+ Indonéština
+ Italština
+ Japonština
+ Kazakh
+ Korejština
+ Litevština
+ lotyšština
+ makedonština
+ Mongolština
+ Maráthština
+ Malajština
+ Burmese
+ Holandština
+ Odia
+ Punjabi
+ Polština
+ Portugalština (Brazílie)
+ Portugalština (Portugalsko)
+ Rumunština
+ Ruština
+ Slovenština
+ Slovene
+ Srbština
+ Švédština
+ Svahilština
+ Tamil
+ Telugu
+ Thajština
+ Turecký
+ Ukrajinština
+ Urdština
+ Vietnamese
+ Čínština
diff --git a/patches/src/main/resources/addresources/values-da-rDK/strings.xml b/patches/src/main/resources/addresources/values-da-rDK/strings.xml
index 570b2df4a0..b28440a2b0 100644
--- a/patches/src/main/resources/addresources/values-da-rDK/strings.xml
+++ b/patches/src/main/resources/addresources/values-da-rDK/strings.xml
@@ -699,6 +699,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Spiller popup paneler er skjult
Spiller popup paneler vises
+
+ Åbn videoer i fuldskærm portræt
+ Videoer åbne fuld skærm
+ Videoer åbner ikke fuld skærm
+
Spiller overlay gennemsigtighed
Gennemsigtighedsværdi mellem 0-100, hvor 0 er gennemsigtig
@@ -1183,14 +1188,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
At slå denne indstilling fra kan forårsage problemer med videoafspilning.
Standard klient
Gennemtving AVC (H.264)
- Video codec er AVC (H.264)
- Video-codec er VP9 eller AV1
- Din enhed har ikke VP9 hardwareafkodning, og denne indstilling er altid tændt, når Client spoofing er aktiveret
- Aktivering af dette kan forbedre batteriets levetid og rette afspilningsstuttering.\n\nAVC har en maksimal opløsning på 1080p, og videoafspilning vil bruge flere internetdata end VP9 eller AV1.
+ Video-codec er tvunget til AVC (H.264)
+ Video-codec bestemmes automatisk
+ Aktivering af dette kan forbedre batteriets levetid og rette afspilningsstuttering.\n\nAVC har en maksimal opløsning på 1080p, Opus audio codec er ikke tilgængelig, og videoafspilning vil bruge flere internetdata end VP9 eller AV1.
iOS forfalskning bivirkninger
- • Private børn videoer kan ikke afspille\n• Livestreams starter fra begyndelsen\n• Videoer kan ende 1 sekund tidlig\n• Ingen opus audio codec
+ • Private børn videoer kan ikke afspille\n• Livestreams starter fra begyndelsen\n• Videoer kan ende 1 sekund tidlig
Android VR spoofing bivirkninger
• Kids videoer afspiller muligvis ikke\n• Menuen for lydspor mangler\n• Stabil lydstyrke er ikke tilgængelig
+ Video streams er spoofed
+ Foretrukket lyd-stream sprog
+ App sprog
+ Arabisk
+ Aserbajdsjansk
+ Bulgarsk
+ Bengalsk
+ Catalansk
+ Tjekkisk
+ Dansk
+ Tysk
+ Græsk
+ Engelsk
+ Spansk
+ Estisk
+ Persisk
+ Finsk
+ Fransk
+ Gujarati
+ Hindi
+ Kroatisk
+ Ungarsk
+ Indonesisk
+ Italiensk
+ Japansk
+ Kazakh
+ Koreansk
+ Litauisk
+ Lettisk
+ Makedonsk
+ Mongolsk
+ Marathi
+ Malaysisk
+ Burmese
+ Hollandsk
+ Odia
+ Punjabi
+ Polsk
+ Portugisisk (Brasilien)
+ Portugisisk (Portugal)
+ Rumænsk
+ Russisk
+ Slovakisk
+ Slovene
+ Serbisk
+ Svensk
+ Swahili
+ Tamil
+ Telugu
+ Thailandsk
+ Tyrkisk
+ Ukrainsk
+ Urdu
+ Vietnamese
+ Kinesisk
diff --git a/patches/src/main/resources/addresources/values-de-rDE/strings.xml b/patches/src/main/resources/addresources/values-de-rDE/strings.xml
index 4651b79ea0..08b5b64e72 100644
--- a/patches/src/main/resources/addresources/values-de-rDE/strings.xml
+++ b/patches/src/main/resources/addresources/values-de-rDE/strings.xml
@@ -710,6 +710,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Player-Popup-Fenster sind ausgeblendet
Player-Popup-Fenster werden angezeigt
+
+ Videos im Vollbild-Hochformat öffnen
+ Videos im Vollbild öffnen
+ Videos öffnen nicht Vollbild
+
Spieler-Überlagerung Deckkraft
Deckkraft Wert zwischen 0-100, wobei 0 transparent ist
@@ -1201,14 +1206,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Das Deaktivieren dieser Einstellung kann zu Videowiedergabeproblemen führen.
Standard-Client
AVC erzwingen (H.264)
- Video Codec ist AVC (H.264)
- Video Codec ist VP9 oder AV1
- Ihr Gerät hat keine VP9-Hardware-Dekodierung, und diese Einstellung ist immer aktiviert, wenn Client-Spoofing aktiviert ist
- Das Aktivieren kann die Akkulaufzeit verbessern und die Wiedergabe-Stutting beheben.\n\nAVC hat eine maximale Auflösung von 1080p, und die Videowiedergabe wird mehr Internet-Daten als VP9 oder AV1 verwenden.
+ Video-Codec ist zu AVC gezwungen (H.264)
+ Video-Codec wird automatisch bestimmt
+ Das Aktivieren kann die Akkulaufzeit verbessern und die Wiedergabe-Stutting beheben.\n\nAVC hat eine maximale Auflösung von 1080p, Opus Audio Codec ist nicht verfügbar und Video-Wiedergabe wird mehr Internet-Daten als VP9 oder AV1 verwenden.
iOS Spoofing Nebeneffekte
- • Videos für Privatkinder dürfen nicht\nabspielen • Livestreams beginnen von Anfang an\n• Videos können 1 Sekunde früher\n• Kein opus Audio Codec
+ • Videos für private Kinder dürfen nicht\nabspielen • Livestreams beginnen von Anfang an\n• Videos können 1 Sekunde früher enden
Android VR Spoofing Nebeneffekte
• Kindervideos dürfen nicht\nabspielen • Audiospurmenü fehlt\n• Stabile Lautstärke ist nicht verfügbar
+ Video-Streams sind gefälscht
+ Bevorzugte Audio-Stream-Sprache
+ App-Sprache
+ Arabisch
+ Aserbaidschan
+ Bulgarisch
+ Bengalisch
+ Katalanisch
+ Tschechisch
+ Dänisch
+ Deutsch
+ Griechisch
+ Englisch
+ Spanisch
+ Estnisch
+ Persisch
+ Finnisch
+ Französisch
+ Gujarati
+ Hannah
+ Kroatisch
+ Ungarisch
+ Indonesisch
+ Italienisch
+ Japanisch
+ Kazakh
+ Koreanisch
+ Litauisch
+ Lettisch
+ Makedonisch
+ Mongolisch
+ Marathi
+ Malaiisch
+ Burmese
+ Niederländisch
+ Odia
+ Punjabi
+ Polnisch
+ Portugiesisch (Brasilien)
+ Portugiesisch (Portugal)
+ Rumänisch
+ Russisch
+ Slowakisch
+ Slovene
+ Serbisch
+ Schwedisch
+ Swahili
+ Tamil
+ Telugu
+ Thailändisch
+ Türkisch
+ Ukrainische
+ Urdu
+ Vietnamese
+ Chinesisch
diff --git a/patches/src/main/resources/addresources/values-el-rGR/strings.xml b/patches/src/main/resources/addresources/values-el-rGR/strings.xml
index 3c82ea91ae..6208e9159a 100644
--- a/patches/src/main/resources/addresources/values-el-rGR/strings.xml
+++ b/patches/src/main/resources/addresources/values-el-rGR/strings.xml
@@ -709,6 +709,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Κρυμμένα
Εμφανίζονται
+
+ Άνοιγμα των βίντεο σε πλήρη οθόνη με κατακόρυφη προβολή
+ Τα βίντεο ανοίγουν σε λειτουργία πλήρους οθόνης
+ Τα βίντεο δεν ανοίγουν σε λειτουργία πλήρους οθόνης
+
Αδιαφάνεια φόντου οθόνης αναπαραγωγής
Τιμή αδιαφάνειας μεταξύ 0-100, όπου το 0 είναι διαφανές
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Η απενεργοποίηση αυτής της ρύθμισης ενδέχεται να προκαλέσει προβλήματα αναπαραγωγής βίντεο.
Προεπιλεγμένο πρόγραμμα πελάτη
Εξαναγκασμός AVC (H.264)
- Ο κωδικοποιητής βίντεο είναι ο AVC (H.264)
- Ο κωδικοποιητής βίντεο είναι ο VP9 ή ο AV1
- Η συσκευή σας δεν διαθέτει αποκωδικοποίηση υλικού VP9, και αυτή η ρύθμιση είναι πάντα ενεργή όταν είναι ενεργοποιημένη η παραποίηση προγράμματος πελάτη
- Ενεργοποιώντας αυτόν τον κωδικοποιητή ίσως να βελτιώσει κατανάλωση ενέργειας και ίσως διορθώσει κολλήματα αναπαραγωγής.\n\nΟ AVC έχει μέγιστη ανάλυση 1080p, και καταναλώνει περισσότερα δεδομένα internet από τον VP9 ή τον AV1.
+ Ο κωδικοποιητής βίντεο έχει οριστεί υποχρεωτικά σε AVC (H.264)
+ Ο κωδικοποιητής βίντεο ορίζεται αυτόματα
+ Η ενεργοποίηση αυτού μπορεί να βελτιώσει τη διάρκεια ζωής της μπαταρίας και να διορθώσει κολλήματα αναπαραγωγής.\n\nΟ AVC έχει μέγιστη ανάλυση 1080p, ο κωδικοποιητής ήχου Opus δεν είναι διαθέσιμος και η αναπαραγωγή βίντεο θα καταναλώνει περισσότερα δεδομένα internet από τον VP9 ή τον AV1.
Παρενέργειες παραποίησης σε iOS
- • Ιδιωτικά βίντεο για παιδιά ενδεχομένως να μην αναπαράγονται\n• Οι ζωντανές μεταδόσεις ξεκινούν από την αρχή\n• Τα βίντεο ενδέχεται να λήξουν 1 δευτερόλεπτο νωρίτερα\n• Δεν υπάρχει κωδικοποιητής ήχου opus
+ • Ιδιωτικά βίντεο για παιδιά ενδεχομένως να μην αναπαράγονται\n• Οι ζωντανές μεταδόσεις ξεκινούν από την αρχή\n• Τα βίντεο ενδέχεται να λήξουν 1 δευτερόλεπτο νωρίτερα
Παρενέργειες παραποίησης σε Android VR
• Τα βίντεο για παιδιά ενδέχεται να μην αναπαράγονται\n• Το μενού «Κομμάτι ήχου» λείπει\n• Η λειτουργία «Σταθερή ένταση» δεν είναι διαθέσιμη
+ Οι ροές βίντεο παραποιούνται
+ Προτιμώμενη γλώσσα ροής ήχου
+ Γλώσσα εφαρμογής
+ Αραβικά
+ Αζερμπαϊτζανικά
+ Βουλγαρικά
+ Βεγγαλικά
+ Καταλανικά
+ Τσέχικα
+ Δανέζικα
+ Γερμανικά
+ Ελληνικά
+ Αγγλικά
+ Ισπανικά
+ Εσθονικά
+ Περσικά
+ Φινλανδικά
+ Γαλλικά
+ Γκουτζαρατικά
+ Χίντι
+ Κροατικά
+ Ουγγρικά
+ Ινδονησιακά
+ Ιταλικά
+ Ιαπωνικά
+ Καζακικά
+ Κορεάτικα
+ Λιθουανικά
+ Λετονικά
+ Σλαβομακεδονικά
+ Μογγολικά
+ Μαραθικά
+ Μαλαισιανά
+ Βιρμανικά
+ Ολλανδικά
+ Όντια
+ Παντζάμπι
+ Πολωνικά
+ Πορτογαλικά (Βραζιλίας)
+ Πορτογαλικά (Πορτογαλίας)
+ Ρουμανικά
+ Ρωσικά
+ Σλοβακικά
+ Σλοβενικά
+ Σερβικά
+ Σουηδικά
+ Σουαχίλι
+ Ταμιλικά
+ Τελούγκου
+ Ταϊλανδικά
+ Τουρκικά
+ Ουκρανικά
+ Ουρντού
+ Βιετναμέζικα
+ Κινέζικα
diff --git a/patches/src/main/resources/addresources/values-es-rES/strings.xml b/patches/src/main/resources/addresources/values-es-rES/strings.xml
index fe93fe9634..7309866c51 100644
--- a/patches/src/main/resources/addresources/values-es-rES/strings.xml
+++ b/patches/src/main/resources/addresources/values-es-rES/strings.xml
@@ -709,6 +709,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Los paneles emergentes del jugador están ocultos
Se muestran paneles emergentes del jugador
+
+ Abrir vídeos en el retrato de pantalla completa
+ Videos abiertos a pantalla completa
+ Los videos no se abren en pantalla completa
+
Opacidad de superposición del jugador
Valor de potencia entre 0-100, donde 0 es transparente
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Desactivar esta configuración puede causar problemas de reproducción de vídeo.
Cliente por defecto
Forzar AVC (H.264)
- Codec de vídeo AVC (H.264)
- El códec de vídeo es VP9 o AV1
- Su dispositivo no tiene decodificación de hardware VP9, y esta configuración siempre está encendida cuando el cliente spoofing está habilitado
- Activar esto puede mejorar la vida de la batería y corregir el retraso en la reproducción.\n\nAVC tiene una resolución máxima de 1080p, y la reproducción de vídeo utilizará más datos de Internet que VP9 o AV1.
+ Códec de vídeo se ve obligado a AVC (H.264)
+ El códec de vídeo se determina automáticamente
+ Activar esto puede mejorar la vida de la batería y corregir el retraso en la reproducción.\n\nAVC tiene una resolución máxima de 1080p, el código de audio Opus no está disponible. y la reproducción de vídeo utilizará más datos de Internet que VP9 o AV1.
Efectos secundarios para la falsificación de iOS
- • Los vídeos de niños privados no pueden reproducir\n• Livestreams comienzan desde el principio\n• Los vídeos pueden terminar 1 segundo antes de\n• No hay código de audio de opus
+ • Los vídeos de niños privados no pueden reproducir\n• Livestreams comienzan desde el principio\n• Los vídeos pueden terminar temprano 1 segundo
Efectos secundarios para la falsificación de Android RV
• Los vídeos infantiles no pueden reproducir\n• Falta el menú de pista de audio\n• El volumen estable no está disponible
+ El stream de vídeo está falsificado
+ Idioma de flujo de audio preferido
+ Idioma de la aplicación
+ Árabe
+ Бессия
+ Búlgaro
+ Bengalí
+ Catalán
+ Checo
+ Danés
+ Alemán
+ Griego
+ Inglés
+ Español
+ Estonio
+ Persa
+ Finlandés
+ Francés
+ Gujarati
+ Hindú
+ Croata
+ Húngaro
+ Indonesio/a
+ Italiano
+ Japonés
+ Kazakh
+ Coreano
+ Lituano
+ Letón
+ Macedonio
+ Mongol
+ Maratí
+ Malayo
+ Burmese
+ Holandés
+ Odia
+ Punjabi
+ Polaco
+ Portugués (Brasil)
+ Portugués (R)
+ Rumano
+ Ruso
+ Eslovaco
+ Slovene
+ Serbio
+ Sueco
+ Swahili
+ Tamil
+ Telugu
+ Tailandés
+ Turco
+ Ucraniano
+ Urdu
+ Vietnamese
+ Chino
diff --git a/patches/src/main/resources/addresources/values-et-rEE/strings.xml b/patches/src/main/resources/addresources/values-et-rEE/strings.xml
index 9932344420..0252d1bc56 100644
--- a/patches/src/main/resources/addresources/values-et-rEE/strings.xml
+++ b/patches/src/main/resources/addresources/values-et-rEE/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-eu-rES/strings.xml b/patches/src/main/resources/addresources/values-eu-rES/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-eu-rES/strings.xml
+++ b/patches/src/main/resources/addresources/values-eu-rES/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-fa-rIR/strings.xml b/patches/src/main/resources/addresources/values-fa-rIR/strings.xml
index 54a33df44a..570bdf4063 100644
--- a/patches/src/main/resources/addresources/values-fa-rIR/strings.xml
+++ b/patches/src/main/resources/addresources/values-fa-rIR/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-fi-rFI/strings.xml b/patches/src/main/resources/addresources/values-fi-rFI/strings.xml
index ac320bc2b3..b4dcf9c2dd 100644
--- a/patches/src/main/resources/addresources/values-fi-rFI/strings.xml
+++ b/patches/src/main/resources/addresources/values-fi-rFI/strings.xml
@@ -711,6 +711,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Soittimen ponnahdusikkunat on piilotettu
Soittimen ponnahdusikkunat näytetään
+
+ Avaa videot koko näytön muotokuvassa
+ Videot avataan kokoruututilassa
+ Videot eivät avaa kokoruututilaa
+
Soittimen peittoalueen läpinäkyvyys
Läpinäkyvyysarvo välillä 0–100, jossa 0 on läpinäkyvä
@@ -1202,14 +1207,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Tämän asetuksen poistaminen käytöstä voi aiheuttaa ongelmia videotoistossa.
Oletusasiakasohjelma
Pakota AVC (H.264)
- Videokoodekki on AVC (H.264)
- Videokoodekki on VP9 tai AV1
- Laitteessasi ei ole VP9-laitteiston dekoodausta, ja tämä asetus on aina päällä, kun asiakkaan spoofing on käytössä
- Tämän käyttöönotto voi parantaa akun kestoa ja korjata toistoa stuttering.\n\nAVC on suurin resoluutio 1080p, ja videon toisto käyttää enemmän internet-tietoja kuin VP9 tai AV1.
+ Videon koodekki pakotetaan AVC (H.264)
+ Videokoodekki määritetään automaattisesti
+ Tämän käyttöönotto voi parantaa akun kestoa ja korjata toistoa stuttering.\n\nAVC on enintään 1080p, Opus audio koodekki ei ole käytettävissä, ja videon toisto käyttää enemmän internet-tietoja kuin VP9 tai AV1.
iOS-naamioinnin haittavaikutukset
- • Yksityiset lapset videot eivät välttämättä pelaa\n• Livestreams alusta alkaen\n• Videot saattavat päättyä 1 sekunnin alkupuolella\n• Ei opus-äänikoodekkia
+ • Yksityiset lapset videot eivät välttämättä pelaa\n• Livestreams alkaa alusta\n• Videot saattavat päättyä 1 sekunti aikaisin
Android VR -naamioinnin haittavaikutukset
• Lapset videot eivät välttämättä soita\n• Ääniraidan valikko puuttuu\n• Vakaa äänenvoimakkuus ei ole käytettävissä
+ Videostriimit naamioidaan
+ Ensisijainen äänen suoratoistokieli
+ Sovelluksen kieli
+ Arabia
+ Azerbaidžan
+ Bulgaria
+ Bengali
+ Katalaani
+ Tšekki
+ Tanska
+ Saksa
+ Kreikka
+ Englanti
+ Espanja
+ Viro
+ Persia
+ Suomi
+ Ranska
+ Gujarati
+ Hindi
+ Kroatia
+ Unkari
+ Indonesialainen
+ Italia
+ Japani
+ Kazakh
+ Korealainen
+ Liettua
+ Latvia
+ Makedonia
+ Mongolia
+ Marathi
+ Malaiji
+ Burmese
+ Hollanti
+ Odia
+ Punjabi
+ Puola
+ Portugali (Brasilia)
+ Portugali (Portugali)
+ Romania
+ Venäjä
+ Slovakki
+ Slovene
+ Serbia
+ Ruotsi
+ Swahili
+ Tamil
+ Telugu
+ Thaimaalainen
+ Turkki
+ Ukraina
+ Urdu
+ Vietnamese
+ Kiina
diff --git a/patches/src/main/resources/addresources/values-fil-rPH/strings.xml b/patches/src/main/resources/addresources/values-fil-rPH/strings.xml
index 6b688c88aa..3d1188bbf0 100644
--- a/patches/src/main/resources/addresources/values-fil-rPH/strings.xml
+++ b/patches/src/main/resources/addresources/values-fil-rPH/strings.xml
@@ -640,6 +640,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Nakatago ang mga popup panel ng player
Ipinapakita ang mga popup panel ng player
+
+
Opacity ng overlay ng player
Ang halaga ng opacity sa pagitan ng 0-100, kung saan ang 0 ay transparent
diff --git a/patches/src/main/resources/addresources/values-fr-rFR/strings.xml b/patches/src/main/resources/addresources/values-fr-rFR/strings.xml
index 1206ff7908..331b426929 100644
--- a/patches/src/main/resources/addresources/values-fr-rFR/strings.xml
+++ b/patches/src/main/resources/addresources/values-fr-rFR/strings.xml
@@ -710,6 +710,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Les fenêtres pop-up sont masquées
Les fenêtres pop-up sont affichées
+
+ Ouvrir les vidéos en mode portrait plein écran
+ Vidéos ouvertes en plein écran
+ Les vidéos ne s\'ouvrent pas en plein écran
+
Opacité de l\'overlay du joueur
Valeur d\'opacité entre 0 et 100, où 0 est transparent
@@ -1201,14 +1206,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Désactiver ce paramètre peut causer des problèmes de lecture vidéo.
Client par défaut
Forcer AVC (H.264)
- Le codec vidéo est AVC (H.264)
- Le codec vidéo est VP9 ou AV1
- Votre appareil ne possède pas de décodage matériel VP9, et ce paramètre est toujours activé lorsque la falsification du client est activée
- Activer ceci peut améliorer la durée de vie de la batterie et corriger les erreurs de lecture.\n\nAVC a une résolution maximale de 1080p, et la lecture vidéo utilisera plus de données internet que VP9 ou AV1.
+ Le codec vidéo est forcé à AVC (H.264)
+ Le codec vidéo est déterminé automatiquement
+ Activer ceci peut améliorer la durée de vie de la batterie et corriger les erreurs de lecture.\n\nAVC a une résolution maximale de 1080p, le codec audio Opus n\'est pas disponible, et la lecture vidéo utilisera plus de données Internet que VP9 ou AV1.
Effets secondaires d\'usurpation iOS
- • Les vidéos privées des enfants ne peuvent pas être lues\n• Les live reams commencent à partir de\n• Les vidéos peuvent se terminer 1 seconde tôt\n• Aucun codec audio opus
+ • Les vidéos privées des enfants peuvent ne pas jouer à\n• Les live reams commencent dès le début\n• Les vidéos peuvent se terminer 1 seconde plus tôt
Effets secondaires de l\'usurpation VR Android
• Les vidéos des enfants peuvent ne pas lire\n• Le menu de la piste audio manque\n• Le volume stable n\'est pas disponible
+ Les flux vidéo sont falsifiés
+ Langue préférée du flux audio
+ Langue de l\'application
+ Arabe
+ Azerbaïdjan
+ Bulgare
+ Bengalais
+ Catalan
+ Tchèque
+ Danois
+ Allemand
+ Grecque
+ Anglais
+ Espagnol
+ estonien
+ Perse
+ Finlandais
+ Français
+ Gujarati
+ Hindi
+ Croate
+ Hongrois
+ Indonésien
+ Italien
+ Japonais
+ Kazakh
+ Coréen
+ lituanien
+ Lettonie
+ Macédonien
+ Mongol
+ Marathi
+ Malais
+ Burmese
+ Néerlandais
+ Odia
+ Punjabi
+ Polonais
+ Portugais (Brésil)
+ Portugais (Portugal)
+ Roumain
+ Russe
+ Slovaque
+ Slovene
+ Serbe
+ Suédois
+ Swahili
+ Tamil
+ Telugu
+ Thaï
+ Turc
+ Ukrainien
+ Ourdou
+ Vietnamese
+ Chinois
diff --git a/patches/src/main/resources/addresources/values-ga-rIE/strings.xml b/patches/src/main/resources/addresources/values-ga-rIE/strings.xml
index 199709e80a..3c2d8e843a 100644
--- a/patches/src/main/resources/addresources/values-ga-rIE/strings.xml
+++ b/patches/src/main/resources/addresources/values-ga-rIE/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Tá painéil aníos imreoirí i bhfolach
Taispeántar painéil aníos imreoirí
+
+
Trédhearcacht forleagtha an imreoir
Luach trédhearcachta idir 0-100, áit a bhfuil 0 trédhearcach
@@ -1200,14 +1202,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Seans go mbeidh fadhbanna athsheinm físe ag baint leis an socrú seo a mhúchadh.
Cliant réamhshocraithe
Fórsa AVC (H.264)
- Is é AVC (H.264) an codec físeán
- Is é VP9 nó AV1 an codec físeán
- Níl díchódú crua-earraí VP9 ar do ghléas, agus bíonn an socrú seo ar siúl i gcónaí nuair atá spoofing Cliant cumasaithe
- Má dhéantar é seo a chumasú, d\'fhéadfadh sé go bhfeabhsófaí saol na gceallraí agus go n-athshocraigh sé stopáil athsheinm.\n\nTá uas-taifeach 1080p ag AVC, agus úsáidfidh athsheinm físe níos mó sonraí idirlín ná mar a úsáideann VP9 nó AV1.
Fo-iarsmaí spoofing iOS
- • Ní cheadaítear físeáin leanaí príobháideacha a sheinm\n• Tosaíonn sruthanna beo ón tús\n• Seans go gcríochnóidh físeáin 1 soicind go luath\n• Gan codec fuaime opus
+ Ní féidir físeáin phríobháideacha do pháistí a sheinm\n• Tosaíonn sruthanna beo ón tús\n• Féadfaidh físeáin críochnú 1 soicind go luath
Fo-iarsmaí spoofing Android VR
• Ní fhéadfaidh físeáin leanaí a sheinm\n• Tá an roghchlár rian fuaime ar iarraidh\n• Níl an toirt cobhsaí ar fáil
+ Tá sruthanna físe spoofed
diff --git a/patches/src/main/resources/addresources/values-gl-rES/strings.xml b/patches/src/main/resources/addresources/values-gl-rES/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-gl-rES/strings.xml
+++ b/patches/src/main/resources/addresources/values-gl-rES/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-gu-rIN/strings.xml b/patches/src/main/resources/addresources/values-gu-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-gu-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-gu-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-hi-rIN/strings.xml b/patches/src/main/resources/addresources/values-hi-rIN/strings.xml
index 4ca0dc1347..1d84b6c951 100644
--- a/patches/src/main/resources/addresources/values-hi-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-hi-rIN/strings.xml
@@ -149,6 +149,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-hr-rHR/strings.xml b/patches/src/main/resources/addresources/values-hr-rHR/strings.xml
index 9d8a5fdddc..6831a44fa6 100644
--- a/patches/src/main/resources/addresources/values-hr-rHR/strings.xml
+++ b/patches/src/main/resources/addresources/values-hr-rHR/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-hu-rHU/strings.xml b/patches/src/main/resources/addresources/values-hu-rHU/strings.xml
index f8631eedd4..09683ad5bf 100644
--- a/patches/src/main/resources/addresources/values-hu-rHU/strings.xml
+++ b/patches/src/main/resources/addresources/values-hu-rHU/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
A lejátszó előugró panelei el vannak rejtve
A lejátszó előugró panelei megjelennek
+
+
Lejátszó fedőrétegének átlátszatlansága
Az átlátszatlanság értéke 0 és 100 között van, ahol a 0 átlátszó
@@ -1200,14 +1202,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
A beállítás kikapcsolása videolejátszási problémákat okozhat.
Alapértelmezett kliens
AVC (H.264) kényszerítése
- A videokodek AVC (H.264)
- A videokodek VP9 vagy AV1
- Eszközén nincs VP9 hardveres dekódolás, és ez a beállítás mindig be van kapcsolva, ha az ügyfélhamisítás engedélyezve van
- Ennek engedélyezése javíthatja az akkumulátor élettartamát, és kijavíthatja a lejátszás akadozását.\n\nAz AVC maximális felbontása 1080p, és a videolejátszás több internetadatot használ, mint a VP9 vagy az AV1.
iOS hamisítási mellékhatások
- • Előfordulhat, hogy a privát gyerekeknek készült videókat nem lehet lejátszani\n• Az élő közvetítések az elejétől kezdődnek.\n• A videók 1 másodperccel korábban véget érhetnek\n• Nincs opus audiokodek
+ • Előfordulhat, hogy a privát gyerekeknek szóló videók nem játszhatók le\n• Az élő közvetítések elölről kezdődnek\n• A videók 1 másodperccel korábban véget érhetnek
Android VR-hamisítási mellékhatások
• Előfordulhat, hogy a gyerekvideókat nem lehet lejátszani\n• Hiányzik a hangsáv menü\n• A stabil hangerő nem érhető el
+ A videó stream hamisítva
diff --git a/patches/src/main/resources/addresources/values-hy-rAM/strings.xml b/patches/src/main/resources/addresources/values-hy-rAM/strings.xml
index 5abb9a012a..07587de533 100644
--- a/patches/src/main/resources/addresources/values-hy-rAM/strings.xml
+++ b/patches/src/main/resources/addresources/values-hy-rAM/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-in-rID/strings.xml b/patches/src/main/resources/addresources/values-in-rID/strings.xml
index 079b912450..ef3edb68f4 100644
--- a/patches/src/main/resources/addresources/values-in-rID/strings.xml
+++ b/patches/src/main/resources/addresources/values-in-rID/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Panel popup pemutar disembunyikan
Panel popup pemutar ditampilkan
+
+
Opasitas hamparan pemutar
Nilai opasitas antara 0-100, dimana 0 adalah transparan
@@ -1200,14 +1202,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Mematikan pengaturan ini dapat menyebabkan masalah pemutaran video.
Klien bawaan
Paksa AVC (H.264)
- Kodek video adalah AVC (H.264)
- Kodek video adalah VP9 atau AV1
- Perangkat Anda tidak memiliki dekode perangkat keras VP9, dan pengaturan ini selalu aktif saat pemalsuan Klien diaktifkan
- Menyalakan ini dapat meningkatkan masa pakai baterai dan memperbaiki gangguan pemutaran.\n\nAVC memiliki resolusi maksimum 1080p, dan pemutaran video akan menggunakan lebih banyak data internet daripada VP9 atau AV1.
Efek samping pemalsuan iOS
- • Video anak-anak pribadi mungkin tidak dapat diputar\n• Siaran langsung dimulai dari awal\n• Video mungkin berakhir 1 detik lebih awal\n• Tidak ada codec audio opus
+ • Video privat anak-anak tidak dapat diputar\n• Siaran langsung dimulai dari awal\n• Video akan berakhir 1 detik lebih awal
Efek samping pemalsuan Android VR
• Video anak-anak mungkin tidak dapat diputar\n• Menu trek audio tidak ada\n• Volume stabil tidak tersedia
+ Aliran video dipalsukan
diff --git a/patches/src/main/resources/addresources/values-is-rIS/strings.xml b/patches/src/main/resources/addresources/values-is-rIS/strings.xml
index 7350387f63..e45b093602 100644
--- a/patches/src/main/resources/addresources/values-is-rIS/strings.xml
+++ b/patches/src/main/resources/addresources/values-is-rIS/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-it-rIT/strings.xml b/patches/src/main/resources/addresources/values-it-rIT/strings.xml
index 7c9f621fb0..e259475b58 100644
--- a/patches/src/main/resources/addresources/values-it-rIT/strings.xml
+++ b/patches/src/main/resources/addresources/values-it-rIT/strings.xml
@@ -709,6 +709,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
I pannelli popup del player sono nascosti
I pannelli popup del player sono visibili
+
+ Apri video in verticale a schermo intero
+ Video aperti a schermo intero
+ I video non aprono schermo intero
+
Opacità sovrapposizione del player
Il valore dell\'opacità compreso tra 0 e 100, dove 0 è trasparente
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Disattivando questa impostazione potrebbe causare problemi di riproduzione video.
Client predefinito
Forza AVC (H.264)
- Il codec video è AVC (H.264)
- Il codec video è VP9 o AV1
- Il tuo dispositivo non ha la decodifica hardware VP9 e questa impostazione è sempre attiva quando la simulazione del client è abilitato
- L\'attivazione di questa impostazione potrebbe migliorare la durata della batteria e risolvere il problema della riproduzione a scatti.\n\nNota: AVC ha una risoluzione massima di 1080p e la riproduzione userà più dati internet rispetto a VP9 o AV1.
+ Il codec video è forzato ad AVC (H.264)
+ Il codec video viene determinato automaticamente
+ Abilitando questo si potrebbe migliorare la durata della batteria e correggere la riproduzione della balbuzia.\n\nAVC ha una risoluzione massima di 1080p, il codec audio Opus non è disponibile, e la riproduzione video utilizzerà più dati internet di VP9 o AV1.
Effetti collaterali simulazione iOS
- • I video privati per bambini potrebbero non essere riprodotti\n• Le dirette iniziano dall\'inizio\n• I video potrebbero terminare 1 secondo prima\n• Nessun codec audio Opus
+ • I video privati per bambini potrebbero non riprodurre\n• Livestreams start from the beginning\n• Video potrebbero terminare 1 secondo presto
Effetti collaterali simulazione Android VR
• I video per bambini potrebbero non riprodurre\n• Il menu traccia audio è mancante\n• Volume stabile non è disponibile
+ Il client del flusso video è simulato
+ Lingua del flusso audio preferita
+ Lingua app
+ Arabo
+ Azerbaigian
+ Bulgaro
+ Bengalese
+ Catalano
+ Ceco
+ Danese
+ Tedesco
+ Greco
+ Inglese
+ Spagnolo
+ Estone
+ Persiano
+ Finlandese
+ Français
+ Gujarati
+ Hindi
+ Croato
+ Ungherese
+ Indonesiano
+ Italiano
+ Giapponese
+ Kazakh
+ Coreano
+ Lituano
+ Lettone
+ Macedone
+ Mongolo
+ Marathi
+ Malese
+ Burmese
+ Olandese
+ Odia
+ Punjabi
+ Polacco
+ Portoghese (Brasile)
+ Portoghese (Portogallo)
+ Rumeno
+ Russo
+ Slovacco
+ Slovene
+ Serbo
+ Svedese
+ Swahili
+ Tamil
+ Telugu
+ Tailandese
+ Turco
+ Ucraino
+ Urdu
+ Vietnamese
+ Cinese
diff --git a/patches/src/main/resources/addresources/values-iw-rIL/strings.xml b/patches/src/main/resources/addresources/values-iw-rIL/strings.xml
index bfc7338d84..3eeceedef2 100644
--- a/patches/src/main/resources/addresources/values-iw-rIL/strings.xml
+++ b/patches/src/main/resources/addresources/values-iw-rIL/strings.xml
@@ -164,6 +164,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ja-rJP/strings.xml b/patches/src/main/resources/addresources/values-ja-rJP/strings.xml
index c82a5ccb5e..cc5ecef354 100644
--- a/patches/src/main/resources/addresources/values-ja-rJP/strings.xml
+++ b/patches/src/main/resources/addresources/values-ja-rJP/strings.xml
@@ -695,6 +695,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
プレーヤーのポップアップパネルが非表示になります
プレーヤーのポップアップパネルが表示されます
+
+ 全画面表示で動画を開く
+ 動画を全画面表示で開く
+ 動画が全画面表示されません
+
プレイヤーオーバーレイの透明度
透明度の値は 0〜100 の範囲で、0 が透明です
@@ -1178,12 +1183,66 @@ This is because Crowdin requires temporarily flattening this file and removing t
この設定をオフにすると、ビデオ再生の問題が発生する可能性があります。
デフォルトのクライアント
強制AVC (H.264)
- ビデオコーデックは AVC (H.264) です
- ビデオコーデックはVP9またはAV1です
- お使いのデバイスにはVP9ハードウェアデコードがありません。この設定はクライアントのスプーフィングが有効になっているときに常に有効になります
- これを有効にするとバッテリー寿命と再生の途切れが改善する可能性があります。\n\nAVCの最大解像度は1080pで、ビデオ再生はVP9やAV1よりも多くの通信量を使用します。
+ ビデオコーデックはAVCに強制されました (H.264)
+ ビデオコーデックが自動的に決定されます
+ これを有効にするとバッテリー寿命が延長され、再生が停止する可能性があります。\n\nAVCの最大解像度は1080pで、Opusオーディオコーデックは利用できません。 動画再生は、VP9やAV1よりも多くのインターネットデータを使用します。
iOSのクライアント偽装での副作用
Android-VR クライアント偽装の副作用
+ ビデオストリームはなりすましています
+ 優先オーディオストリーム言語
+ アプリの言語
+ アラビア文字
+ アゼルバイジャン語
+ ブルガリア語
+ ベンガル語
+ カタロニア語
+ チェコ語
+ デンマーク語
+ ドイツ語
+ ギリシア語
+ 英語
+ スペイン語
+ エストニア語
+ ペルシャ語
+ フィンランド語
+ Français
+ Gujarati
+ ヒンディー語
+ クロアチア語
+ ハンガリー語
+ インドネシア語
+ イタリア語
+ 日本語
+ Kazakh
+ Korean
+ リトアニア語
+ ラトビア語
+ マケドニア語
+ モンゴル語
+ Marathi
+ マレー語
+ Burmese
+ オランダ語
+ Odia
+ Punjabi
+ ポーランド語
+ ポルトガル語 (ブラジル)
+ ポルトガル語 (ポルトガル)
+ ルーマニア語
+ ロシア語
+ スロバキア語
+ Slovene
+ セルビア語
+ スウェーデン語
+ スワヒリ語
+ Tamil
+ Telugu
+ タイ語
+ トルコ語
+ ウクライナ語
+ ウルドゥー語
+ Vietnamese
+ 中国語
diff --git a/patches/src/main/resources/addresources/values-ka-rGE/strings.xml b/patches/src/main/resources/addresources/values-ka-rGE/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-ka-rGE/strings.xml
+++ b/patches/src/main/resources/addresources/values-ka-rGE/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-kk-rKZ/strings.xml b/patches/src/main/resources/addresources/values-kk-rKZ/strings.xml
index 3c7a7e561e..95d2c20eb5 100644
--- a/patches/src/main/resources/addresources/values-kk-rKZ/strings.xml
+++ b/patches/src/main/resources/addresources/values-kk-rKZ/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-km-rKH/strings.xml b/patches/src/main/resources/addresources/values-km-rKH/strings.xml
index 29efa3385b..c52561d7d0 100644
--- a/patches/src/main/resources/addresources/values-km-rKH/strings.xml
+++ b/patches/src/main/resources/addresources/values-km-rKH/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-kn-rIN/strings.xml b/patches/src/main/resources/addresources/values-kn-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-kn-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-kn-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ko-rKR/strings.xml b/patches/src/main/resources/addresources/values-ko-rKR/strings.xml
index 2548ae1e94..b0c210df01 100644
--- a/patches/src/main/resources/addresources/values-ko-rKR/strings.xml
+++ b/patches/src/main/resources/addresources/values-ko-rKR/strings.xml
@@ -221,8 +221,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
아티스트 카드가 숨겨집니다
아티스트 카드가 표시됩니다
속성 섹션 숨기기
- 게임 섹션, 음악 섹션 그리고 동영상 속 장소 섹션이 숨겨집니다
- 게임 섹션, 음악 섹션 그리고 동영상 속 장소 섹션이 표시됩니다
+ 게임, 음악, 동영상 속 장소 그리고 언급된 인물 섹션이 숨겨집니다
+ 게임, 음악, 동영상 속 장소 그리고 언급된 인물 섹션이 표시됩니다
챕터 섹션 숨기기
챕터 섹션이 숨겨집니다
챕터 섹션이 표시됩니다
@@ -304,7 +304,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
홈 / 구독 / 검색 결과가 필터링되어 키워드 구문과 일치하는 콘텐츠가 숨겨집니다\n\n알려진 문제점:\n• 채널 이름으로 Shorts는 숨길 수 없습니다\n• 일부 화면 구성요소는 숨겨지지 않을 수 있습니다\n• 필터링 키워드를 검색하면 검색 결과가 표시되지 않을 수 있습니다
전체 단어 일치시키기
- 필터링할 키워드 및 구문을 큰따옴표로 묶으면 동영상 제목과 채널 이름이 부분적으로 일치하지 않도록 방지할 수 있습니다<br><br>예를 들어,<br><b>\"ai\"</b>라는 키워드로 <b>AI 커리어 완벽 가이드</b>라는 제목의 동영상을 숨길 수 있지만, <b>생성형AI가 바꿔놓은 세계</b> 또는 <b>What does fair use mean?</b>라는 제목의 동영상은 숨길 수 없습니다
+ 필터링할 키워드 및 구문을 큰따옴표로 묶으면 동영상 제목과 채널 이름이 부분적으로 일치하지 않도록 방지할 수 있습니다<br><br>• 예를 들어, <b>\"ai\"</b>라는 키워드로 <b>AI 커리어 완벽 가이드</b>라는 동영상을 숨길 수 있지만, <b>생성형AI가 바꿔놓은 세계</b> 또는 <b>What does fair use mean?</b>라는 동영상은 숨길 수 없습니다<br>• 그리고 구두점을 단어의 경계로 간주하기 때문에 <b>인공지능(AI)의 원리</b>라는 동영상은 숨길 수 있습니다. 큰따옴표는 다른 단어 내부의 하위 문자열만 무시합니다 (예: <b>fair</b>는 숨길 수 없지만, <b>f(ai)r</b>는 숨김)
키워드를 사용할 수 없습니다: %s
따옴표를 추가하여 키워드를 사용합니다: %s
@@ -364,11 +364,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
URL을 클립보드에 복사하였습니다
타임스탬프를 표기한 URL을 클립보드에 복사하였습니다
동영상 URL 복사 버튼 표시하기
- 버튼을 표시합니다. 버튼을 눌러서 동영상 URL을 복사할 수 있습니다. 길게 누르면 타임스탬프를 표기한 동영상 URL이 복사됩니다
- 버튼을 표시하지 않습니다
+ 버튼을 눌러서 동영상 URL을 복사할 수 있습니다\n길게 누르면 타임스탬프를 표기한 동영상 URL이 복사됩니다
+ 버튼을 눌러서 동영상 URL을 복사할 수 있습니다\n길게 누르면 타임스탬프를 표기한 동영상 URL이 복사됩니다
타임스탬프를 표기한 URL 복사 버튼 표시하기
- 버튼을 표시합니다. 버튼을 눌러서 타임스탬프를 표기한 동영상 URL을 복사할 수 있습니다. 길게 누르면 타임스탬프를 표기하지 않은 동영상 URL이 복사됩니다
- 버튼을 표시하지 않습니다
+ 버튼을 눌러서 타임스탬프를 표기한 동영상 URL을 복사할 수 있습니다\n길게 누르면 타임스탬프를 표기하지 않은 동영상 URL이 복사됩니다
+ 버튼을 눌러서 타임스탬프를 표기한 동영상 URL을 복사할 수 있습니다\n길게 누르면 타임스탬프를 표기하지 않은 동영상 URL이 복사됩니다
시청 경고 다이얼로그 제거하기
@@ -710,6 +710,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
플레이어 팝업 패널이 숨겨집니다\n• 재생목록, 실시간 채팅, etc.
플레이어 팝업 패널이 표시됩니다\n• 재생목록, 실시간 채팅, etc.
+
+
플레이어 오버레이 불투명도
불투명도 값은 0-100 사이이며, 0은 투명입니다
@@ -1029,7 +1031,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
드래그 & 드롭을 활성화합니다\n\n• 미니 플레이어를 화면의 어느 곳이든 드래그할 수 있습니다
드래그 & 드롭을 비활성화합니다
수평 드래그 제스처 활성화하기
- 수평 드래그 제스처를 활성화합니다\n\n미니 플레이어를 화면에서 왼쪽 또는 오른쪽으로 드래그할 수 있습니다
+ 수평 드래그 제스처를 활성화합니다\n\n미니 플레이어 절반 정도를 왼쪽 밖 또는 오른쪽 밖으로 드래그하여 숨길 수 있습니다
수평 드래그 제스처를 비활성화합니다
닫기 버튼 숨기기
닫기 버튼이 숨겨집니다
@@ -1201,14 +1203,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
이 설정을 비활성화하면 동영상 재생 문제가 발생할 수 있습니다
기본 클라이언트
AVC (H.264) 강제로 활성화하기
- 동영상 코덱을 AVC (H.264)로 활성화합니다\n\n• 일부 VP9 코덱 동영상에서 제거되었던 화질 값들이 표시될 수 있습니다.\n• 최대 화질 값이 1080p이므로 초고화질 동영상을 재생할 수 없습니다.\n• HDR 동영상을 재생할 수 없습니다
- 동영상 코덱을 VP9 또는 AV1으로 활성화합니다\n\n• 예전에 업로드된 동영상을 재생했는데 VP9 코덱 응답을 받았을 경우, 일부 화질 값들이 제거되어 360p와 1080p(Premium 기능)만 선택할 수 있거나 화질 메뉴를 선택할 수 없을 수 있습니다
- 이 기기는 VP9 하드웨어 디코딩을 지원하지 않습니다. 그러므로 \'클라이언트 변경하기\'가 활성화된 경우에는 이 설정은 항상 켜져 있습니다
- 이 설정을 활성화하면 배터리 수명이 향상되고 재생 끊김 현상이 해결될 수 있습니다\n\nAVC의 최대 화질 값은 1080p이며 동영상을 재생하면 VP9 또는 AV1보다 더 많은 모바일 데이터가 사용되오니 주의하세요.
\'iOS로 변경\'의 알려진 문제점
- • 비공개 Kids 동영상이 재생되지 않을 수 있습니다\n• 일부 실시간 스트림이 처음부터 시작될 수 있습니다\n• 동영상이 1초 일찍 종료될 수 있습니다\n• OPUS 오디오 코덱이 지원되지 않습니다
+ • 비공개 Kids 동영상이 재생되지 않을 수 있습니다\n• 일부 실시간 스트림이 처음부터 재생될 수 있습니다\n• 동영상이 1초 일찍 종료될 수 있습니다
\'Android VR로 변경\'의 알려진 문제점
• Kids 동영상이 재생되지 않을 수 있습니다\n• 오디오 트랙 메뉴가 표시되지 않습니다\n• 안정적인 볼륨 메뉴가 비활성화된 채로 잠겨있습니다
+ 스트리밍 데이터를 변경합니다
diff --git a/patches/src/main/resources/addresources/values-ky-rKG/strings.xml b/patches/src/main/resources/addresources/values-ky-rKG/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-ky-rKG/strings.xml
+++ b/patches/src/main/resources/addresources/values-ky-rKG/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-lo-rLA/strings.xml b/patches/src/main/resources/addresources/values-lo-rLA/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-lo-rLA/strings.xml
+++ b/patches/src/main/resources/addresources/values-lo-rLA/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-lt-rLT/strings.xml b/patches/src/main/resources/addresources/values-lt-rLT/strings.xml
index 9d36ba8c73..994006ce94 100644
--- a/patches/src/main/resources/addresources/values-lt-rLT/strings.xml
+++ b/patches/src/main/resources/addresources/values-lt-rLT/strings.xml
@@ -150,6 +150,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-lv-rLV/strings.xml b/patches/src/main/resources/addresources/values-lv-rLV/strings.xml
index 22d09a13bd..bf0703ed07 100644
--- a/patches/src/main/resources/addresources/values-lv-rLV/strings.xml
+++ b/patches/src/main/resources/addresources/values-lv-rLV/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-mk-rMK/strings.xml b/patches/src/main/resources/addresources/values-mk-rMK/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-mk-rMK/strings.xml
+++ b/patches/src/main/resources/addresources/values-mk-rMK/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ml-rIN/strings.xml b/patches/src/main/resources/addresources/values-ml-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-ml-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-ml-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-mn-rMN/strings.xml b/patches/src/main/resources/addresources/values-mn-rMN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-mn-rMN/strings.xml
+++ b/patches/src/main/resources/addresources/values-mn-rMN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-mr-rIN/strings.xml b/patches/src/main/resources/addresources/values-mr-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-mr-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-mr-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ms-rMY/strings.xml b/patches/src/main/resources/addresources/values-ms-rMY/strings.xml
index d53ecc9935..5f30c180a6 100644
--- a/patches/src/main/resources/addresources/values-ms-rMY/strings.xml
+++ b/patches/src/main/resources/addresources/values-ms-rMY/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-my-rMM/strings.xml b/patches/src/main/resources/addresources/values-my-rMM/strings.xml
index 9a1d0171de..6a6446a239 100644
--- a/patches/src/main/resources/addresources/values-my-rMM/strings.xml
+++ b/patches/src/main/resources/addresources/values-my-rMM/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-nb-rNO/strings.xml b/patches/src/main/resources/addresources/values-nb-rNO/strings.xml
index 3f1432e96c..66643b0753 100644
--- a/patches/src/main/resources/addresources/values-nb-rNO/strings.xml
+++ b/patches/src/main/resources/addresources/values-nb-rNO/strings.xml
@@ -697,6 +697,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Spillerens popup-paneler er skjult
Spillerpopup-paneler vises
+
+ Åpne videoer i fullskjerm portrett
+ Videoer åpnes fullskjerm
+ Videoer åpner ikke fullskjerm
+
Spiller overlegg ugjennomsiktighet
Gjennomsiktighet mellom 0-100, der 0 er gjennomsiktig
@@ -1170,14 +1175,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Ved å slå av denne innstillingen kan problemer med videoavspilling.
Standard klient
Tving AVC (H.264)
- Videokodek er AVC (H.264)
- Videokodek er VP9 eller AV1
- Din enhet har ikke VP9, dekotering av maskinvare og denne innstillingen er alltid på når spoofing av klient er aktivert
- Aktivering av dette kan forbedre batterilevetiden og korrigere avspilling med avvik.\n\nAVC har en maksimal oppløsning på 1080p, og videoavspilling vil bruke flere Internettdata enn VP9 eller AV1.
+ Videokodek tvinges til AVC (H.264)
+ Videokodek bestemmes automatisk
+ Aktivering av dette kan forbedre batterilevetiden og korrigere avspilling med avvik.\n\nAVC har en maksimal oppløsning på 1080p, Opus lydkodek er ikke tilgjengelig. og videoavspilling vil bruke flere Internett-data enn VP9 eller AV1.
iOS med bivirkninger
- • Private kids-videoer spiller kanskje ikke\n• Livestreams start fra begynnelsen\n• Videoer kan ende 1 sekund av\n• Ingen opus lydkodek
+ • Private kids-videoer spiller kanskje ikke\n• Livestreams start fra begynnelsen\n• Videoer kan ende med 1 andre tidlig
Android VR opplever bivirkninger
• Barn kan ikke spille\n• Lydspormeny mangler\n• Stabilt volum er ikke tilgjengelig
+ Videostrømmer er skjevet
+ Foretrukket lydstrømsspråk
+ App språk
+ Arabisk
+ Aserbajdsjansk
+ Bulgarsk
+ Bengalsk
+ Katalansk
+ Tsjekkisk
+ Dansk
+ Tysk
+ Gresk
+ Engelsk
+ Spansk
+ Estisk
+ Persisk
+ Finsk
+ Fransk
+ Gujarati
+ hindi
+ Kroatisk
+ Ungarsk
+ Indonesisk
+ Italiensk
+ Japansk
+ Kazakh
+ Koreansk
+ Litauisk
+ Latvisk
+ Makedonsk
+ Mongolsk
+ Marathi
+ Malayisk
+ Burmese
+ Nederlandsk
+ Odia
+ Punjabi
+ Polsk
+ Portugisisk (Brasil)
+ Portugisisk (Portugal)
+ Rumensk
+ Russisk
+ Slovakisk
+ Slovene
+ Serbisk
+ Svensk
+ Swahili
+ Tamil
+ Telugu
+ Thailandsk
+ Tyrkisk
+ Ukrainsk
+ Urdu
+ Vietnamese
+ Kinesisk
diff --git a/patches/src/main/resources/addresources/values-ne-rIN/strings.xml b/patches/src/main/resources/addresources/values-ne-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-ne-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-ne-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-nl-rNL/strings.xml b/patches/src/main/resources/addresources/values-nl-rNL/strings.xml
index 644be3566f..c92af0f550 100644
--- a/patches/src/main/resources/addresources/values-nl-rNL/strings.xml
+++ b/patches/src/main/resources/addresources/values-nl-rNL/strings.xml
@@ -701,6 +701,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Speler pop-up panelen zijn verborgen
Speler pop-up panelen worden getoond
+
+ Open video\'s in volledig scherm portret
+ Video\'s openen volledig scherm
+ Video\'s openen niet volledig scherm
+
Doorzichtigheid speler overlay
Transparantiewaarde tussen 0-100, waarbij 0 transparant is
@@ -1185,14 +1190,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Het uitschakelen van deze instelling kan problemen met het afspelen van video veroorzaken.
Standaard client
Forceer AVC (H.264)
- Videocodec is AVC (H.264)
- Videocodec is VP9 of AV1
- Je apparaat heeft geen VP9 hardware-decodering en deze instelling is altijd ingeschakeld wanneer \'Client spoofing\' is ingeschakeld
- Het inschakelen hiervan kan de batterijduur verbeteren en het terugspringen corrigeren.\n\nAVC heeft een maximale resolutie van 1080p, en het afspelen van video\'s zal meer internetgegevens gebruiken dan VP9 of AV1.
+ Videocodec wordt gedwongen naar AVC (H.264)
+ Videocodec wordt automatisch bepaald
+ Het inschakelen hiervan kan de batterijduur verbeteren en het terugspringen corrigeren.\n\nAVC heeft een maximale resolutie van 1080p, Opus audiocodec is niet beschikbaar. en afspelen van video\'s zal meer internetgegevens gebruiken dan VP9 of AV1.
iOS vervalste bijwerkingen
- • Privé-kinderen video\'s kunnen mogelijk niet afspelen\n• Livestreams beginnen vanaf het begin\n• Video\'s kunnen 1 seconde vroeg eindigen\n• Geen opus audiocodec
+ • Privé-kinderen video\'s mogen niet afspelen\n• Livestreams beginnen vanaf het begin\n• Video\'s kunnen 1 seconde vroeg eindigen
Android VR vervalste bijeffecten
• Kids video\'s mogen niet afspelen\n• Audio track menu ontbreekt\n• Stabiel volume is niet beschikbaar
+ Videostreams zijn vervalst
+ Voorkeurstaal audio stream
+ App taal
+ Arabisch
+ Azerbeidzjaans
+ Bulgaars
+ Bengaalse
+ Catalaans
+ Tsjechisch
+ Deens
+ Duits
+ Grieks
+ Engels
+ Spaans
+ Estlands
+ Perzisch
+ Fins
+ Frans
+ Gujarati
+ Hindoestani
+ Kroatisch
+ Hongaars
+ Indonesisch
+ Italiaans
+ Afrikaans
+ Kazakh
+ Koreaans
+ Litouws
+ Lets
+ Macedonisch
+ Mongools
+ Marathi
+ Maleisisch
+ Burmese
+ Nederlands
+ Odia
+ Punjabi
+ Pools
+ Portugees (Brazilië)
+ Portugees (Portugal)
+ Roemeens
+ Russisch
+ Slowaaks
+ Slovene
+ Servisch
+ Zweeds
+ Moeilijk
+ Tamil
+ Telugu
+ Thaise
+ Turks
+ Oekraïens
+ Urdu
+ Vietnamese
+ Chinees
diff --git a/patches/src/main/resources/addresources/values-or-rIN/strings.xml b/patches/src/main/resources/addresources/values-or-rIN/strings.xml
index 85928d6450..73d01e1d55 100644
--- a/patches/src/main/resources/addresources/values-or-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-or-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-pa-rIN/strings.xml b/patches/src/main/resources/addresources/values-pa-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-pa-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-pa-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-pl-rPL/strings.xml b/patches/src/main/resources/addresources/values-pl-rPL/strings.xml
index 0e47f991eb..326a70dae3 100644
--- a/patches/src/main/resources/addresources/values-pl-rPL/strings.xml
+++ b/patches/src/main/resources/addresources/values-pl-rPL/strings.xml
@@ -710,6 +710,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Wyskakujące panele odtwarzacza są ukryte
Wyskakujące panele odtwarzacza są widoczne
+
+ Otwórz filmy w trybie pełnoekranowym
+ Filmy otwarte w trybie pełnoekranowym
+ Filmy nie otwierają się w trybie pełnoekranowym
+
Przezroczystość nakładki odtwarzacza
Wartość przezroczystości między 0-100, gdzie 0 jest przezroczysty
@@ -1201,14 +1206,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Wyłączenie tej opcji może spowodować problemy z odtwarzaniem filmów.
Domyślny klient
Wymuś AVC (H.264)
- Kodek wideo to AVC (H.264)
- Kodek wideo to VP9 / AV1
- Twoje urządzenie nie posiada sprzętowego dekodowania VP9, a ta opcja jest zawsze włączona, gdy spoofing klienta jest aktywny
- Włączenie tej opcji może poprawić żywotność baterii i wyeliminować zacinanie się odtwarzania.\n\nAVC ma maksymalną rozdzielczość 1080p, a odtwarzanie wideo zużywa więcej danych internetowych niż VP9 czy AV1.
+ Kodek wideo jest wymuszone do AVC (H.264)
+ Kodek wideo jest ustawiany automatycznie
+ Włączenie tego może poprawić żywotność baterii i naprawić stłuczenie odtwarzania.\n\nAVC ma maksymalną rozdzielczość 1080p, kodek audio Opus jest niedostępny, a odtwarzanie wideo wykorzysta więcej danych internetowych niż VP9 lub AV1.
Efekty uboczne spoofingu iOS
- • Prywatne filmy dla dzieci mogą się nie odtwarzać\n• Transmisje na żywo rozpoczynają się od początku\n• Filmy mogą zakończyć się o sekundę wcześniej\n• Kodek opus jest niedostępny
+ • Prywatne filmy dla dzieci mogą się nie odtwarzać\n• Transmisje na żywo rozpoczynają się od początku\n• Filmy mogą zakończyć się o sekundę wcześniej
Efekty uboczne spoofingu Android VR
• Filmy dla dzieci mogą się nie odtwarzać\n• Brakuje menu od ścieżki dźwiękowej\n• Stabilna głośność jest niedostępna
+ Oszukiwanie strumienia jest włączone
+ Preferowany język strumienia audio
+ Język aplikacji
+ arabski
+ Azerbejdżański
+ bułgarski
+ Bengali
+ kataloński
+ czeski
+ duński
+ niemiecki
+ grecki
+ Angielski
+ hiszpański
+ estoński
+ perski
+ fiński
+ Francuski
+ Gujarati
+ Hindi
+ chorwacki
+ węgierski
+ indonezyjski
+ włoski
+ japoński
+ Kazakh
+ koreański
+ litewski
+ łotewski
+ macedoński
+ mongolski
+ Marathi
+ Malajski
+ Burmese
+ Holenderski
+ Odia
+ Punjabi
+ polski
+ Portugalski (Brazylia)
+ Portugalski (Portugalia)
+ rumuński
+ rosyjski
+ Słowacki
+ Slovene
+ serbski
+ Szwedzki
+ Sahili
+ Tamil
+ Telugu
+ tajski
+ turecki
+ ukraiński
+ Urdu
+ Vietnamese
+ Chiński
diff --git a/patches/src/main/resources/addresources/values-pt-rBR/strings.xml b/patches/src/main/resources/addresources/values-pt-rBR/strings.xml
index d7db760c42..7a7749cb10 100644
--- a/patches/src/main/resources/addresources/values-pt-rBR/strings.xml
+++ b/patches/src/main/resources/addresources/values-pt-rBR/strings.xml
@@ -51,7 +51,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Reiniciar
Importar
Copiar
- Configurações ReVanced redefinidas para o padrão
+ Configurações do ReVanced redefinidas para o padrão
Configurações %d importadas
Importação falhou: %s
Importar / Exportar
@@ -710,6 +710,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Painel pop-up do reprodutor está oculto
Painel pop-up do reprodutor não está oculto
+
+
Opacidade do reprodutor
Valor de opacidade entre 0-100, onde 0 é transparente
@@ -1201,14 +1203,12 @@ This is because Crowdin requires temporarily flattening this file and removing t
Desativar esta configuração pode causar problemas de reprodução de vídeo.
Cliente padrão
Forçar AVC (H.264)
- Codec de vídeo é AVC (H.264)
- Codec de vídeo é VP9 ou AV1
- Seu dispositivo não possui decodificação de VP9 por hardware, e esta configuração está sempre ligada quando o spoofing do cliente está ativado
- Ativar isso pode melhorar a duração da bateria e corrigir falhas na reprodução.\n\nO AVC tem uma resolução máxima de 1080p, e a reprodução de vídeo usará mais dados de internet do que o VP9 ou o AV1.
Efeitos colaterais do spoofing de iOS
- • Vídeos privados para crianças não podem ser reproduzidos\n• As transmissões ao vivo começam do início\n• Os vídeos podem terminar 1 segundo antes\n• Nenhum codec de áudio opus
+ • Vídeos privados para crianças não podem ser reproduzidos\n• As transmissões ao vivo começam do início\n• Os vídeos podem terminar 1 segundo antes
Efeitos colaterais do spoofing de Android VR
• Os vídeos infantis podem não ser reproduzidos\n• O menu da faixa de áudio está ausente\n• O volume estável não está disponível
+ Fluxo de vídeo spoofado
+ Inglês
diff --git a/patches/src/main/resources/addresources/values-pt-rPT/strings.xml b/patches/src/main/resources/addresources/values-pt-rPT/strings.xml
index 37b4cbb0d3..aa02c6fa9a 100644
--- a/patches/src/main/resources/addresources/values-pt-rPT/strings.xml
+++ b/patches/src/main/resources/addresources/values-pt-rPT/strings.xml
@@ -709,6 +709,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Painéis pop-up do jogador estão escondidos
Painéis pop-up do jogador são visíveis
+
+ Abrir vídeos em retrato em tela cheia
+ Vídeos abertos em tela cheia
+ Vídeos não abrem tela cheia
+
Opacidade do jogador
Valor de opacidade entre 0-100, onde 0 é transparente
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Desativar essa configuração pode causar problemas de reprodução de vídeo.
Cliente padrão
Forçar AVC (H.264)
- Codec de vídeo é AVC (H.264)
- Codec de vídeo é VP9 ou AV1
- Seu dispositivo não possui decodificação por hardware VP9, e esta configuração está sempre ligada quando o spoofing do cliente está ativado
- Habilitar isso pode melhorar a duração da bateria e corrigir travamentos na reprodução.\n\nAVC tem uma resolução máxima de 1080p, e a reprodução de vídeo usará mais dados na internet do que VP9 ou AV1.
+ Codec de vídeo é forçado a AVC (H.264)
+ Codec de vídeo é determinado automaticamente
+ Habilitar isso pode melhorar a duração da bateria e corrigir travamentos na reprodução.\n\nAVC tem uma resolução máxima de 1080p, codec de áudio de Opus não está disponível, e a reprodução de vídeo usará mais dados na internet do que VP9 ou AV1.
Efeitos colaterais de iOS
- • Crianças privadas podem não reproduzir\n• Livestreams iniciados desde o início\n• Vídeos podem terminar 1 segundo segundo segundo\n• Nenhum codec de áudio de opus
+ • Crianças privadas podem não reproduzir\n• Livestreams iniciados desde o início\n• Vídeos podem terminar 1 segundo cedo
Android VR efeito de spoofing side
• As crianças podem não reproduzir\n• O menu da faixa de áudio está faltando\n• Volume estável não está disponível
+ Fluxos de vídeo são falsificados
+ Idioma preferencial do áudio stream
+ Idioma do aplicativo
+ Arábico
+ azerbaijano
+ búlgaro
+ bengali
+ catalão
+ tcheco
+ Dinamarquês
+ alemão
+ Grego
+ Inglês
+ espanhol
+ Estônio
+ persa
+ Finlandês
+ Francês
+ Gujarati
+ hindi
+ croata
+ Húngaro
+ indonésio
+ italiano
+ japonês
+ Kazakh
+ coreano
+ lituano
+ Letã
+ macedônio
+ Mongol
+ marata
+ malaio
+ Burmese
+ Neerlandês
+ Odia
+ Punjabi
+ Polonês
+ Português (Brasil)
+ Português (Portugal)
+ romeno
+ Russo
+ Eslovaco
+ Slovene
+ Sérvio
+ sueco
+ Suaíli
+ Tamil
+ Telugu
+ Tailandês
+ Turco
+ ucraniano
+ urdu
+ Vietnamese
+ chinês
diff --git a/patches/src/main/resources/addresources/values-ro-rRO/strings.xml b/patches/src/main/resources/addresources/values-ro-rRO/strings.xml
index 22ebef1b42..1d9ff84c10 100644
--- a/patches/src/main/resources/addresources/values-ro-rRO/strings.xml
+++ b/patches/src/main/resources/addresources/values-ro-rRO/strings.xml
@@ -33,31 +33,30 @@ This is because Crowdin requires temporarily flattening this file and removing t
- Verificările au eșuat
+ Verificări eșuate
Deschide site-ul oficial
Ignoră
- <h5>Se pare că aplicația nu este modificată de dv.</h5><br>Este posibil ca aplicația să nu funcționeze corect, <b>să dăuneze dispozitivului sau să prezinte un pericol la utilizare</b>.<br><br>Simpla existență a acestor verificări sugerează faptul că aplicația este modificată în prealabil sau obținută de la altcineva: <br><br><small>%1$s</small><br>Recomandăm cu tărie <b>dezinstalarea și modificarea manuală a acestei aplicații</b> pentru a vă asigura că aplicația pe care o folosiți este validă și sigură.<p><br>După ignorare, mesajul nu va mai fi afișat decât o a doua oară.
- Modificată pe un alt dispozitiv
- Nu este instalată de ReVanced Manager
- Modificat de mai mult de 10 minute
- Modificat cu %s zile în urmă
- Data de compilare a fișierului APK este coruptă
+ Patchat pe un alt dispozitiv
+ Nu este instalat de ReVanced Manager
+ Patchat acum mai mult de 10 minute
+ Patchat %s zile în urmă
+ Data construcției APK este coruptă
ReVanced
Doriți să continuați?
- Resetare
- Reîmprospătare și repornire
+ Resetează
+ Reîmprospătați și reporniți
Repornire
Importare
Copiere
- Setările ReVanced vor fi reinițializate
+ Setările revizuite se resetează la valorile implicite
Setări %d importate
Importul a eșuat: %s
- Importați / Exportați
- Importați / Exportați setări ReVanced
+ Importă / Exportă
+ Setări Import / Export ReVanced
- Folosiți versiunea <i>%s</i> a ReVanced Patches
+ Folosiți ReVanced Patch-uri versiunea <i>%s</i>
Notă
Această versiune este o pre-lansare și este posibil să întâmpinați probleme neașteptate
Link-uri oficiale
@@ -77,10 +76,10 @@ This is because Crowdin requires temporarily flattening this file and removing t
Despre
- Publicitate
+ Anunţuri
Miniaturi alternative
Flux
- Player
+ Jucător
Structura generală
Bară de căutare
Controale glisare
@@ -88,9 +87,6 @@ This is because Crowdin requires temporarily flattening this file and removing t
Video
- Dezactivează redarea în fundal a videoclipurilor Shorts
- Redarea în fundal este dezactivată
- Redarea în fundal este activată
Depanare
@@ -110,9 +106,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Eroare la dezactivare toasts ascunde toate notificările de eroare ReVanced\n\nNu veți fi notificat de niciun eveniment neașteptat.
- Dezactivare strălucire butoane „Apreciez“ și „Abonare“
- Butoanele nu vor străluci când sunt menționate în clip
- Butoanele vor străluci când sunt menționate în clip
+ Butonul Îmi place și abonare nu va străluci când este menționat
+ Butonul de like-uri și abonare va străluci când este menționat
Ascundeți cardurile de album
Cardurile de album sunt ascunse
Cardurile de album sunt afișate
@@ -126,7 +121,6 @@ This is because Crowdin requires temporarily flattening this file and removing t
Marcajul este ascuns
Se afișează filigran
Ascunde rafturile orizontale
- Sunt ascunse recomandări, precum:\n• Știri de ultimă oră\n• Continuați urmărirea\n• Explorați mai multe canale\n• Cumpărături\n• Urmăriți din nou
Se afişează rafturi
@@ -143,7 +137,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Butonul este ascuns
Butonul este afișat
- Ascundeți recomandările „Specatorii vizionează și acest videoclip“
+ Ascunde recomandările \'Oameni urmăriți\'
Recomandările sunt ascunse
Recomandările sunt afișate
Lista șirurilor constructorului traiectoriei componentei pentru filtrarea separată de o linie nouă
Filtru personalizat nevalid: %s
- Ascundere conținut după cuvinte cheie
- Ascundeți videoclipuri din flux după cuvinte cheie
- Ascundeți videoclipuri de pe pagina „Acasă“ după cuvinte cheie
- Videoclipurile de pe pagina „Acasă“ sunt filtrate
- Videoclipurile de pe pagina „Acasă“ nu sunt filtrate
- Ascundeți videoclipuri de pe pagina „Abonamente“ după cuvinte cheie
- Videoclipurile de pe pagina „Abonamente“ sunt filtrate
- Videoclipurile de pe pagina „Abonamente“ nu sunt filtrate
- Ascundeți rezultate ale căutării după cuvinte cheie
- Rezultatele sunt filtrate după cuvinte cheie
- Rezultatele nu sunt filtrate după cuvinte cheie
+ Ascundeți conținutul cuvântului cheie
+ Ascundeți căutarea și hrănirea videoclipurilor folosind filtre de cuvinte cheie
+ Ascunde videoclipurile de acasă după cuvintele cheie
+ Videoclipurile din fila principală sunt filtrate de cuvinte cheie
+ Videoclipurile din fila principală nu sunt filtrate de cuvintele cheie
+ Ascunde abonarea videoclipurilor după cuvintele-cheie
+ Videoclipurile din fila abonamente sunt filtrate de cuvinte cheie
+ Videoclipurile din fila abonamente nu sunt filtrate de cuvinte cheie
+ Ascunde rezultatele căutării după cuvinte cheie
+ Rezultatele căutării sunt filtrate după cuvintele cheie
+ Rezultatele căutării nu sunt filtrate de cuvinte cheie
Cuvinte cheie de ascuns
- Cuvinte cheie și fraze de ascuns, separate prin linii noi\n\nCuvintele cheie pot fi nume de canal sau orice text afișat în titlurile video\n\nCuvinte cu litere mari în mijloc trebuie să fie introduse corespunzător (ex: iPhone, TikTok, LeBlanc)
- Despre filtrarea după cuvinte cheie
- Paginile „Acasă“, „Abonamente“ și cea pentru rezultatele căutării sunt filtrate după o serie de fraze sau cuvinte cheie pentru a ascunde conținut.\n\nLimitări:\n• Videoclipurile scurte nu pot fi ascunse după numele canalui\n• Unele componente ale interfeței nu pot fi ascunse\n• Căutări după cuvinte din listă pot să nu returneze niciun rezultat
- Filtrare după cuvinte întregi
+ Cuvinte cheie și fraze de ascuns, separate prin linii noi\n\nCuvintele cheie pot fi nume de canal sau orice text afișat în titlurile video\n\nCuvinte cu litere mari în mijloc trebuie să fie introduse cu caseta (ex: iPhone, TikTok, LeBlanc)
+ Despre filtrarea cuvintelor cheie
+ Potrivește cuvinte întregi
- Încadrarea unui cuvânt în ghilimele va împiedica filtrarea potrivirilor parțiale din cadrul titlurilor clipurilor sau a numelor canalelor<br><br>Spre exemplu,<br><b>\"ai\"</b> va ascunde clipul: <b>How does AI work?</b>,<br>dar nu va ascunde: <b>What does fair use mean?</b>.
Nu se poate folosi cuvantul cheie: %s
Adaugă oferte pentru a utiliza cuvântul cheie: %s
@@ -366,9 +354,9 @@ This is because Crowdin requires temporarily flattening this file and removing t
Afișare buton copie URL
Butonul este afișat. Atingeți pentru a copia URL-ul video. Atingeți și țineți apăsat pentru a copia URL-ul video cu marcajul de timp
Butonul nu este afișat
- Afișați butonul pentru copierea URL-ului cu marcaj de timp
- Butonul este afișat. Apăsați pentru a copia URL-ul cu marcaj de timp. Țineți apăsat pentru a copia URL-ul simplu.
- Butonul este ascuns
+ Afișare buton copie marcaj URL
+ Butonul este afișat. Atingeți pentru a copia URL-ul video cu marcajul de timp. Atingeți și țineți apăsat pentru a copia videoclipul fără marcaj de timp
+ Butonul nu este afișat
Eliminați dialogul discreționar al vizualizatorului
@@ -430,16 +418,16 @@ This is because Crowdin requires temporarily flattening this file and removing t
Cantitatea de prag pentru a glisa
- Dezactivare subtitrări automate
- Subtitrările automate sunt dezactivate
- Subtitrările automate sunt activate
+ Dezactivează subtitrările automate
+ Legendele automate sunt dezactivate
+ Legenda automată este activată
Butoane de acţiune
Ascunde sau arată butoanele sub videoclipuri
- Ascunde butoanele „Apreciez“ și „Nu apreciez“
- Butoanele „Apreciez“ și „Nu apreciez“ sunt ascunse
- Butoanele „Apreciez“ și „Nu apreciez“ sunt afișate
+ Ascunde Like și Dislike
+ Butoanele Like și Dislike sunt ascunse
+ Butoanele Like și Dislike sunt afișate
Ascunde Partajarea
Butonul de distribuire este ascuns
@@ -491,7 +479,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Butonul Abonamente este afișat
Comutare creare cu notificări
- Pozițiile butoanelor „Creează“ și „Notificări” sunt interschimbate\n\nNotă: Această setare ascunde forțat anunțurile video
+ Butonul Creare este comutat cu butonul Notificări\n\nNotă: Activarea acestui buton și ascunderea forțată a anunțurilor video
Butonul Creare nu este comutat cu butonul Notificări
Ascunde etichetele butoanelor de navigare
Etichetele sunt ascunse
@@ -556,9 +544,9 @@ This is because Crowdin requires temporarily flattening this file and removing t
Ascunde butoanele anterioare & următorul video
Butoanele sunt ascunse
Butoanele sunt afișate
- Ascunde butonul „Proiectează“
- Butonul este ascuns
- Butonul este afișat
+ Ascunde butonul de redare
+ Butonul de distribuție este ascuns
+ Butonul de execuție este afișat
Ascunde butonul de legendă
Butonul subtitrari este ascuns
@@ -596,7 +584,6 @@ This is because Crowdin requires temporarily flattening this file and removing t
Pictograma bara de căutare este afișată
- Player pentru videoclipuri scurte
Ascunde Short din feed-ul de acasă
Shorts în fluxul de acasă sunt ascunse
@@ -657,9 +644,9 @@ This is because Crowdin requires temporarily flattening this file and removing t
Ascunde butonul similar
Butonul Like este ascuns
Butonul Like este afișat
- Ascunde butonul „Nu apreciez“
- Butonul „Nu apreciez“ este ascuns
- Butonul „Nu apreciez“ este afișat
+ Ascunde butonul diferit
+ Butonul nu este ascuns
+ Butonul nu este afișat
Ascunde butonul de comentarii
Butonul de comentarii este ascuns
Butonul pentru comentarii este afișat
@@ -694,8 +681,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Bara de navigare este afișată
- Dezactivare videoclipuri sugerate din ecranul de final
- Videoclipurile sugerate vor fi ascunse
+ Videoclipurile sugerate vor fi dezactivate
Videoclipurile sugerate vor fi afișate
@@ -704,9 +690,14 @@ This is because Crowdin requires temporarily flattening this file and removing t
Ora este afișată
+
+ Deschide videoclipurile în modul ecran complet
+ Videoclipuri deschide tot ecranul
+ Videoclipurile nu deschid tot ecranul
Opacitate suprapusă jucătorului
@@ -715,28 +706,28 @@ This is because Crowdin requires temporarily flattening this file and removing t
- Neaprecieri temporar indisponibile (API a expirat)
- Neaprecieri indisponibile (stare: %d)
- Neaprecieri indisponibile (limita API atinsă)
- Neaprecieri indisponibile (%s)
+ Dislike-uri temporar indisponibile (API a expirat)
+ Dislike-uri indisponibile (status %d)
+ Dislike-uri indisponibile (limita API atinsă)
+ Dislike-uri indisponibile (%s)
- Reîncarcă clipul pentru a folosi Return YouTube Dislike
- Neaprecierile sunt afișate
- Neaprecierile nu sunt afișate
- Afișați neaprecierile pentru videoclipurle scurte
- Neaprecierile pentru videoclipurle scurte sunt afișate
- Neaprecierile pentru videoclipurile scurte sunt afișate\n\nConsecință: Acestea pot să nu apară în modul incognito
- Neaprecierile pentru videoclipurile scurte sunt ascunse
- Afișați neaprecierile sub formă de procentaj
- Neaprecierile sunt afișate sub formă de procentaj
- Neaprecierile sunt afișate sub formă de număr
+ Reîncarcă videoclipul pentru a vota folosind Returnare YouTube Dislike
+ Dislike-urile sunt afișate
+ Dislike-urile nu sunt afișate
+ Arată displace pe scurtmetraje
+ Dislike-uri afișate pe scurtmetraje
+ Dislike-uri afișate pe Scurtăturile\n\nLimitare: Este posibil ca displace să nu apară în modul incognito
+ Displace ascunse pe scurt-metraje
+ Displace ca procentaj
+ Dislike-uri afișate ca procent
+ Dislike-uri afișate ca număr
Buton compact ca
Buton de stilizat pentru lățime minimă
Buton asemănător pentru cel mai bun aspect
- Arată un mesaj dacă serverul este indisponibil
- Se afișează un mesaj dacă „Return YouTube Dislike” este indisponibil
- Nu se afișează un mesaj dacă „Return YouTube Dislike” este indisponibil
+ Arată un toast dacă API-ul nu este disponibil
+ Toast este afișat dacă Returnarea YouTube Dislike nu este disponibilă
+ Toast nu este afișat dacă Returnarea YouTube Dislike nu este disponibilă
Despre
Datele sunt furnizate de API-ul Returnare YouTube Dislike. Atinge aici pentru a afla mai multe
@@ -955,14 +946,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Datele sunt furnizate de API-ul SponsorBlock. Apasă aici pentru a afla mai multe și a vedea descărcările pentru alte platforme
- Simulare versiune
- Versiune simulată
- Versiune reală
+ Versiune falsificată
+ Versiune neafectată
Versiunea aplicației va fi falsificată de o versiune mai veche de YouTube.\n\nAceasta va schimba aspectul şi caracteristicile aplicaţiei, dar pot apărea reacţii adverse necunoscute.\n\nDacă se dezactivează ulterior, se recomandă ștergerea datelor aplicației pentru a preveni erorile de interfață.
- Versiune de simulat
- 19.35.36 - Restabilire pictograme învechite pentru playerul videoclipurilor scurte
18.33.40 - Restaurează RYD în modul incognito Shorts
18.20.39 - Restaurare viteză video mare & meniu calitate
@@ -988,9 +976,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Urmărește mai târziu
- Nu relua videoclipurile Shorts la deschidere
- Videoclipurile Shorts nu vor fi reluate la deschiderea aplicației
- Videoclipurile Shorts vor fi reluate la deschiderea aplicației
+ Scurtătura va fi reluată la pornirea aplicației
@@ -1001,9 +987,9 @@ This is because Crowdin requires temporarily flattening this file and removing t
Posturile comunitare nu apar pe tablete
- Miniplayer
+ Minijucător
Schimbă stilul aplicaţiei minimizat jucătorul
- Tip de miniplayer
+ Tip minijucător
Dezactivat
Originală
Minimă
@@ -1062,42 +1048,31 @@ This is because Crowdin requires temporarily flattening this file and removing t
- Fila „Acasă“
- Fila „Abonamente“
+ Filă abonament
- Fila „Tu“
+ Fila ta
Liste de redare, recomandări
Rezultatele căutării
- Miniaturi originale
- DeArrow & Miniaturi originale
- Săgeată & Capturi statice
- Capturi statice
- DeArrow oferă miniaturi sugerate de comunitate. Deseori, acestea sunt mai relevante decât cele furnizate de YouTube\n\nDacă sunt activate, adresele clipurilor video vor fi trimise serverului DeArrow, însă fără alte date. Dacă un videoclip nu are miniaturi DeArrow, sunt afișate cele originale\n\nApăsați aici pentru a afla mai multe despre DeArrow
- Afișați un mesaj dacă serverul este indisponibil
- Se afișează un mesaj dacă DeArrow este indisponibil
- Nu se afișează un mesaj dacă DeArrow este indisponibil
- Punct final al DeArrow API
- Adresa punctul final DeArrow pentru miniaturi
- Capturi statice
- Capturile statice sunt extrase de la începutul / mijlocul / sfârșitul fiecărui videoclip. Funcționalitatea este încorporată în YouTube și nu necesită API extern.
- Utilizați capturi statice rapide
- Se folosesc capturi statice de calitate normală. Miniaturile se vor încărca mai repede, dar fluxurile în direct, videoclipurile nepublicate sau cele foarte vechi pot afișa miniaturi goale
- Se folosesc capturi statice de calitate înaltă
- Moment din clip pentru preluarea capturii statice
- Început
- Mijloc
- Sfârșit
+ Original thumbnails
+ Săgeată & Miniaturi originale
+ Arată un toast dacă API-ul nu este disponibil
+ Toast este afișat dacă DeArrow nu este disponibil
+ Toast nu este afișat dacă DeArrow nu este disponibil
+ DeArrow API endpoint
+ Folosește capturi rapide încă
+ Folosind calitate înaltă capturează încă
+ Timp video pentru a face capturi încă din
+ Începutul videoclipului
+ Mijloc video
+ Sfârșitul videoclipului
- DeArrow indisponibil temporar (stare: %s)
- DeArrow indisponibil temporar
- Afișați știri din partea echipei ReVanced la pornire
- Știrile sunt afișate la pornire
- Știrile nu sunt afișate la pornire
- Afișați știri din partea echipei ReVanced la pornire
- Conectarea la serverul de știri a eșuat
+ Anunțurile sunt afișate la pornire
+ Anunțurile nu sunt afișate la pornire
+ Afișare anunțuri la pornire
+ Conectarea la furnizorul de anunțuri a eșuat
Anulare
@@ -1185,33 +1160,84 @@ This is because Crowdin requires temporarily flattening this file and removing t
Slide pentru a căuta nu este activat
- Simulare flux video
- Simulează randorul fluxurilor video pentru a preveni probleme de redare
- Simulare fluxuri video
- Fluxurile video sunt simulate
- Fluxurile video nu sunt simulate\n\nEste posibil ca redarea video să nu funcționeze
+ Spoof video stream-uri
+ Sporirea canalelor video client pentru a preveni problemele de redare
+ Fluxurile video sunt falsificate
+ Fluxurile video nu sunt marcate cu\n\nEste posibil ca redarea video să nu funcționeze
Dezactivarea acestei setări poate cauza probleme de redare video.
- Randor implicit
+ Client implicit
Forțează AVC (H.264)
- Codecul video este AVC (H.264)
- Codecul video este VP9 sau AV1
- Dispozitivul dvs. nu acceptă decodarea VP9 la nivel hardware. Această setare este necesară pentru simularea randorului
- Activarea acestei funcții ar putea îmbunătăți durata de viață a bateriei și repara blocajul de redare.\n\nAVC are o rezoluție maximă de 1080p, iar redarea video va folosi mai multe date internet decât VP9 sau AV1.
- Consecințe ale simulării randorului iOS
- • Este posibil ca videoclipurile private pentru copii să nu se redea\n• Transmisiunile în direct încep mereu de la început\n• Videoclipurile pot să se încheie mai devreme cu o secundă\n• Codecul audio Opus nu este acceptat
- Consecințe ale simulării randorului Android VR
- • Videoclipurile pentru copii pot să nu se redea\n• Meniul piesei audio lipsește\n• Volumul stabil nu este disponibil
+ Codecul video este forţat să facă AVC (H.264)
+ Codecul video este determinat automat
+ Activarea acestei funcții ar putea îmbunătăți durata de viață a bateriei și repara blocajul de redare.\n\nAVC are o rezoluție maximă de 1080p, codec audio Opus nu este disponibil, iar redarea video va utiliza mai multe date internet decât VP9 sau AV1.
+ • Este posibil ca videoclipurile private pentru copii să nu se redea\n• Livestream-urile încep de la începutul\n• Videoclipurile se pot termina cu o secundă mai devreme
+ Reacţii adverse de spoofing Android VR
+ Fluxurile video sunt falsificate
+ Limba de transmisiune audio preferată
+ Limba aplicației
+ Arabă
+ Azerbaidjan
+ Bulgară
+ Bengaleză
+ Catalană
+ Cehă
+ Daneză
+ Germană
+ Greacă
+ Engleză
+ Spaniolă
+ Estonă
+ persană
+ Finlandeză
+ Franceză
+ Gujarati
+ Hindi
+ Croată
+ Maghiară
+ Indoneziană
+ Italiană
+ Japoneză
+ Kazakh
+ Coreeană
+ Lituaniană
+ Letonă
+ Macedoneană
+ Mongolie
+ Marati
+ Malaeză
+ Burmese
+ Olandeză
+ Odia
+ Punjabi
+ Poloneză
+ Portugheză (Brazilia)
+ Portugheză (Portugalia)
+ Română
+ Rusă
+ Slovacă
+ Slovene
+ Sârbă
+ Suedeză
+ Asteapta
+ Tamil
+ Telugu
+ Tailandeză
+ Turcă
+ Ucraineană
+ Urdu
+ Vietnamese
+ Chineză
Blochează reclamele audio
- Anunțurile audio sunt blocate
- Anunțurile audio sunt permise
+ Anunţurile audio sunt blocate
+ Anunţurile audio sunt deblocate
%s este indisponibil. Reclame pot arata. Incercati sa treceti la un alt serviciu de blocare a reclamelor din setari.
- Serverul %s a returnat o eroare. E posibil ca anunțurile să apară. Încercați un alt serviciu de blocare a reclamelor.
+ Serverul %s a returnat o eroare. Anunţurile pot apărea. Încearcă să treci la un alt serviciu de blocare a reclamelor din setări.
Blocare reclame video integrate
Dezactivat
Proxy luminos
@@ -1220,7 +1246,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Blocare reclame video
Anunțurile video sunt blocate
- Anunțurile audio sunt permise
+ Anunţurile video sunt deblocate
mesaj șters
@@ -1244,7 +1270,7 @@ This is because Crowdin requires temporarily flattening this file and removing t
Setări ReVanced
Despre
Despre ReVanced
- Publicitate
+ Anunţuri
Setări blocare reclame
Chat
Setări chat
diff --git a/patches/src/main/resources/addresources/values-ru-rRU/strings.xml b/patches/src/main/resources/addresources/values-ru-rRU/strings.xml
index 7b4c6f5d61..3e64a1f457 100644
--- a/patches/src/main/resources/addresources/values-ru-rRU/strings.xml
+++ b/patches/src/main/resources/addresources/values-ru-rRU/strings.xml
@@ -710,6 +710,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Автоматически всплывающие панели (плейлист или живой чат) в плеере скрыты
Автоматически всплывающие панели (плейлист или живой чат) в плеере отображены
+
+ Открыть видео в полноэкранном портрете
+ Видео открыть полноэкранный режим
+ Видео не открывают полноэкранный режим
+
Непрозрачность оверлея плеера
Значение непрозрачности в пределах 0-100, где 0 - это прозрачно
@@ -1201,14 +1206,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Отключение этой настройки может вызвать проблемы с воспроизведением видео.
Клиент по умолчанию
Принудительно AVC (H.264)
- Видеокодек AVC (H.264)
- Видеокодек VP9 или AV1
- На вашем устройстве нет аппаратного декодирования VP9, и эта настройка всегда активна при включенной подмене клиента
- Активация данной опции может улучшить время работы батареи и исправить задержки воспроизведения.\n\nAVC имеет максимальное разрешение 1080p, воспроизведение видео будет использовать больше интернет данных в сравнении с VP9 или AV1.
+ Видео кодек привязан к AVC (H.264)
+ Видео кодек определяется автоматически
+ Включение этого параметра может улучшить время работы батареи и исправить затяжку воспроизведения.\n\nAVC имеет максимальное разрешение 1080p, аудио кодек Opus недоступен, и воспроизведение видео будет использовать больше интернет-данных, чем VP9 или AV1.
Побочные эффекты подмены на iOS
- • Частные детские видео могут не воспроизводиться\n• Прямые трансляции начинаются с самого начала\n• Видео может закончиться на 1 секунду раньше\n• Отсутствует аудиокодек opus
+ • Видео частных детей не могут играть\n• Livestreams начинается с начала\n• Видео может закончиться 1 секунду рано
Побочные эффекты подмены на Android VR
• Детские видео могут не воспроизводиться\n• Пункт меню \"Звуковая дорожка\" отсутвтует\n• Пункт меню \"Постоянный уровень громкости\" недоступен
+ Видеопотоки подменены
+ Предпочитаемый язык аудио потока
+ Язык приложения
+ Арабский
+ Азербайджан
+ Болгарский
+ Бенгальский
+ Каталанский
+ Чешский
+ Датский
+ Немецкий
+ Греческий
+ Английский
+ Испанский
+ Эстонский
+ Персидский
+ Финский
+ Французский
+ Gujarati
+ Хинди
+ Хорватский
+ Венгерский
+ Индонезийский
+ Итальянский
+ Японский
+ Kazakh
+ Корейский
+ Литовский
+ Латышский
+ Македонский
+ Монгольский
+ Маратти
+ Малай
+ Burmese
+ Голландский
+ Odia
+ Punjabi
+ Польский
+ Португальский (Бразилия)
+ Португальский (Португалия)
+ Румынский
+ Русский
+ Словацкий
+ Slovene
+ Сербский
+ Шведский
+ Суахили
+ Tamil
+ Telugu
+ Тайский
+ Турецкий
+ Украинский
+ Урду
+ Vietnamese
+ Китайский
diff --git a/patches/src/main/resources/addresources/values-si-rLK/strings.xml b/patches/src/main/resources/addresources/values-si-rLK/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-si-rLK/strings.xml
+++ b/patches/src/main/resources/addresources/values-si-rLK/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-sk-rSK/strings.xml b/patches/src/main/resources/addresources/values-sk-rSK/strings.xml
index 45b6f7d10f..47855b49a1 100644
--- a/patches/src/main/resources/addresources/values-sk-rSK/strings.xml
+++ b/patches/src/main/resources/addresources/values-sk-rSK/strings.xml
@@ -642,6 +642,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Vyskakovacie panely prehrávača sú skryté
Zobrazia sa vyskakovacie panely prehrávača
+
+
Nepriehľadnosť prekrytia prehrávača
Hodnota nepriehľadnosti medzi 0-100, kde 0 je transparentné
diff --git a/patches/src/main/resources/addresources/values-sl-rSI/strings.xml b/patches/src/main/resources/addresources/values-sl-rSI/strings.xml
index dbf983a2c1..b2cfafe930 100644
--- a/patches/src/main/resources/addresources/values-sl-rSI/strings.xml
+++ b/patches/src/main/resources/addresources/values-sl-rSI/strings.xml
@@ -154,6 +154,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-sq-rAL/strings.xml b/patches/src/main/resources/addresources/values-sq-rAL/strings.xml
index c01d464359..44d98222db 100644
--- a/patches/src/main/resources/addresources/values-sq-rAL/strings.xml
+++ b/patches/src/main/resources/addresources/values-sq-rAL/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-sr-rCS/strings.xml b/patches/src/main/resources/addresources/values-sr-rCS/strings.xml
index 606f7b03a9..95096c2368 100644
--- a/patches/src/main/resources/addresources/values-sr-rCS/strings.xml
+++ b/patches/src/main/resources/addresources/values-sr-rCS/strings.xml
@@ -710,6 +710,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Iskačuće table u plejeru su skrivene
Iskačuće table u plejeru su prikazane
+
+
Neprozirnost preklopa plejera
Vrednost neprozirnosti između 0 i 100, gde je 0 prozirno
@@ -1201,14 +1203,12 @@ This is because Crowdin requires temporarily flattening this file and removing t
Isključivanje ove opcije će možda izazvati probleme sa reprodukcijom videa.
Podrazumevani klijent
Prisili AVC (H.264)
- Video kodek je AVC (H.264)
- Video kodek je VP9 ili AV1
- Vaš uređaj nema VP9 hardversko dekodiranje, i ova opcija je uvek uključena kada je omogućeno lažiranje klijenta
- Ako ovo omogućite, možda će se produžiti trajanje baterije i popraviti zastoj pri reprodukciji.\n\nAVC ima maksimalnu rezoluciju od 1080p, a reprodukcija videa će koristiti više internet podataka nego VP9 ili AV1.
Neželjeni efekti lažiranja na iOS
- • Privatni dečji videi se možda neće puštati\n• Strimovi uživo počinju od početka\n• Videi će se možda završiti 1 sekundu ranije\n• Nema audio kodeka opus
+ • Privatni dečji videi se možda neće puštati\n• Strimovi uživo počinju od početka\n• Videi će se možda završiti 1 sekundu ranije
Neželjeni efekti lažiranja na Android VR
• Dečji videi se možda neće puštati\n• Meni „Audio snimak” nedostaje\n• Ujednačena jačina zvuka nije dostupna
+ Video strimovi su lažirani
+ engleski
diff --git a/patches/src/main/resources/addresources/values-sr-rSP/strings.xml b/patches/src/main/resources/addresources/values-sr-rSP/strings.xml
index 7c18486f15..a045247d6a 100644
--- a/patches/src/main/resources/addresources/values-sr-rSP/strings.xml
+++ b/patches/src/main/resources/addresources/values-sr-rSP/strings.xml
@@ -710,6 +710,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Искачуће табле у плејеру су скривене
Искачуће табле у плејеру су приказане
+
+
Непрозирност преклопа плејера
Вредност непрозирности између 0 и 100, где је 0 прозирно
@@ -1201,14 +1203,12 @@ This is because Crowdin requires temporarily flattening this file and removing t
Искључивање ове опције ће можда изазвати проблеме са репродукцијом видеа.
Подразумевани клијент
Присили AVC (H.264)
- Видео кодек је AVC (H.264)
- Видео кодек је VP9 или AV1
- Ваш уређај нема VP9 хардверско декодирање, и ова опција је увек укључена када је омогућено лажирање клијента
- Ако ово омогућите, можда ће се продужити трајање батерије и поправити застој при репродукцији.\n\nAVC има максималну резолуцију од 1080p, а репродукција видеа ће користити више интернет података него VP9 или AV1.
Нежељени ефекти лажирања на iOS
- • Приватни дечји видеи се можда неће пуштати\n• Стримови уживо почињу од почетка\n• Видеи ће се можда завршити 1 секунду раније\n• Нема аудио кодека opus
+ • Приватни дечји видеи се можда неће пуштати\n• Стримови уживо почињу од почетка\n• Видеи ће се можда завршити 1 секунду раније
Нежељени ефекти лажирања на Android VR
• Дечји видеи се можда неће пуштати\n• Мени „Аудио снимак” недостаје\n• Уједначена јачина звука није доступна
+ Видео стримови су лажирани
+ енглески
diff --git a/patches/src/main/resources/addresources/values-sv-rSE/strings.xml b/patches/src/main/resources/addresources/values-sv-rSE/strings.xml
index 5ebda049dc..9ed83acb79 100644
--- a/patches/src/main/resources/addresources/values-sv-rSE/strings.xml
+++ b/patches/src/main/resources/addresources/values-sv-rSE/strings.xml
@@ -710,6 +710,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Spelare popup-paneler är dolda
Spelarens popup-paneler visas
+
+ Öppna videor i helskärmsporträtt
+ Videor öppna helskärm
+ Videor öppnar inte fullskärm
+
Överlagring av spelarens opacitet
Opacitetsvärde mellan 0-100, där 0 är transparent
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Att stänga av den här inställningen kan orsaka videouppspelningsproblem.
Standard klient
Tvinga AVC (H.264)
- Videocodec är AVC (H.264)
- Video-codec är VP9 eller AV1
- Din enhet har inte VP9 hårdvaruavkodning, och denna inställning är alltid på när klientförfalskning är aktiverad
- Aktivering av detta kan förbättra batteriets livslängd och åtgärda uppspelningshjälp.\n\nAVC har en maximal upplösning på 1080p, och videouppspelning kommer att använda mer internetdata än VP9 eller AV1.
+ Video-codec tvingas till AVC (H.264)
+ Video-codec bestäms automatiskt
+ Aktivering av detta kan förbättra batteriets livslängd och åtgärda uppspelningshjälp.\n\nAVC har en maximal upplösning på 1080p, Opus audio codec är inte tillgänglig, och videouppspelning kommer att använda mer internetdata än VP9 eller AV1.
iOS förfalskning biverkningar
- • Privata barnvideor kanske inte spelar\n• Livestreams börjar från början\n• Videor kan sluta 1 sekund tidigt\n• Ingen opus-ljud-codec
+ • Privata barn videor får inte spela\n• Livestreams börjar från början\n• Videor kan sluta 1 sekund tidigt
Android VR förfalskning biverkningar
• Barnvideor kanske inte spelar\n• Ljudspårsmenyn saknas\n• Stabil volym är inte tillgänglig
+ Videoströmmar är förfalskade
+ Föredraget ljudströmspråk
+ Appens språk
+ Arabiska
+ Azerbajdzjanska
+ Bulgariska
+ Bengaliska
+ Katalanska
+ Tjeckiska
+ Danska
+ Tyska
+ Grekiska
+ Engelska
+ Spanska
+ Estniska
+ Persiska
+ Finska
+ Franska
+ Gujarati
+ Hindi
+ Kroatiska
+ Ungerska
+ Indonesiska
+ Italienska
+ Japanska
+ Kazakh
+ Koreanska
+ Litauiska
+ Lettiska
+ Makedonska
+ Mongoliska
+ Marathi
+ Malajiska
+ Burmese
+ Holländska
+ Odia
+ Punjabi
+ Polska
+ Portugisiska (Brasilien)
+ Portugisiska (Portugal)
+ Rumänska
+ Ryska
+ Slovakiska
+ Slovene
+ Serbiska
+ Svenska
+ Swahili
+ Tamil
+ Telugu
+ Thailändska
+ Turkiska
+ Ukrainska
+ Urdu
+ Vietnamese
+ Kinesiska
diff --git a/patches/src/main/resources/addresources/values-sw-rKE/strings.xml b/patches/src/main/resources/addresources/values-sw-rKE/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-sw-rKE/strings.xml
+++ b/patches/src/main/resources/addresources/values-sw-rKE/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-ta-rIN/strings.xml b/patches/src/main/resources/addresources/values-ta-rIN/strings.xml
index c28311bbef..5f89950991 100644
--- a/patches/src/main/resources/addresources/values-ta-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-ta-rIN/strings.xml
@@ -154,6 +154,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-te-rIN/strings.xml b/patches/src/main/resources/addresources/values-te-rIN/strings.xml
index 1498e898f0..63330e29e1 100644
--- a/patches/src/main/resources/addresources/values-te-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-te-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-th-rTH/strings.xml b/patches/src/main/resources/addresources/values-th-rTH/strings.xml
index ca1743ea17..8880ef3fb9 100644
--- a/patches/src/main/resources/addresources/values-th-rTH/strings.xml
+++ b/patches/src/main/resources/addresources/values-th-rTH/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-tr-rTR/strings.xml b/patches/src/main/resources/addresources/values-tr-rTR/strings.xml
index b9fcc6bd3a..92b96474f4 100644
--- a/patches/src/main/resources/addresources/values-tr-rTR/strings.xml
+++ b/patches/src/main/resources/addresources/values-tr-rTR/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Oynatıcı açılır panelleri gizleniyor
Oynatıcı açılır panelleri gösteriliyor
+
+
Oynatıcı opaklığı
0-100 arasında opaklık değeri, 0 şeffaftır
@@ -1200,14 +1202,10 @@ This is because Crowdin requires temporarily flattening this file and removing t
Bu ayarı devre dışı bırakmak video oynatma sorunlarına yol açabilir.
Varsayılan istemci
AVC\'yi (H.264) zorla
- Video kodeği AVC (H.264)
- Video kodeği VP9 ya da AV1
- Cihazınız VP9 donanım çözme özelliği yok ve bu ayar istemci taklit etme açık iken her zaman açıktır
- Bunu etkinleştirmek batarya ömrünü uzatabilir ve oynatma takılmalarını çözebilir.\n\nAVC en fazla 1080p çözünürlüğe sahiptir ve video oynatımı VP9 veya AV1\'e göre daha fazla internet harcayacaktır.
iOS taklidi yan etkileri
- • Çocuklara özel gizli videolar oynatılamayabilir\n• Canlı yayınlar en baştan başlar\n• Videolar 1 saniye erken bitebilir\n• Opus ses kodeği yok
Android VR taklidi yan etkileri
• Çocuklara özel videolar oynatılamayabilir\n• Ses parçası menüsü eksik\n• Sabit ses özelliği kullanılamaz
+ Video akışları taklit ediliyor
diff --git a/patches/src/main/resources/addresources/values-uk-rUA/strings.xml b/patches/src/main/resources/addresources/values-uk-rUA/strings.xml
index b6ed686482..09ce4fef5e 100644
--- a/patches/src/main/resources/addresources/values-uk-rUA/strings.xml
+++ b/patches/src/main/resources/addresources/values-uk-rUA/strings.xml
@@ -709,6 +709,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Автоматичні спливаючі панелі плеєра приховано, такі як список відтворення чи чат
Автоматичні спливаючі панелі плеєра показуються
+
+ Відкривати відео в портретному режимі
+ Відео відкриваються в повноекранному режимі
+ Відео не відкривають на весь екран
+
Затемнення плеєра при натисканні
Значення непрозорості затемнення при натисканні на плеєр в межах 0-100, де 0 це прозоро
@@ -1200,14 +1205,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Вимкнення цього параметра може спричинити проблеми відтворення відео.
Клієнт за замовчуванням
Примусово AVC (H.264)
- Примусово увімкнено відеокодек AVC (H.264)
- Примусово увімкнено відеокодек VP9 або AV1
- Ваш пристрій не має апаратного декодування VP9, тому це налаштування завжди ввімкнено, коли ввімкнено підробку відеопотоків
- Увімкнення цієї опції може збільшити час роботи від акумулятора та виправити затримки відтворення.\n\nAVC має максимальну роздільну здатність 1080p, а відтворення відео використовуватиме більше інтернет-даних, ніж на кодеках VP9 або AV1.
+ Відео кодек змушений до AVC (H.264)
+ Відеокодек визначається автоматично
+ Увімкнення цієї функції може збільшити час роботи акумулятора та виправити режим зупинки відтворення.\n\nAVC має максимальну роздільну здатність 1080p, відсутній аудіо-кодек Opus і відтворення відео буде використовувати більше даних Інтернету, ніж VP9 або AV1.
Побічні ефекти підробки iOS:
- • Приватні дитячі відео можуть не відтворюватися\n• Прямі трансляції починаються з початку\n• Відео можуть закінчуватися на 1 секунду раніше\n• Відсутній аудіокодек Opus
+ • Приватні дитячі відео можуть не відтворюватися\n• Прямі трансляції починаються з початку\n• Відео можуть закінчуватися на 1 секунду раніше
Побічні ефекти підробки Android VR:
• Дитячі відео можуть не відтворюватися\n• Меню звукової доріжки відсутнє\n• Меню стабілізації гучності недоступне
+ Відеопотоки підроблено
+ Бажана мова аудіо-потоків
+ Мова додатку
+ Арабська
+ Азербайджанська
+ Болгарська
+ Бенгальська
+ Каталонська
+ Чеська
+ Данська
+ Німецька
+ Грецька
+ Англійська
+ Іспанська
+ Естонська
+ Фарсі
+ Фінська
+ Français
+ Gujarati
+ Гінді
+ Хорватська
+ Угорська
+ Індонезійська
+ Італійська
+ Японська
+ Kazakh
+ Корейська
+ Литовська
+ Латиська
+ Македонська
+ Монгольська
+ Маратхі
+ Малайська
+ Burmese
+ Голландська
+ Odia
+ Punjabi
+ Польська
+ Португальська (Бразилія)
+ Португальська (Португалія)
+ Румунська
+ Російська
+ Словацька
+ Slovene
+ Сербська
+ Шведська
+ Суахілі
+ Tamil
+ Telugu
+ Тайська
+ Турецька
+ Українська
+ Урду
+ Vietnamese
+ Китайська
diff --git a/patches/src/main/resources/addresources/values-ur-rIN/strings.xml b/patches/src/main/resources/addresources/values-ur-rIN/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-ur-rIN/strings.xml
+++ b/patches/src/main/resources/addresources/values-ur-rIN/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-uz-rUZ/strings.xml b/patches/src/main/resources/addresources/values-uz-rUZ/strings.xml
index a781a13aca..6da87a3c71 100644
--- a/patches/src/main/resources/addresources/values-uz-rUZ/strings.xml
+++ b/patches/src/main/resources/addresources/values-uz-rUZ/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values-vi-rVN/strings.xml b/patches/src/main/resources/addresources/values-vi-rVN/strings.xml
index 8bd5d6c9d2..d8b3663fe5 100644
--- a/patches/src/main/resources/addresources/values-vi-rVN/strings.xml
+++ b/patches/src/main/resources/addresources/values-vi-rVN/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
Bảng bật lên trên trình phát được ẩn
Bảng bật lên trên trình phát được hiện
+
+
Độ mờ của lớp phủ trình phát
Giá trị độ mờ của lớp phủ trình phát trong khoảng từ 0 đến 100, trong đó 0 là trong suốt
@@ -1200,14 +1202,10 @@ This is because Crowdin requires temporarily flattening this file and removing t
Việc tắt cài đặt này có thể gây ra sự cố phát nền video.
Máy khách mặc định
AVC (H.264) ép buộc
- Bộ giải mã là AVC (H.264)
- Bộ giải mã là VP9 hoặc AV1
- Thiết bị của bạn không có phần cứng giải mã VP9, và thiết lập này luôn bật khi Giả mạo máy khách bật
- Bật chức năng này có thể tăng cường thời lượng pin và sửa lỗi phát lặp.\n\nAVC có độ phân giải tối đa 1080p, và video phát sẽ dùng nhiều dữ liệu mạng hơn VP9 hoặc AV1.
Tác dụng phụ của giả mạo iOS
- •Video trẻ em riêng tư có thể không phát được \n •Phát trực tiếp bắt đầu từ đầu \n • Video có thể kết thúc sớm 1 giây \n • Không có codec âm thanh Opus
Tác dụng phụ của giả mạo Android VR
• Video trẻ em có thể không phát được \n • Menu chọn bản âm thanh không khả dụng \n • Âm lượng ổn định không có sẵn
+ Luồng video đã được giả mạo
diff --git a/patches/src/main/resources/addresources/values-zh-rCN/strings.xml b/patches/src/main/resources/addresources/values-zh-rCN/strings.xml
index 3c7ef8dc2e..99aefcf2de 100644
--- a/patches/src/main/resources/addresources/values-zh-rCN/strings.xml
+++ b/patches/src/main/resources/addresources/values-zh-rCN/strings.xml
@@ -703,6 +703,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
播放器弹出面板已隐藏
显示播放器弹出面板
+
+ 全屏竖屏打开视频
+ 视频打开全屏
+ 视频不全屏
+
玩家覆盖不透明度
0-100之间的不透明度值, 其中0是透明的
@@ -1182,13 +1187,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
关闭此选项可能会导致视频不能正常播放。
默认客户端
强制使用 AVC (H.264)
- 视频编解码器是 AVC (H.264)
- 视频编解码器是 VP9 或 AV1
- 您的设备没有 VP9 硬件解码,启用客户端伪装时此设置始终开启
- 启用此功能可能会改善电池续航力并修复播放卡顿问题。\n\nAVC 的最大解析度为 1080p,且影片播放将使用比 VP9 或 AV1 更多的网路数据。
+ 视频编解码器被强制使用 AVC (H.264)
+ 视频编解码器自动确定
+ 启用这可能会改善电池寿命并修复播放停顿。\n\nAVC 最大分辨率为1080p, Opus 音频编解码器不可用。 视频播放将使用比VP9或AV1更多的网络数据。
iOS 伪装副作用
+ • 私人孩子视频可能无法播放\n• 生命线从开头开始\n• 视频可能提前结束 1 秒
Android VR 伪装副作用
• 儿童视频可能无法播放\n• 音轨菜单丢失\n• 稳定音量
+ 视频流已被破坏了
+ 首选音频流语言
+ 应用语言
+ 阿拉伯语
+ 阿塞拜疆文
+ 保加利亚文
+ 孟加拉语
+ 加泰罗尼亚语
+ 捷克语
+ 丹麦语
+ 德文
+ 希腊语
+ 英语
+ 西班牙语
+ 爱沙尼亚语
+ 波斯文
+ 芬兰语
+ French
+ Gujarati
+ 印地文
+ 克罗地亚语
+ 匈牙利
+ 印尼语
+ 意大利语
+ 日语
+ Kazakh
+ 韩语
+ 立陶宛语
+ 拉脱维亚语
+ 马其顿语
+ 蒙古语
+ 马拉蒂文
+ 马来文
+ Burmese
+ 荷兰语
+ Odia
+ Punjabi
+ 波兰语
+ 葡萄牙语(巴西)
+ 葡萄牙语(葡萄牙)
+ 罗马尼亚语
+ 俄文
+ 斯洛伐克语
+ Slovene
+ 塞尔维亚语
+ 瑞典语
+ 斯瓦希里文
+ Tamil
+ Telugu
+ 泰文
+ 土耳其语
+ 乌克兰语
+ 乌尔都文
+ Vietnamese
+ 中文
diff --git a/patches/src/main/resources/addresources/values-zh-rTW/strings.xml b/patches/src/main/resources/addresources/values-zh-rTW/strings.xml
index aedf82236e..5b1fa28b0f 100644
--- a/patches/src/main/resources/addresources/values-zh-rTW/strings.xml
+++ b/patches/src/main/resources/addresources/values-zh-rTW/strings.xml
@@ -709,6 +709,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
已隱藏播放器彈出面板
已顯示播放器彈出面板
+
+
播放器覆蓋透明度
不透明度值介於 0-100 之間,0 為透明
@@ -1201,14 +1203,12 @@ This is because Crowdin requires temporarily flattening this file and removing t
關閉此設定可能會導致影片播放發生問題
預設用戶端
強制 AVC (H.264)
- 影片編碼器為 AVC (H.264)
- 影片編碼器為 VP9 或 AV1
- 您的裝置不支援 VP9 硬體解碼,當啟用用戶端欺騙時,此設定將始終保持開啟
- 啟用此功能可能會改善電池續航力並修復播放卡頓問題。\n\nAVC 的最大解析度為 1080p,且影片播放將使用比 VP9 或 AV1 更多的網路數據。
iOS 欺騙副作用
- • 私人的兒童影片有可能不會播放\n• 從直播起始處播放\n• 影片可能會提早一秒結束\n• 找不到音訊解碼器
+ • 私人的兒童影片有可能不會播放\n• 從直播起始處播放\n• 影片可能會提早一秒結束
Android VR 欺騙副作用
• 私人的兒童影片有可能不會播放\n• 找不到音樂曲目選單\n• 音量平衡不可用
+ 已欺騙影片串流
+ 英文
diff --git a/patches/src/main/resources/addresources/values-zu-rZA/strings.xml b/patches/src/main/resources/addresources/values-zu-rZA/strings.xml
index 91ed738784..fd725fe22e 100644
--- a/patches/src/main/resources/addresources/values-zu-rZA/strings.xml
+++ b/patches/src/main/resources/addresources/values-zu-rZA/strings.xml
@@ -147,6 +147,8 @@ This is because Crowdin requires temporarily flattening this file and removing t
+
+
diff --git a/patches/src/main/resources/addresources/values/arrays.xml b/patches/src/main/resources/addresources/values/arrays.xml
index de96c6e5b5..bc66bb4bea 100644
--- a/patches/src/main/resources/addresources/values/arrays.xml
+++ b/patches/src/main/resources/addresources/values/arrays.xml
@@ -11,6 +11,116 @@
- ANDROID_VR
- IOS
+
+ - @string/revanced_spoof_video_streams_language_DEFAULT
+ - @string/revanced_spoof_video_streams_language_AR
+ - @string/revanced_spoof_video_streams_language_AZ
+ - @string/revanced_spoof_video_streams_language_BG
+ - @string/revanced_spoof_video_streams_language_BN
+ - @string/revanced_spoof_video_streams_language_CA
+ - @string/revanced_spoof_video_streams_language_CS
+ - @string/revanced_spoof_video_streams_language_DA
+ - @string/revanced_spoof_video_streams_language_DE
+ - @string/revanced_spoof_video_streams_language_EL
+ - @string/revanced_spoof_video_streams_language_EN
+ - @string/revanced_spoof_video_streams_language_ES
+ - @string/revanced_spoof_video_streams_language_ET
+ - @string/revanced_spoof_video_streams_language_FA
+ - @string/revanced_spoof_video_streams_language_FI
+ - @string/revanced_spoof_video_streams_language_FR
+ - @string/revanced_spoof_video_streams_language_GU
+ - @string/revanced_spoof_video_streams_language_HI
+ - @string/revanced_spoof_video_streams_language_HR
+ - @string/revanced_spoof_video_streams_language_HU
+ - @string/revanced_spoof_video_streams_language_ID
+ - @string/revanced_spoof_video_streams_language_IT
+ - @string/revanced_spoof_video_streams_language_JA
+ - @string/revanced_spoof_video_streams_language_KK
+ - @string/revanced_spoof_video_streams_language_KO
+ - @string/revanced_spoof_video_streams_language_LT
+ - @string/revanced_spoof_video_streams_language_LV
+ - @string/revanced_spoof_video_streams_language_MK
+ - @string/revanced_spoof_video_streams_language_MN
+ - @string/revanced_spoof_video_streams_language_MR
+ - @string/revanced_spoof_video_streams_language_MS
+ - @string/revanced_spoof_video_streams_language_MY
+ - @string/revanced_spoof_video_streams_language_NL
+ - @string/revanced_spoof_video_streams_language_OR
+ - @string/revanced_spoof_video_streams_language_PA
+ - @string/revanced_spoof_video_streams_language_PL
+ - @string/revanced_spoof_video_streams_language_PT_BR
+ - @string/revanced_spoof_video_streams_language_PT_PT
+ - @string/revanced_spoof_video_streams_language_RO
+ - @string/revanced_spoof_video_streams_language_RU
+ - @string/revanced_spoof_video_streams_language_SK
+ - @string/revanced_spoof_video_streams_language_SL
+ - @string/revanced_spoof_video_streams_language_SR
+ - @string/revanced_spoof_video_streams_language_SV
+ - @string/revanced_spoof_video_streams_language_SW
+ - @string/revanced_spoof_video_streams_language_TA
+ - @string/revanced_spoof_video_streams_language_TE
+ - @string/revanced_spoof_video_streams_language_TH
+ - @string/revanced_spoof_video_streams_language_TR
+ - @string/revanced_spoof_video_streams_language_UK
+ - @string/revanced_spoof_video_streams_language_UR
+ - @string/revanced_spoof_video_streams_language_VI
+ - @string/revanced_spoof_video_streams_language_ZH
+
+
+ - DEFAULT
+ - AR
+ - AZ
+ - BG
+ - BN
+ - CA
+ - CS
+ - DA
+ - DE
+ - EL
+ - EN
+ - ES
+ - ET
+ - FA
+ - FI
+ - FR
+ - GU
+ - HI
+ - HR
+ - HU
+ - ID
+ - IT
+ - JA
+ - KK
+ - KO
+ - LT
+ - LV
+ - MK
+ - MN
+ - MR
+ - MS
+ - MY
+ - NL
+ - OR
+ - PA
+ - PL
+ - PT_BR
+ - PT_PT
+ - RO
+ - RU
+ - SK
+ - SL
+ - SR
+ - SV
+ - SW
+ - TA
+ - TE
+ - TH
+ - TR
+ - UK
+ - UR
+ - VI
+ - ZH
+
diff --git a/patches/src/main/resources/addresources/values/strings.xml b/patches/src/main/resources/addresources/values/strings.xml
index c8a3636853..82f37cd657 100644
--- a/patches/src/main/resources/addresources/values/strings.xml
+++ b/patches/src/main/resources/addresources/values/strings.xml
@@ -715,6 +715,11 @@ This is because Crowdin requires temporarily flattening this file and removing t
Player popup panels are hidden
Player popup panels are shown
+
+ Open videos in fullscreen portrait
+ Videos open fullscreen
+ Videos do not open fullscreen
+
Player overlay opacity
Opacity value between 0-100, where 0 is transparent
@@ -1220,14 +1225,68 @@ This is because Crowdin requires temporarily flattening this file and removing t
Turning off this setting may cause video playback issues.
Default client
Force AVC (H.264)
- Video codec is AVC (H.264)
- Video codec is VP9 or AV1
- Your device does not have VP9 hardware decoding, and this setting is always on when Client spoofing is enabled
- Enabling this might improve battery life and fix playback stuttering.\n\nAVC has a maximum resolution of 1080p, and video playback will use more internet data than VP9 or AV1.
+ Video codec is forced to AVC (H.264)
+ Video codec is determined automatically
+ Enabling this might improve battery life and fix playback stuttering.\n\nAVC has a maximum resolution of 1080p, Opus audio codec is not available, and video playback will use more internet data than VP9 or AV1.
iOS spoofing side effects
- • Private kids videos may not play\n• Livestreams start from the beginning\n• Videos may end 1 second early\n• No opus audio codec
+ • Private kids videos may not play\n• Livestreams start from the beginning\n• Videos may end 1 second early
Android VR spoofing side effects
• Kids videos may not play\n• Audio track menu is missing\n• Stable volume is not available
+ Video streams are spoofed
+ Preferred audio stream language
+ App language
+ Arabic
+ Azerbaijani
+ Bulgarian
+ Bengali
+ Catalan
+ Czech
+ Danish
+ German
+ Greek
+ English
+ Spanish
+ Estonian
+ Persian
+ Finnish
+ French
+ Gujarati
+ Hindi
+ Croatian
+ Hungarian
+ Indonesian
+ Italian
+ Japanese
+ Kazakh
+ Korean
+ Lithuanian
+ Latvian
+ Macedonian
+ Mongolian
+ Marathi
+ Malay
+ Burmese
+ Dutch
+ Odia
+ Punjabi
+ Polish
+ Portuguese (Brazil)
+ Portuguese (Portugal)
+ Romanian
+ Russian
+ Slovak
+ Slovene
+ Serbian
+ Swedish
+ Swahili
+ Tamil
+ Telugu
+ Thai
+ Turkish
+ Ukrainian
+ Urdu
+ Vietnamese
+ Chinese