rk3399 Android7.1 预置app

首先进入如下目录,打开如下文件

root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/device/rockchip/common# vim device.mk 
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/device/rockchip/common# 

看到如下代码段

# Prebuild apps
ifneq ($(strip $(TARGET_PRODUCT)), )
    TARGET_DEVICE_DIR=$(shell test -d device && find device -maxdepth 4 -path '*/$(TARGET_PRODUCT)/BoardConfig.mk')
    TARGET_DEVICE_DIR := $(patsubst %/,%,$(dir $(TARGET_DEVICE_DIR)))
    $(info device-rockchip-common TARGET_DEVICE_DIR: $(TARGET_DEVICE_DIR))//此打印语句是我添加上的,目的在于确认TARGET_DEVICE_DIR
    $(shell python $(LOCAL_PATH)/auto_generator.py $(TARGET_DEVICE_DIR) preinstall bundled_persist-app)
    $(shell python $(LOCAL_PATH)/auto_generator.py $(TARGET_DEVICE_DIR) preinstall_del bundled_uninstall_back-app)
    $(shell python $(LOCAL_PATH)/auto_generator.py $(TARGET_DEVICE_DIR) preinstall_del_forever bundled_uninstall_gone-app)
    -include $(TARGET_DEVICE_DIR)/preinstall/preinstall.mk
    -include $(TARGET_DEVICE_DIR)/preinstall_del/preinstall.mk
    -include $(TARGET_DEVICE_DIR)/preinstall_del_forever/preinstall.mk
endif

auto_generator.py用于生成Android.mk 、preinstall.mk

两个文件生成后的内容就不说了,因为这些都是类似于内核驱动里边的makefile文件一样,三个文件夹(preinstall、preinstall_del、preinstall_del_forever)下生成的文件内容都是不一样的,具体的自己去观察吧

$(info device-rockchip-common TARGET_DEVICE_DIR: $(TARGET_DEVICE_DIR))//此打印语句是我添加上的,目的在于确认TARGET_DEVICE_DIR   先声明一点,每个开发板这个目录可能都不一样,所以最好自己确认,比如有的公司自己拿去改了源码,改了统一的东西为自己的

打印结果如下(说明一下,这是在编译Android系统,不同的开发板有不同编译方式,按着自己的来)

root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup# ./mk.sh -s -j=4
'/3399_backup/g3399-v7-1-2-20180529_backup/device/rockchip/rk3399/g3399/parameter.txt' -> '/3399_backup/g3399-v7-1-2-20180529_backup/out/release/parameter.txt'
'/3399_backup/g3399-v7-1-2-20180529_backup/device/rockchip/rk3399/g3399/misc.img' -> '/3399_backup/g3399-v7-1-2-20180529_backup/out/release/misc.img'
'/3399_backup/g3399-v7-1-2-20180529_backup/device/rockchip/rk3399/g3399/upgrade_tool' -> '/3399_backup/g3399-v7-1-2-20180529_backup/out/release/upgrade_tool'
including device/asus/fugu/vendorsetup.sh
including device/generic/mini-emulator-arm64/vendorsetup.sh
including device/generic/mini-emulator-armv7-a-neon/vendorsetup.sh
including device/generic/mini-emulator-mips/vendorsetup.sh
including device/generic/mini-emulator-mips64/vendorsetup.sh
including device/generic/mini-emulator-x86/vendorsetup.sh
including device/generic/mini-emulator-x86_64/vendorsetup.sh
including device/google/dragon/vendorsetup.sh
including device/google/marlin/vendorsetup.sh
including device/htc/flounder/vendorsetup.sh
including device/huawei/angler/vendorsetup.sh
including device/lge/bullhead/vendorsetup.sh
including device/linaro/hikey/vendorsetup.sh
including device/moto/shamu/vendorsetup.sh
including device/rockchip/rk3399/vendorsetup.sh
including sdk/bash_completion/adb.bash


//就是这句话
device-rockchip-common TARGET_DEVICE_DIR: device/rockchip/rk3399/g3399




============================================
PLATFORM_VERSION_CODENAME=REL
PLATFORM_VERSION=7.1.2
TARGET_PRODUCT=g3399
TARGET_BUILD_VARIANT=userdebug
TARGET_BUILD_TYPE=release
TARGET_BUILD_APPS=
TARGET_ARCH=arm64
TARGET_ARCH_VARIANT=armv8-a
TARGET_CPU_VARIANT=cortex-a53
TARGET_2ND_ARCH=arm
TARGET_2ND_ARCH_VARIANT=armv7-a-neon
TARGET_2ND_CPU_VARIANT=cortex-a53.a57
HOST_ARCH=x86_64
HOST_2ND_ARCH=x86

    -include $(TARGET_DEVICE_DIR)/preinstall/preinstall.mk
    -include $(TARGET_DEVICE_DIR)/preinstall_del/preinstall.mk
    -include $(TARGET_DEVICE_DIR)/preinstall_del_forever/preinstall.mk

上面三句话就是根据文件夹下边的.mk文件去预置app

所以,理论上,我们应该将apk文件放入到源码目录这个路径下device/rockchip/rk3399/g3399的preinstall(系统的不可卸载的)    、   preinstall_del(系统的可卸载的,恢复出厂设置可恢复的)   、  preinstall_del_forever(非系统的可卸载的,恢复出厂设置不可恢复的)这三个文件夹下边,然后重新编译整个系统烧写就ok了,此时可能会报错,不知道原因是什么(报错的情况下,将preinstall等文件夹删除后重新编译也是可以的,其实你可以去out/target/product/g3399/system/vendor/这个文件下边看,如果有bundled_persist-app/这个文件夹生成,且文件夹里边有你预置的app,那么删除preinstall等文件夹重新编译烧写系统也是可行的,虽然我不知道原因在哪,有可能是第三方的公司修改东西没改完全或者还有一些其他需要我们注意的地方吧),但是执行make clean后编译,就可编译成功,如果预置成功,则在device/rockchip/rk3399/g3399的你之前放入的文件夹下边会生成Android.mk 和app名字命名的文件夹,以及preinstall.mk;另外一种查看方式是在源码目录下的

root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor# pwd
/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor# ls
bin  bundled_persist-app  etc  lib  lib64
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor# 

上边新生成的bundled_persist-app就是预置的app,如下

root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor# cd bundled_persist-app/
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor/bundled_persist-app# ls
baidushurufa_194  InfrareEye1.0
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor/bundled_persist-app# cd baidushurufa_194/
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor/bundled_persist-app/baidushurufa_194# ls
baidushurufa_194.apk  lib  oat
root@ubuntu:/3399_backup/g3399-v7-1-2-20180529_backup/out/target/product/g3399/system/vendor/bundled_persist-app/baidushurufa_194# 

网上还有一种牛掰的操作,就是在vendor目录下建立对应的文件夹,将app放进去,这种方式经过测试,对于系统的不可卸载的是行不通的,对于不需要.so的方式是可以的,你可以尝试一下将app放入preinstall下边编译(系统的不可卸载的),如上我预置的百度输入法,它在以自己命名的文件下边除了apk文件,还有lib文件夹的oat这些东西肯定都是必须的,对于系统的不可卸载的方式去预置app来说 

这样重新烧写系统就能看到预置的app了

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 可以使用以下方法重启 Android 系统: 1. 使用 `System.exit(0)` 方法终止应用程序进程。 2. 使用 `android.os.Process.killProcess(android.os.Process.myPid())` 方法杀死应用程序进程。 3. 使用 `PowerManager` 类的 `reboot()` 方法重启设备。 需要注意的是,第 3 种方法只能在系统级别使用,需要在应用程序中声明 `REBOOT` 权限。 例如: ``` PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); pm.reboot(null); ``` 调用 `reboot()` 方法时,可以传入一个字符串参数,表示重启的原因。 ### 回答2: 要使用代码在RK3399 Android 7.1中重启系统,您可以使用以下方法: 1. 使用Runtime类: 您可以使用Runtime类中的exec()方法来执行shell命令。可以执行"reboot"命令来重启系统。以下是一个示例代码片段: ``` try { Runtime.getRuntime().exec("reboot"); } catch (IOException e) { e.printStackTrace(); } ``` 2. 使用PowerManager类: 您可以使用PowerManager类中的reboot()方法来实现重启系统的功能。以下是一个示例代码片段: ``` PowerManager powerManager = (PowerManager) getSystemService(Context.POWER_SERVICE); if (powerManager != null) { powerManager.reboot(null); } ``` 请注意,为了使用PowerManager类,您需要在AndroidManifest.xml文件中添加相应的权限:<uses-permission android:name="android.permission.REBOOT" /> 3. 使用DevicePolicyManager类: 如果您的应用程序是设备管理员应用程序,您可以使用DevicePolicyManager类中的reboot()方法来实现重启系统的功能。以下是一个示例代码片段: ``` DevicePolicyManager devicePolicyManager = (DevicePolicyManager) getSystemService(Context.DEVICE_POLICY_SERVICE); ComponentName adminComponentName = new ComponentName(this, AdminReceiver.class); // AdminReceiver是自定义的广播接收器类,用于处理设备管理员相关的操作 devicePolicyManager.reboot(adminComponentName); ``` 需要注意的是,如果您的应用程序不是设备管理员应用程序,您需要先设置您的应用程序为设备管理员,才能使用DevicePolicyManager类。 这些是在RK3399 Android 7.1中使用代码重启系统的几种方法。您可以根据您的需求选择适合您的方法。 ### 回答3: 使用RK3399开发板上的Android 7.1系统,我们可以通过编写代码来实现系统的重启。 在Android中,系统重启可以通过调用系统服务的方法来实现。首先,我们需要获取系统服务的一个实例,然后调用相应的方法来实现重启。 具体步骤如下: 1. 获取系统服务的实例。我们可以通过调用`Context.getSystemService()`方法来获取系统服务的实例。在这个例子中,我们可以获取`Context.POWER_SERVICE`服务的实例,该服务用于控制设备的电源。 ```java PowerManager powerManager = (PowerManager) getSystemService(Context.POWER_SERVICE); ``` 2. 通过系统服务实例调用重启方法。获取到`PowerManager`的实例后,我们可以调用`reboot()`方法来实现系统重启。 ```java powerManager.reboot(null); ``` 在这个例子中,`reboot()`方法接受一个字符串参数,用于传递重启的原因。我们传递`null`作为参数,表示没有特定的重启原因。 3. 添加权限。为了调用系统服务,我们需要在AndroidManifest.xml文件中添加适当的权限。在这种情况下,我们需要添加`REBOOT`权限。 ```xml <uses-permission android:name="android.permission.REBOOT" /> ``` 通过编写上述代码,我们可以在RK3399上的Android 7.1系统中实现系统的重启。请注意,系统重启将导致设备重新启动,并且会中断正在运行的任何应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值