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

时间:2015-12-16 21:20:09

标签: android android-4.4-kitkat android-source kiosk-mode

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

为了拥有完整的沉浸式模式,我遵循了这篇SO Enabling KioskMode in Android 4.4.2 with Root

我完全按照他们的说法完成,但它不起作用。系统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

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

#!/system/bin/sh
am startservice -n com.android.systemui/.SystemUIService

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

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

1 个答案:

答案 0 :(得分: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();
    }
}

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