提示:这里解决两个问题:
- 内置第三方应用-但是应用是32位的
- 解决:此应用与最新版 Android 不兼容。请检查是否有更新,或与应用开发者联系 弹框问题
前言
在RK-Android15版本,或者 Android9以上版本,内置32位应用程序;解决旧版本弹框提醒问题
一、 需求-场景
-
需求:内置一个应用到系统里面,内置应用可卸载、恢复出厂设置后仍存在
-
场景:Android15、RK3576 平台上面内置
-
难点:Android15平台,这里是RK3576 为例,本身默认支持的都是 64位应用,假使应用软件比较老,只有32位的
.so文件,如:armeabi-v7a库文件。 -
问题一:如下,集成一个32位的应用,apk 内部只有
armeabi-v7a库文件。

-
问题二:及时内置成功,或者 手动安装成功,一定会报错,如下

-
所以实现需求:就是集成一个应用,但是这个应用没有64位的库,只有32位库。那么在默认64位机器上面去内置一个32位库程序App,同时解决弹框提醒。
二、涉及到修改文件
\device\rockchip\rk3576\device.mk # 在当前需求用于定义一个属性,新增属性
\device\rockchip\rk3576\rk3576_u\preinstall_del # 内置应用
三、参考资料
Rk-内置应用作为系统Launcher-内置APK-拷贝文件-替换开机动画 这是之前的一个知识点总结:也是相同的平台RK3576,相同版本Android15 里面有内置应用和添加属性相关内容的阐述,强烈建议查看。
RK-Android11-系统增加一个属性值 这里是RKAndroid11 版本添加属性方法,可以借鉴。
Android 9.0以上,系统弹出应用版本过低提示窗
完整教程:2025-09-08升级问题记录:app提示“此应用专为旧版Android打造…”或“此应用与最新版 Android 不兼容”
四、实现方案
1、内置第三方应用在可卸载区域-内置32位库文件
路径:\device\rockchip\rk3576\rk3576_u\preinstall_del,可参考:Rk-内置应用作为系统Launcher-内置APK-拷贝文件-替换开机动画

基本结构



配置文件-Android.mk
LOCAL_PATH := $(my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := tangdoutv
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_PATH := $(TARGET_OUT_ODM)/bundled_uninstall_back-app
LOCAL_SRC_FILES := $(LOCAL_MODULE)$(COMMON_ANDROID_PACKAGE_SUFFIX)
LOCAL_CERTIFICATE := PRESIGNED
LOCAL_DEX_PREOPT := false
LOCAL_DONT_CHECK_MODULE := true
LOCAL_ENFORCE_USES_LIBRARIES := false
LOCAL_MODULE_TAGS := optional
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
LOCAL_MULTILIB := 32
#LOCAL_JNI_SHARED_LIBRARIES_ABI := arm32
LOCAL_PREBUILT_JNI_LIBS := \
lib/armeabi-v7a/libcrashsdk.so\
lib/armeabi-v7a/libijkffmpeg.so\
lib/armeabi-v7a/libijkplayer.so\
lib/armeabi-v7a/libijksdl.so\
lib/armeabi-v7a/libpl_droidsonroids_gif.so\
lib/armeabi-v7a/libpl_droidsonroids_gif_surface.so\
lib/armeabi-v7a/librsjni.so\
lib/armeabi-v7a/librsjni_androidx.so\
lib/armeabi-v7a/libRSSupport.so\
lib/armeabi-v7a/libsdk.so\
lib/armeabi-v7a/libumeng-spy.so\
include $(BUILD_PREBUILT)
这里有一个核心的配置和具体指定每一个库文件 .so 路径:
LOCAL_MULTILIB := 32
LOCAL_PREBUILT_JNI_LIBS := \
lib/armeabi-v7a/libcrashsdk.so\
lib/armeabi-v7a/libijkffmpeg.so\
lib/armeabi-v7a/libijkplayer.so\
lib/armeabi-v7a/libijksdl.so\
lib/armeabi-v7a/libpl_droidsonroids_gif.so\
lib/armeabi-v7a/libpl_droidsonroids_gif_surface.so\
lib/armeabi-v7a/librsjni.so\
lib/armeabi-v7a/librsjni_androidx.so\
lib/armeabi-v7a/libRSSupport.so\
lib/armeabi-v7a/libsdk.so\
lib/armeabi-v7a/libumeng-spy.so\
存放32位库文件
如上已描述:

坑点
这里还是特别强调一下,遇到的坑。 互联网资料、其他人参考经验那是别人的,实践才是自己的,AI工具生成一大推答案、Google 搜索也有答案,那是别人的,还是需要自己实践 总结 自己学会配置。
强调:这里绝不是一个简单内置应用的需求这么简单,会遇到各种坑,各种不成功,各种错误,需要不断实践、总结、提炼、尝试才行,最后总结、沉淀。 这里列举遇到的几个错误,仅提供少许错误,供参考:



2、取消旧版本体系弹框
修改源码:\device\rockchip\rk3576\device.mk
添加一个属性如下: 相关参考资料可参考:
Rk-内置应用作为系统Launcher-内置APK-拷贝文件-替换开机动画

就是添加一个属性:debug.wm.disable_deprecated_abi_dialog=true 如下,

五、源码分析
对于内置应用、内置集成32位库文件,这个是经验加实践,不同Android版本、不同主控平台权限不一样,特殊语法、不分语法可能不一样,具体实现、实践即可,吃经验。
这里主要分析 屏蔽 旧版本提醒问题:
屏蔽-旧版本提醒问题
思路
- 思路一:找关联的布局UI, 凡是遇到提醒的弹框,首先
dumpsys activity top | grep ACTIVITY查看堆栈,如果找不到,继续dumpsys activity top - 思路二:系统相关的弹框,自己经验在三个应用里面可能性极大:
SystemUI / Framework层 / Settings里面
根据思路二-查找源码
找配置文件 values.xml
这里自己在Fraework 里面首先去查看,查找,路径 找到中文的文件夹 去查看:路径:/frameworks/base/core/res/res

通过stringId 找源码-弹框DeprecatedAbiDialog
命令:grep -rn deprecated_abi_message | grep java

通过 弹框DeprecatedAbiDialog 找弹框启动的类AppWarnings

分析源码-AppWarnings -查找弹框弹出逻辑-定位到具体代码

找到具体代码,如下:
/**
* Shows the "deprecated abi" warning, if necessary. This can only happen is the device
* supports both 64-bit and 32-bit ABIs, and the app only contains 32-bit libraries. The app
* cannot be installed if the device only supports 64-bit ABI while the app contains only 32-bit
* libraries.
*
* @param r activity record for which the warning may be displayed
*/
public void showDeprecatedAbiDialogIfNeeded(ActivityRecord r) {
final boolean isUsingAbiOverride = (r.info.applicationInfo.privateFlagsExt
& ApplicationInfo.PRIVATE_FLAG_EXT_CPU_OVERRIDE) != 0;
if (isUsingAbiOverride) {
// The abiOverride flag was specified during installation, which means that if the app
// is currently running in 32-bit mode, it is intended. Do not show the warning dialog.
return;
}
// The warning dialog can also be disabled for debugging purpose
final boolean disableDeprecatedAbiDialog = SystemProperties.getBoolean(
"debug.wm.disable_deprecated_abi_dialog", false);
if (disableDeprecatedAbiDialog) {
return;
}
final String appPrimaryAbi = r.info.applicationInfo.primaryCpuAbi;
final String appSecondaryAbi = r.info.applicationInfo.secondaryCpuAbi;
final boolean appContainsOnly32bitLibraries =
(appPrimaryAbi != null && appSecondaryAbi == null && !appPrimaryAbi.contains("64"));
final boolean is64BitDevice =
ArrayUtils.find(Build.SUPPORTED_ABIS, abi -> abi.contains("64")) != null;
if (is64BitDevice && appContainsOnly32bitLibraries) {
mUiHandler.showDeprecatedAbiDialog(r);
}
}

属性分析-debug.wm.disable_deprecated_abi_dialog
那就直接看系统属性默认值,如下:系统并没有这个属性,那就定义属性并赋值true 即可。
所以,我们定义一个属性,并赋值就屏蔽了所有的 App 旧版本弹框提醒,如果需要 针对某一个 包名app, 再分析一下代码,拦截即可。

避坑指南与总结
- 这里设计到两种需求:其中内置应用,内置32位到机器本身支持64 位中的需求比较 麻烦,多实践。
- 对于 弹框提醒的需求,去掉提醒:掌握基本的解决问题思路并通过搜索、通过经验、实践 来实现需求,多了解、查阅源码。
2028

被折叠的 条评论
为什么被折叠?



