feat(music/hide-cast-button): patch now hides the cast banner inside the player

This commit is contained in:
inotia00 2023-09-20 14:55:58 +09:00
parent 5dc592ac0d
commit dc02ee4933
5 changed files with 65 additions and 30 deletions

View File

@ -1,11 +0,0 @@
package app.revanced.patches.music.general.castbutton.fingerprints
import app.revanced.patcher.extensions.or
import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint
import com.android.tools.smali.dexlib2.AccessFlags
object HideCastButtonFingerprint : MethodFingerprint(
returnType = "V",
accessFlags = AccessFlags.PUBLIC or AccessFlags.FINAL,
parameters = listOf("I")
)

View File

@ -4,8 +4,8 @@ import app.revanced.patcher.extensions.or
import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint
import com.android.tools.smali.dexlib2.AccessFlags import com.android.tools.smali.dexlib2.AccessFlags
object HideCastButtonParentFingerprint : MethodFingerprint( object MediaRouteButtonFingerprint : MethodFingerprint(
returnType = "Z", returnType = "Z",
accessFlags = AccessFlags.PRIVATE or AccessFlags.FINAL, accessFlags = AccessFlags.PRIVATE or AccessFlags.FINAL,
strings = listOf("MediaRouteButton") strings = listOf("MediaRouteButton")
) )

View File

@ -0,0 +1,13 @@
package app.revanced.patches.music.general.castbutton.fingerprints
import app.revanced.patcher.extensions.or
import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint
import app.revanced.patches.music.utils.resourceid.patch.SharedResourceIdPatch.Companion.PlayerOverlayChip
import app.revanced.util.bytecode.isWideLiteralExists
import com.android.tools.smali.dexlib2.AccessFlags
object PlayerOverlayChipFingerprint : MethodFingerprint(
returnType = "L",
accessFlags = AccessFlags.PUBLIC or AccessFlags.FINAL,
customFingerprint = { methodDef, _ -> methodDef.isWideLiteralExists(PlayerOverlayChip) }
)

View File

@ -4,41 +4,72 @@ import app.revanced.extensions.exception
import app.revanced.patcher.annotation.Description import app.revanced.patcher.annotation.Description
import app.revanced.patcher.annotation.Name import app.revanced.patcher.annotation.Name
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.fingerprint.method.impl.MethodFingerprint.Companion.resolve 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.annotations.DependsOn import app.revanced.patcher.patch.annotations.DependsOn
import app.revanced.patcher.patch.annotations.Patch import app.revanced.patcher.patch.annotations.Patch
import app.revanced.patches.music.general.castbutton.fingerprints.HideCastButtonFingerprint import app.revanced.patches.music.general.castbutton.fingerprints.MediaRouteButtonFingerprint
import app.revanced.patches.music.general.castbutton.fingerprints.HideCastButtonParentFingerprint import app.revanced.patches.music.general.castbutton.fingerprints.PlayerOverlayChipFingerprint
import app.revanced.patches.music.utils.annotations.MusicCompatibility import app.revanced.patches.music.utils.annotations.MusicCompatibility
import app.revanced.patches.music.utils.resourceid.patch.SharedResourceIdPatch
import app.revanced.patches.music.utils.resourceid.patch.SharedResourceIdPatch.Companion.PlayerOverlayChip
import app.revanced.patches.music.utils.settings.resource.patch.SettingsPatch import app.revanced.patches.music.utils.settings.resource.patch.SettingsPatch
import app.revanced.util.bytecode.getWideLiteralIndex
import app.revanced.util.enum.CategoryType import app.revanced.util.enum.CategoryType
import app.revanced.util.integrations.Constants.MUSIC_GENERAL import app.revanced.util.integrations.Constants.MUSIC_GENERAL
import com.android.tools.smali.dexlib2.iface.instruction.OneRegisterInstruction
@Patch @Patch
@Name("Hide cast button") @Name("Hide cast button")
@Description("Hides the cast button.") @Description("Hides the cast button.")
@DependsOn([SettingsPatch::class]) @DependsOn(
[
SettingsPatch::class,
SharedResourceIdPatch::class
]
)
@MusicCompatibility @MusicCompatibility
class HideCastButtonPatch : BytecodePatch( class HideCastButtonPatch : BytecodePatch(
listOf(HideCastButtonParentFingerprint) listOf(
MediaRouteButtonFingerprint,
PlayerOverlayChipFingerprint
)
) { ) {
override fun execute(context: BytecodeContext) { override fun execute(context: BytecodeContext) {
HideCastButtonParentFingerprint.result?.let { parentResult -> /**
HideCastButtonFingerprint.also { * Hide cast button
it.resolve( */
context, MediaRouteButtonFingerprint.result?.let {
parentResult.classDef val setVisibilityMethod = it.mutableClass.methods.find { method -> method.name == "setVisibility" }
setVisibilityMethod?.apply {
addInstructions(
0, """
invoke-static {p1}, $MUSIC_GENERAL->hideCastButton(I)I
move-result p1
"""
) )
}.result?.mutableMethod?.addInstructions( } ?: throw PatchException("Failed to find setVisibility method")
0, """ } ?: throw MediaRouteButtonFingerprint.exception
invoke-static {p1}, $MUSIC_GENERAL->hideCastButton(I)I
move-result p1 /**
""" * Hide floating cast banner
) ?: throw HideCastButtonFingerprint.exception */
} ?: throw HideCastButtonParentFingerprint.exception PlayerOverlayChipFingerprint.result?.let {
it.mutableMethod.apply {
val targetIndex = getWideLiteralIndex(PlayerOverlayChip) + 2
val targetRegister = getInstruction<OneRegisterInstruction>(targetIndex).registerA
addInstruction(
targetIndex + 1,
"invoke-static {v$targetRegister}, $MUSIC_GENERAL->hideCastButton(Landroid/view/View;)V"
)
}
}
SettingsPatch.addMusicPreference( SettingsPatch.addMusicPreference(
CategoryType.GENERAL, CategoryType.GENERAL,

View File

@ -28,6 +28,7 @@ class SharedResourceIdPatch : ResourcePatch {
var MenuEntry: Long = -1 var MenuEntry: Long = -1
var MusicMenuLikeButtons: Long = -1 var MusicMenuLikeButtons: Long = -1
var NamesInactiveAccountThumbnailSize: Long = -1 var NamesInactiveAccountThumbnailSize: Long = -1
var PlayerOverlayChip: Long = -1
var PrivacyTosFooter: Long = -1 var PrivacyTosFooter: Long = -1
var QualityAuto: Long = -1 var QualityAuto: Long = -1
var Text1: Long = -1 var Text1: Long = -1
@ -54,6 +55,7 @@ class SharedResourceIdPatch : ResourcePatch {
MenuEntry = find(LAYOUT, "menu_entry") MenuEntry = find(LAYOUT, "menu_entry")
MusicMenuLikeButtons = find(LAYOUT, "music_menu_like_buttons") MusicMenuLikeButtons = find(LAYOUT, "music_menu_like_buttons")
NamesInactiveAccountThumbnailSize = find(DIMEN, "names_inactive_account_thumbnail_size") NamesInactiveAccountThumbnailSize = find(DIMEN, "names_inactive_account_thumbnail_size")
PlayerOverlayChip = find(ID, "player_overlay_chip")
PrivacyTosFooter = find(ID, "privacy_tos_footer") PrivacyTosFooter = find(ID, "privacy_tos_footer")
QualityAuto = find(STRING, "quality_auto") QualityAuto = find(STRING, "quality_auto")
Text1 = find(ID, "text1") Text1 = find(ID, "text1")