以编程方式启用AOSP Build上的禁用系统UI

ale*_*slg 3 android android-source kiosk-mode android-4.4-kitkat

我已经使用Android 4.4.4源构建了我的AOSP自定义ROM.我想做一个自助服务终端模式应用程序(总是全屏 - 用户不可能离开它或切换到另一个应用程序).

为了拥有一个完整的沉浸式模式,我跟着这个SO帖子在Android 4.4.2中使用Root启用了KioskMode

我完全按照他们的说法完成,但它不起作用.系统UI未禁用,我没有错误.

所以我决定创建一个从Android SDK代码运行的.sh文件:

Process proc = Runtime.getRuntime().exec(new String[] { "su", "-c", "/etc/stop-ui.sh" });

它完美地运作.但是当我想再次启动系统UI时: Process proc = Runtime.getRuntime().exec(new String[] { "su", "-c", "/etc/start-ui.sh" }); 它返回错误1.

当我从adb shell运行/etc/start-ui.sh时,它可以工作.

这是我的stop.sh(有权限555)文件:

#!/system/bin/sh
service call activity 42 s16 com.android.systemui
Run Code Online (Sandbox Code Playgroud)

这是我的start.sh(有权限555)文件:

#!/system/bin/sh
am startservice -n com.android.systemui/.SystemUIService
Run Code Online (Sandbox Code Playgroud)

我的应用程序是一个系统应用程序(我用平台签名签名)

结论:我可以从shell重启系统UI,但不能以编程方式从app重启

Vea*_*rji 5

我有这两种方法(在root手机上),他们完美地工作:

public static void hideSystemUi(){
    try {
        Build.VERSION_CODES vc = new Build.VERSION_CODES();
        Build.VERSION vr = new Build.VERSION();
        String ProcID = "79"; //HONEYCOMB AND OLDER

        //v.RELEASE  //4.0.3
        if(vr.SDK_INT >= vc.ICE_CREAM_SANDWICH){
            ProcID = "42"; //ICS AND NEWER
        }
        Process proc = Runtime.getRuntime().exec(new String[]{
                "su","-c","service call activity " + ProcID + " s16 com.android.systemui"});

        proc.waitFor();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

public static void showSystemUi(){
    try {
        Process proc = Runtime.getRuntime().exec("am startservice --user 0 -n com.android.systemui/.SystemUIService");
        proc.waitFor();
    } catch (Exception e) {
        e.printStackTrace();
    }
}
Run Code Online (Sandbox Code Playgroud)

尝试在am startservice -n com.android.systemui/.SystemUIService命令中传递用户ID .就我而言,它是0(root用户ID).