启用在AOSP上禁用系统UI以编程方式构建

启用在AOSP上禁用系统UI以编程方式构建

问题描述:

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

为了有一个完整的沉浸式模式,我跟着这个SO发布Enabling KioskMode in Android 4.4.2 with Root

我DIT正是因为他们说,但它不工作。系统用户界面没有被禁用,我没有错误。

所以我决定创建一个我从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.

当我运行从它的工作原理亚行外壳/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,但不能通过程序从应用程序启动

我有这个2种方法(上根植电话)和他们的工作完美:

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(); 
    } 
} 

尝试通过用户ID am startservice -n com.android.systemui/.SystemUIService命令。在我的情况下,它是0(root用户ID)。

+0

哇感谢它的工作原理与添加'--user 0'。这很奇怪。没有它,为什么不工作?在许多其他SO帖子的人没有'--user 0'选项,它的工作原理。谢谢,顺便说一下,你帮了我很多。 – alexislg

+0

第一种方法的工作原理,但第二次却没有。这是不容易返回'systemUI'甚至手动:( –

+0

如果我运行 服务呼叫活动42 S16 com.android.systemui的systemUi消失,而且设备犯规采取任何输入了。上午startservice -n com.android.systemui /.SystemUIService – maggocnx