如何在任何活动中禁用虚拟主页按钮?

时间:2016-01-21 08:45:18

标签: android virtual android-homebutton

我需要在我的应用中的任何活动中禁用3个虚拟按钮。我以某种方式禁用了后退按钮和多任务按钮,但我无法使用主页按钮。

我在stackoverflow上尝试了onAttachedToWindow()样式答案,但它们对我没用。

我不想为整个应用禁用主页按钮,我只想在单个活动窗口中禁用它。谢谢你的帮助!

2 个答案:

答案 0 :(得分:2)

注意:如果您想要部署它,我强烈建议您不要在应用中执行此操作。这只是为了说明我们如何做到这一点。

由于Android 4没有有效的方法来禁用主页按钮。它需要很少的黑客攻击。我认为您的需求是应用程序中的KIOSK模式。通常,我们的想法是检测新应用程序何时处于前台并立即重新启动Activity。流程在下面..

首先创建一个名为KioskService的类,其扩展Service并添加以下代码段:

 public class KioskService extends Service {

  private static final long INTERVAL = TimeUnit.SECONDS.toMillis(2); // periodic interval to check in seconds -> 2 seconds
  private static final String TAG = KioskService.class.getSimpleName();
  private static final String PREF_KIOSK_MODE = "pref_kiosk_mode";

  private Thread t = null;
  private Context ctx = null;
  private boolean running = false;

  @Override
  public void onDestroy() {
    Log.i(TAG, "Stopping service 'KioskService'");
    running =false;
    super.onDestroy();
  }

  @Override
  public int onStartCommand(Intent intent, int flags, int startId) {
    Log.i(TAG, "Starting service 'KioskService'");
    running = true;
    ctx = this;

    // start a thread that periodically checks if your app is in the foreground
    t = new Thread(new Runnable() {
      @Override
      public void run() {
        do {
          handleKioskMode();
          try {
            Thread.sleep(INTERVAL);
          } catch (InterruptedException e) {
            Log.i(TAG, "Thread interrupted: 'KioskService'");
          }
        }while(running);
        stopSelf();
      }
    });

    t.start();
    return Service.START_NOT_STICKY;
  }

  private void handleKioskMode() {
    // is Kiosk Mode active? 
      if(isKioskModeActive()) {
        // is App in background?
      if(isInBackground()) {
        restoreApp(); // restore!
      }
    }
  }

  private boolean isInBackground() {
    ActivityManager am = (ActivityManager) ctx.getSystemService(Context.ACTIVITY_SERVICE);

    List<ActivityManager.RunningTaskInfo> taskInfo = am.getRunningTasks(1);
    ComponentName componentInfo = taskInfo.get(0).topActivity;
    return (!ctx.getApplicationContext().getPackageName().equals(componentInfo.getPackageName()));
  }

  private void restoreApp() {
    // Restart activity
    Intent i = new Intent(ctx, MyActivity.class);
    i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    ctx.startActivity(i);
  }

  public boolean isKioskModeActive(final Context context) {
    SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context);
    return sp.getBoolean(PREF_KIOSK_MODE, false);
  }

  @Override
  public IBinder onBind(Intent intent) {
    return null;
  }
}

AppContext类中添加以下方法,以通过创建应用程序上下文来启动service

@Override
public void onCreate() {
  super.onCreate();
  instance = this;
  registerKioskModeScreenOffReceiver();
  startKioskService();  // add this
}

private void startKioskService() { // ... and this method
  startService(new Intent(this, KioskService.class));
}

AppContext课程看起来像这样

  public class AppContext extends Application {

  private AppContext instance;
  private PowerManager.WakeLock wakeLock;
  private OnScreenOffReceiver onScreenOffReceiver;


  @Override
  public void onCreate() {
    super.onCreate();
    instance = this;
    registerKioskModeScreenOffReceiver();
  }

  private void registerKioskModeScreenOffReceiver() {
    // register screen off receiver
    final IntentFilter filter = new IntentFilter(Intent.ACTION_SCREEN_OFF);
    onScreenOffReceiver = new OnScreenOffReceiver();
    registerReceiver(onScreenOffReceiver, filter);
  }

  public PowerManager.WakeLock getWakeLock() {
    if(wakeLock == null) {
      // lazy loading: first call, create wakeLock via PowerManager.
      PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
      wakeLock = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP, "wakeup");
    }
    return wakeLock;
  }
}

将服务声明和检索前台进程的权限添加到清单中:

<service android:name=".KioskService" android:exported="false"/>
<uses-permission android:name="android.permission.GET_TASKS"/>
//Added permission Edit 1
<uses-permission android:name="android.permission.WAKE_LOCK" />

我在一个网站上看到了这一切,但忘记了链接,无论我有什么只是内容和代码,所以我发布所有作为答案。一旦我收到链接,我会与你分享。

答案 1 :(得分:1)

如果我没有错,那么您想要禁用主页按钮,或者您可以说将活动保持在每个活动屏幕的前面。

为此,我建议您使用窗口管理器屏幕启动活动窗口。当您使用窗口管理器开始活动时,您的主页按钮活动将转到后台。这意味着您的活动无法通过按下主页按钮来关闭。

简单地说,将您的活动用作窗口管理器活动。许多锁屏应用也以这种方式工作

对不起代码。我无法发布代码,因为我离开了android编程,现在我正在使用动画,所以你可能需要为此付出艰苦的努力。

但是你可以用窗口管理器活动击败主页按钮和所有其他系统按钮。

我有一个不完整的锁屏应用项目。您必须进行一些更改,并应删除不需要的java类文件和适配器文件。

此外,我在屏幕上开发了81个图像的新锁。两个解锁手机必须设置所选图像。

您可以从here下载我的不完整项目。

我更新链接并了解其作品。