mirror of
https://github.com/revanced/revanced-patches
synced 2025-01-16 02:27:34 +01:00
feat(Tiktok - Playback speed): Remember playback speed (#2506)
Co-authored-by: oSumAtrIX <johan.melkonyan1@web.de>
This commit is contained in:
parent
6a5e1f3a6e
commit
d2970e54fb
@ -10,7 +10,6 @@ import com.android.tools.smali.dexlib2.iface.instruction.Instruction
|
|||||||
|
|
||||||
@Suppress("MemberVisibilityCanBePrivate")
|
@Suppress("MemberVisibilityCanBePrivate")
|
||||||
abstract class AbstractTransformInstructionsPatch<T> : BytecodePatch() {
|
abstract class AbstractTransformInstructionsPatch<T> : BytecodePatch() {
|
||||||
|
|
||||||
abstract fun filterMap(
|
abstract fun filterMap(
|
||||||
classDef: ClassDef,
|
classDef: ClassDef,
|
||||||
method: Method,
|
method: Method,
|
||||||
|
@ -1,49 +1,82 @@
|
|||||||
package app.revanced.patches.tiktok.interaction.speed
|
package app.revanced.patches.tiktok.interaction.speed
|
||||||
|
|
||||||
import app.revanced.patcher.data.BytecodeContext
|
import app.revanced.patcher.data.BytecodeContext
|
||||||
|
import app.revanced.patcher.extensions.InstructionExtensions.addInstruction
|
||||||
import app.revanced.patcher.extensions.InstructionExtensions.addInstructions
|
import app.revanced.patcher.extensions.InstructionExtensions.addInstructions
|
||||||
|
import app.revanced.patcher.extensions.InstructionExtensions.getInstruction
|
||||||
import app.revanced.patcher.patch.BytecodePatch
|
import app.revanced.patcher.patch.BytecodePatch
|
||||||
|
import app.revanced.patcher.patch.PatchException
|
||||||
import app.revanced.patcher.patch.annotation.CompatiblePackage
|
import app.revanced.patcher.patch.annotation.CompatiblePackage
|
||||||
import app.revanced.patcher.patch.annotation.Patch
|
import app.revanced.patcher.patch.annotation.Patch
|
||||||
import app.revanced.patcher.util.proxy.mutableTypes.MutableMethod
|
import app.revanced.patches.tiktok.interaction.speed.fingerprints.GetSpeedFingerprint
|
||||||
import app.revanced.patches.tiktok.interaction.speed.fingerprints.SpeedControlParentFingerprint
|
import app.revanced.patches.tiktok.interaction.speed.fingerprints.OnRenderFirstFrameFingerprint
|
||||||
|
import app.revanced.patches.tiktok.interaction.speed.fingerprints.SetSpeedFingerprint
|
||||||
import app.revanced.util.exception
|
import app.revanced.util.exception
|
||||||
|
import app.revanced.util.getReference
|
||||||
import app.revanced.util.indexOfFirstInstruction
|
import app.revanced.util.indexOfFirstInstruction
|
||||||
import com.android.tools.smali.dexlib2.Opcode
|
import com.android.tools.smali.dexlib2.iface.instruction.formats.Instruction11x
|
||||||
import com.android.tools.smali.dexlib2.iface.instruction.formats.Instruction35c
|
|
||||||
import com.android.tools.smali.dexlib2.iface.reference.MethodReference
|
import com.android.tools.smali.dexlib2.iface.reference.MethodReference
|
||||||
|
|
||||||
@Patch(
|
@Patch(
|
||||||
name = "Playback speed",
|
name = "Playback speed",
|
||||||
description = "Enables the playback speed option for all videos.",
|
description = "Enables the playback speed option for all videos and " +
|
||||||
|
"retains the speed configurations in between videos.",
|
||||||
compatiblePackages = [
|
compatiblePackages = [
|
||||||
CompatiblePackage("com.ss.android.ugc.trill", ["32.5.3"]),
|
CompatiblePackage("com.ss.android.ugc.trill", ["32.5.3"]),
|
||||||
CompatiblePackage("com.zhiliaoapp.musically", ["32.5.3"])
|
CompatiblePackage("com.zhiliaoapp.musically", ["32.5.3"])
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
@Suppress("unused")
|
@Suppress("unused")
|
||||||
object PlaybackSpeedPatch : BytecodePatch(setOf(SpeedControlParentFingerprint)) {
|
object PlaybackSpeedPatch : BytecodePatch(
|
||||||
|
setOf(
|
||||||
|
GetSpeedFingerprint,
|
||||||
|
OnRenderFirstFrameFingerprint,
|
||||||
|
SetSpeedFingerprint
|
||||||
|
)
|
||||||
|
) {
|
||||||
override fun execute(context: BytecodeContext) {
|
override fun execute(context: BytecodeContext) {
|
||||||
SpeedControlParentFingerprint.result?.mutableMethod?.apply {
|
SetSpeedFingerprint.result?.let { onVideoSwiped ->
|
||||||
val targetMethodCallIndex = indexOfFirstInstruction {
|
// Remember the playback speed of the current video.
|
||||||
if (opcode == Opcode.INVOKE_STATIC) {
|
GetSpeedFingerprint.result?.mutableMethod?.apply {
|
||||||
val paramsTypes = ((this as Instruction35c).reference as MethodReference).parameterTypes
|
val injectIndex = indexOfFirstInstruction { getReference<MethodReference>()?.returnType == "F" } + 2
|
||||||
paramsTypes.size == 1 && paramsTypes[0].contains("/Aweme;")
|
val register = getInstruction<Instruction11x>(injectIndex - 1).registerA
|
||||||
} else false
|
|
||||||
}
|
|
||||||
|
|
||||||
val isSpeedEnableMethod = context
|
addInstruction(
|
||||||
.toMethodWalker(this)
|
injectIndex,
|
||||||
.nextMethod(targetMethodCallIndex, true)
|
"invoke-static { v$register }," +
|
||||||
.getMethod() as MutableMethod
|
" Lapp/revanced/tiktok/speed/SpeedPatch;->rememberPlaybackSpeed(F)V"
|
||||||
|
)
|
||||||
|
} ?: throw GetSpeedFingerprint.exception
|
||||||
|
|
||||||
isSpeedEnableMethod.addInstructions(
|
// By default, the playback speed will reset to 1.0 at the start of each video.
|
||||||
|
// Instead, override it with the desired playback speed.
|
||||||
|
OnRenderFirstFrameFingerprint.result?.mutableMethod?.addInstructions(
|
||||||
0,
|
0,
|
||||||
"""
|
"""
|
||||||
const/4 v0, 0x1
|
# Video playback location (e.g. home page, following page or search result page) retrieved using getEnterFrom method.
|
||||||
return v0
|
const/4 v0, 0x1
|
||||||
|
invoke-virtual {p0, v0}, Lcom/ss/android/ugc/aweme/feed/panel/BaseListFragmentPanel;->getEnterFrom(Z)Ljava/lang/String;
|
||||||
|
move-result-object v0
|
||||||
|
|
||||||
|
# Model of current video retrieved using getCurrentAweme method.
|
||||||
|
invoke-virtual {p0}, Lcom/ss/android/ugc/aweme/feed/panel/BaseListFragmentPanel;->getCurrentAweme()Lcom/ss/android/ugc/aweme/feed/model/Aweme;
|
||||||
|
move-result-object v1
|
||||||
|
|
||||||
|
# Desired playback speed retrieved using getPlaybackSpeed method.
|
||||||
|
invoke-static {}, Lapp/revanced/tiktok/speed/SpeedPatch;->getPlaybackSpeed()F
|
||||||
|
move-result-object v2
|
||||||
|
invoke-static { v0, v1, v2 }, ${onVideoSwiped.method}
|
||||||
|
"""
|
||||||
|
) ?: throw OnRenderFirstFrameFingerprint.exception
|
||||||
|
|
||||||
|
// Force enable the playback speed option for all videos.
|
||||||
|
onVideoSwiped.mutableClass.methods.find { method -> method.returnType == "Z" }?.addInstructions(
|
||||||
|
0,
|
||||||
"""
|
"""
|
||||||
)
|
const/4 v0, 0x1
|
||||||
} ?: throw SpeedControlParentFingerprint.exception
|
return v0
|
||||||
|
"""
|
||||||
|
) ?: throw PatchException("Failed to force enable the playback speed option.")
|
||||||
|
} ?: throw SetSpeedFingerprint.exception
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,9 @@
|
|||||||
|
package app.revanced.patches.tiktok.interaction.speed.fingerprints
|
||||||
|
|
||||||
|
import app.revanced.patcher.fingerprint.MethodFingerprint
|
||||||
|
|
||||||
|
internal object GetSpeedFingerprint : MethodFingerprint(
|
||||||
|
customFingerprint = { methodDef, _ ->
|
||||||
|
methodDef.definingClass.endsWith("/BaseListFragmentPanel;") && methodDef.name == "onFeedSpeedSelectedEvent"
|
||||||
|
}
|
||||||
|
)
|
@ -0,0 +1,9 @@
|
|||||||
|
package app.revanced.patches.tiktok.interaction.speed.fingerprints
|
||||||
|
|
||||||
|
import app.revanced.patcher.fingerprint.MethodFingerprint
|
||||||
|
|
||||||
|
internal object OnRenderFirstFrameFingerprint : MethodFingerprint(
|
||||||
|
customFingerprint = { methodDef, _ ->
|
||||||
|
methodDef.definingClass.endsWith("/BaseListFragmentPanel;") && methodDef.name == "onRenderFirstFrame"
|
||||||
|
}
|
||||||
|
)
|
@ -0,0 +1,16 @@
|
|||||||
|
package app.revanced.patches.tiktok.interaction.speed.fingerprints
|
||||||
|
|
||||||
|
import app.revanced.patcher.extensions.or
|
||||||
|
import app.revanced.patcher.fingerprint.MethodFingerprint
|
||||||
|
import com.android.tools.smali.dexlib2.AccessFlags
|
||||||
|
|
||||||
|
internal object SetSpeedFingerprint : MethodFingerprint(
|
||||||
|
returnType = "V",
|
||||||
|
accessFlags = AccessFlags.PUBLIC or AccessFlags.STATIC,
|
||||||
|
parameters = listOf(
|
||||||
|
"Ljava/lang/String;",
|
||||||
|
"Lcom/ss/android/ugc/aweme/feed/model/Aweme;",
|
||||||
|
"F"
|
||||||
|
),
|
||||||
|
strings = listOf("enterFrom")
|
||||||
|
)
|
@ -1,13 +0,0 @@
|
|||||||
package app.revanced.patches.tiktok.interaction.speed.fingerprints
|
|
||||||
|
|
||||||
import app.revanced.patcher.extensions.or
|
|
||||||
import app.revanced.patcher.fingerprint.MethodFingerprint
|
|
||||||
import com.android.tools.smali.dexlib2.AccessFlags
|
|
||||||
|
|
||||||
internal object SpeedControlParentFingerprint : MethodFingerprint(
|
|
||||||
strings = listOf(
|
|
||||||
"onStopTrackingTouch, hasTouchMove=",
|
|
||||||
", isCurVideoPaused: ",
|
|
||||||
"already_shown_edge_speed_guide"
|
|
||||||
)
|
|
||||||
)
|
|
Loading…
x
Reference in New Issue
Block a user