From 024c4a77fd46e943ab625d715feed2345ba083a3 Mon Sep 17 00:00:00 2001 From: mu7220 <80700814+mu7220@users.noreply.github.com> Date: Fri, 9 Feb 2024 17:06:12 +0800 Subject: [PATCH] fix: The problem of hidden negative screen failure under the lock screen interface (hyperos) Signed-off-by: mu7220 <80700814+mu7220@users.noreply.github.com> --- .../hook/systemui/lockscreen/BlurButton.kt | 240 +++++++----------- .../hook/systemui/lockscreen/RemoveCamera.kt | 51 +++- .../systemui/lockscreen/RemoveSmartScreen.kt | 29 ++- 3 files changed, 149 insertions(+), 171 deletions(-) diff --git a/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/BlurButton.kt b/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/BlurButton.kt index 2b9fa9b3af..d0b66139ba 100644 --- a/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/BlurButton.kt +++ b/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/BlurButton.kt @@ -33,14 +33,18 @@ import com.github.kyuubiran.ezxhelper.finders.MethodFinder.`-Static`.methodFinde import com.sevtinge.hyperceiler.module.base.BaseHook import com.sevtinge.hyperceiler.utils.blur.HookUtils.createBlurDrawable import com.sevtinge.hyperceiler.utils.devicesdk.isMoreHyperOSVersion +import de.robv.android.xposed.XC_MethodHook +@RequiresApi(Build.VERSION_CODES.S) object BlurButton : BaseHook() { - @RequiresApi(Build.VERSION_CODES.S) - override fun init() { - lateinit var mLeftAffordanceView: ImageView - lateinit var mRightAffordanceView: ImageView - lateinit var keyguardBottomAreaView: View + private val removeLeft by lazy { + mPrefsMap.getBoolean("system_ui_lock_screen_hide_smart_screen") + } + private val removeRight by lazy { + mPrefsMap.getBoolean("system_ui_lock_screen_hide_camera") + } + override fun init() { if (isMoreHyperOSVersion(1f)) { loadClassOrNull( "com.android.keyguard.injector.KeyguardBottomAreaInjector" @@ -52,41 +56,7 @@ object BlurButton : BaseHook() { ) }.toList().createHooks { after { param -> - mLeftAffordanceView = - ObjectUtils.getObjectOrNullAs( - param.thisObject, - "mLeftButton" - )!! - - mRightAffordanceView = - ObjectUtils.getObjectOrNullAs( - param.thisObject, - "mRightButton" - )!! - - // Your blur logic - val context = ObjectUtils.getObjectOrNull(param.thisObject, "mContext") as Context - val keyguardManager = - context.getSystemService(Context.KEYGUARD_SERVICE) as KeyguardManager - - if (keyguardManager.isKeyguardLocked) { - val leftBlurDrawable = createBlurDrawable( - mLeftAffordanceView, 40, 100, Color.argb(60, 255, 255, 255) - ) - val rightBlurDrawable = createBlurDrawable( - mRightAffordanceView, 40, 100, Color.argb(60, 255, 255, 255) - ) - val leftLayerDrawable = LayerDrawable(arrayOf(leftBlurDrawable)) - val rightLayerDrawable = LayerDrawable(arrayOf(rightBlurDrawable)) - leftLayerDrawable.setLayerInset(0, 40, 40, 40, 40) - rightLayerDrawable.setLayerInset(0, 40, 40, 40, 40) - mLeftAffordanceView.background = leftLayerDrawable - mRightAffordanceView.background = rightLayerDrawable - } else { - mLeftAffordanceView.background = null - mRightAffordanceView.background = null - } - + systemBlur(param) } } } else { @@ -102,126 +72,90 @@ object BlurButton : BaseHook() { ) }.toList().createHooks { after { param -> - mLeftAffordanceView = - ObjectUtils.getObjectOrNullAs( - param.thisObject, - "mLeftAffordanceView" - )!! - - mRightAffordanceView = - ObjectUtils.getObjectOrNullAs( - param.thisObject, - "mRightAffordanceView" - )!! - - keyguardBottomAreaView = param.thisObject as View - - // Your blur logic - val context = keyguardBottomAreaView.context ?: return@after - val keyguardManager = - context.getSystemService(Context.KEYGUARD_SERVICE) as KeyguardManager - - if (keyguardManager.isKeyguardLocked) { - val leftBlurDrawable = createBlurDrawable( - keyguardBottomAreaView, 40, 100, Color.argb(60, 255, 255, 255) - ) - val rightBlurDrawable = createBlurDrawable( - keyguardBottomAreaView, 40, 100, Color.argb(60, 255, 255, 255) - ) - val leftLayerDrawable = LayerDrawable(arrayOf(leftBlurDrawable)) - val rightLayerDrawable = LayerDrawable(arrayOf(rightBlurDrawable)) - leftLayerDrawable.setLayerInset(0, 40, 40, 40, 40) - rightLayerDrawable.setLayerInset(0, 40, 40, 40, 40) - mLeftAffordanceView.background = leftLayerDrawable - mRightAffordanceView.background = rightLayerDrawable - } else { - mLeftAffordanceView.background = null - mRightAffordanceView.background = null - } + systemBlur(param) } } } + } - /*var mLeftAffordanceView: WeakReference? = null - var mRightAffordanceView: WeakReference? = null - var keyguardBottomAreaView: WeakReference? = null - var handler = Handler(Looper.getMainLooper()) - var needUpdate = true - - // from com.sevtinge.hyperceiler.module.systemui.lockscreen.AddBlurEffectToLockScreen - - val keyguardBottomAreaViewClass = - findClassIfExists("com.android.systemui.statusbar.phone.KeyguardBottomAreaView") ?: return + private fun setNewBackgroundBlur(imageView: ImageView): LayerDrawable { + val blurDrawable = createBlurDrawable( + imageView, 40, 100, Color.argb(60, 255, 255, 255) + ) + val layoutDrawable = LayerDrawable(arrayOf(blurDrawable)) + layoutDrawable.setLayerInset(0, 40, 40, 40, 40) + return layoutDrawable + } - XposedBridge.hookAllMethods( - keyguardBottomAreaViewClass, - "onAttachedToWindow", - object : XC_MethodHook() { - override fun afterHookedMethod(param: MethodHookParam) { - mLeftAffordanceView = WeakReference( - getValueByField(param.thisObject, "mLeftAffordanceView") as ImageView - ) - mRightAffordanceView = WeakReference( - getValueByField(param.thisObject, "mRightAffordanceView") as ImageView - ) - keyguardBottomAreaView = WeakReference(param.thisObject as View) - } - }) - - fun createBlurLayerDrawable(view: View, color: Int): Array { - val blurDrawable = createBlurDrawable(view, 40, 100, color) - val leftLayerDrawable = LayerDrawable(arrayOf(blurDrawable)).apply { - setLayerInset(0, 40, 40, 40, 40) } - val rightLayerDrawable = LayerDrawable(arrayOf(blurDrawable)).apply { - setLayerInset(0, 40, 40, 40, 40) } - return arrayOf(leftLayerDrawable, rightLayerDrawable) - } + private fun setOldBackgroundBlur(view: View): LayerDrawable { + val blurDrawable = createBlurDrawable( + view, 40, 100, Color.argb(60, 255, 255, 255) + ) + val layoutDrawable = LayerDrawable(arrayOf(blurDrawable)) + layoutDrawable.setLayerInset(0, 40, 40, 40, 40) + return layoutDrawable + } - // 已摆烂,剩下数组异常问题(会多生成一个 0 的数组,导致抛出 ArrayIndexOutOfBoundsException 异常),感觉我没能力修好( - // 性能优化得差不多了 - val timer = Timer() - timer.scheduleAtFixedRate(object : TimerTask() { - override fun run() { - val context = keyguardBottomAreaView?.get()?.context ?: return - val keyguardManager = - context.getSystemService(Context.KEYGUARD_SERVICE) as KeyguardManager - - if (keyguardManager.isKeyguardLocked) { - if (needUpdate) { - val message = Message.obtain() - message.obj = true - handler.sendMessage(message) - needUpdate = false - } - } else { - if (needUpdate) { - val message = Message.obtain() - message.obj = false - handler.sendMessage(message) - needUpdate = false - } - } + private fun systemBlur(param: XC_MethodHook.MethodHookParam) { + if (isMoreHyperOSVersion(1f)) { + val mLeftAffordanceView: ImageView = ObjectUtils.getObjectOrNullAs( + param.thisObject, + "mLeftButton" + )!! + val mRightAffordanceView: ImageView = ObjectUtils.getObjectOrNullAs( + param.thisObject, + "mRightButton" + )!! + // Your blur logic + val context = ObjectUtils.getObjectOrNull(param.thisObject, "mContext") as Context + val keyguardManager = + context.getSystemService(Context.KEYGUARD_SERVICE) as KeyguardManager + + if (keyguardManager.isKeyguardLocked) { + mLeftAffordanceView.background = if (!removeLeft) { + setNewBackgroundBlur(mLeftAffordanceView) + } else null + mRightAffordanceView.background = if (!removeRight) { + setNewBackgroundBlur(mRightAffordanceView) + } else null + } else { + mLeftAffordanceView.background = null + mRightAffordanceView.background = null } - }, 0, 100) - - handler = object : Handler(Looper.getMainLooper()) { - override fun handleMessage(msg: Message) { - val updateFlag = msg.obj as? Boolean - if (updateFlag != null) { - if (updateFlag) { - val blurColor = Color.argb(60, 255, 255, 255) - keyguardBottomAreaView?.get()?.let { view -> - val layerDrawables = createBlurLayerDrawable(view, blurColor) - mLeftAffordanceView?.get()?.background = layerDrawables[0] - mRightAffordanceView?.get()?.background = layerDrawables[1] - } - } else { - mLeftAffordanceView?.get()?.background = null - mRightAffordanceView?.get()?.background = null - } - needUpdate = true - } + } else { + val mLeftAffordanceView: ImageView = + ObjectUtils.getObjectOrNullAs( + param.thisObject, + "mLeftAffordanceView" + )!! + + val mRightAffordanceView: ImageView = + ObjectUtils.getObjectOrNullAs( + param.thisObject, + "mRightAffordanceView" + )!! + + val keyguardBottomAreaView: View = param.thisObject as View + // Your blur logic + val context = keyguardBottomAreaView.context + val keyguardManager = + context.getSystemService(Context.KEYGUARD_SERVICE) as KeyguardManager + + if (keyguardManager.isKeyguardLocked) { + mLeftAffordanceView.background = if (!removeLeft) { + setOldBackgroundBlur(keyguardBottomAreaView) + } else null + mRightAffordanceView.background = if (!removeRight) { + setOldBackgroundBlur(keyguardBottomAreaView) + } else null + } else { + mLeftAffordanceView.background = null + mRightAffordanceView.background = null } - }*/ + } } + + /*private fun miuiBlur(param: XC_MethodHook.MethodHookParam) { + + }*/ } diff --git a/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveCamera.kt b/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveCamera.kt index 0be0be9c1c..d265d7bd04 100644 --- a/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveCamera.kt +++ b/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveCamera.kt @@ -1,6 +1,6 @@ /* * This file is part of HyperCeiler. - + * HyperCeiler is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the @@ -22,25 +22,53 @@ import android.view.View import android.widget.LinearLayout import com.github.kyuubiran.ezxhelper.ClassUtils.loadClass import com.github.kyuubiran.ezxhelper.HookFactory.`-Static`.createHook +import com.github.kyuubiran.ezxhelper.HookFactory.`-Static`.createHooks import com.github.kyuubiran.ezxhelper.finders.MethodFinder.`-Static`.methodFinder import com.sevtinge.hyperceiler.module.base.BaseHook import com.sevtinge.hyperceiler.utils.devicesdk.isAndroidVersion +import com.sevtinge.hyperceiler.utils.devicesdk.isMiuiVersion import com.sevtinge.hyperceiler.utils.devicesdk.isMoreHyperOSVersion import com.sevtinge.hyperceiler.utils.getObjectField object RemoveCamera : BaseHook() { + private val oldClass by lazy { + loadClass("com.android.systemui.statusbar.phone.KeyguardBottomAreaView") + } + private val newClass by lazy { + loadClass("com.android.keyguard.injector.KeyguardBottomAreaInjector") + } + override fun init() { // 屏蔽右下角组件显示 - loadClass( - if (isAndroidVersion(34) && !isMoreHyperOSVersion(1f)) - "com.android.keyguard.injector.KeyguardBottomAreaInjector" - else - "com.android.systemui.statusbar.phone.KeyguardBottomAreaView").methodFinder().first { - name == "onFinishInflate" - }.createHook { - after { - (it.thisObject.getObjectField("mRightAffordanceViewLayout") as LinearLayout).visibility = - View.GONE + if (isMoreHyperOSVersion(1f)) { + newClass.methodFinder().filter { + name in setOf( + "updateRightAffordanceViewLayoutVisibility", + "startButtonLayoutAnimate" + ) + }.toList().createHooks { + after { + val right = it.thisObject.getObjectField("mRightAffordanceViewLayout") as LinearLayout + right.visibility = View.GONE + } + } + } else if (isMiuiVersion(14f) && isAndroidVersion(34)) { + newClass.methodFinder().first() { + name == "onFinishInflate" + }.createHook { + after { + val right = it.thisObject.getObjectField("mRightAffordanceViewLayout") as LinearLayout + right.visibility = View.GONE + } + } + } else { + oldClass.methodFinder().first { + name == "onFinishInflate" + }.createHook { + after { + (it.thisObject.getObjectField("mRightAffordanceViewLayout") as LinearLayout).visibility = + View.GONE + } } } @@ -59,6 +87,5 @@ object RemoveCamera : BaseHook() { it.result = null } } - } } diff --git a/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveSmartScreen.kt b/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveSmartScreen.kt index 8966addc51..f58cef93e2 100644 --- a/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveSmartScreen.kt +++ b/app/src/main/java/com/sevtinge/hyperceiler/module/hook/systemui/lockscreen/RemoveSmartScreen.kt @@ -1,6 +1,6 @@ /* * This file is part of HyperCeiler. - + * HyperCeiler is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the @@ -18,18 +18,35 @@ */ package com.sevtinge.hyperceiler.module.hook.systemui.lockscreen +import android.view.View +import android.widget.LinearLayout import com.github.kyuubiran.ezxhelper.ClassUtils.loadClass import com.github.kyuubiran.ezxhelper.HookFactory.`-Static`.createHook import com.github.kyuubiran.ezxhelper.finders.MethodFinder.`-Static`.methodFinder import com.sevtinge.hyperceiler.module.base.BaseHook +import com.sevtinge.hyperceiler.utils.devicesdk.isMoreHyperOSVersion +import com.sevtinge.hyperceiler.utils.getObjectField object RemoveSmartScreen : BaseHook() { override fun init() { - loadClass("com.android.keyguard.negative.MiuiKeyguardMoveLeftViewContainer").methodFinder().first { - name == "inflateLeftView" - }.createHook { - before { - it.result = null + if (isMoreHyperOSVersion(1f)) { + loadClass("com.android.keyguard.injector.KeyguardBottomAreaInjector").methodFinder() + .first { + name == "updateIcons" + }.createHook { + after { + (it.thisObject.getObjectField("mLeftAffordanceViewLayout") as LinearLayout).visibility = + View.GONE + } + } + } else { + loadClass("com.android.keyguard.negative.MiuiKeyguardMoveLeftViewContainer").methodFinder() + .first { + name == "inflateLeftView" + }.createHook { + before { + it.result = null + } } } }