Время простоя приложения

В моем приложении есть три действия A -> B -> C -> A. Я хочу определить время простоя приложения, так что через 15 минут оно выведет сообщение независимо от активности. Что является лучшим методом для реализации этого.

Solutions Collecting From Web of "Время простоя приложения"

Я бы сделал это так:

  1. Создайте поток, который будет управлять незанятой активностью
  2. Запустить этот поток в среде приложения
  3. При каждом взаимодействии пользователя просто обновлять время простоя

Класс для хранения глобального потока, который будет управлять временем простоя

public class ControlApplication extends Application { private static final String TAG=ControlApplication.class.getName(); private Waiter waiter; //Thread which controls idle time // only lazy initializations here! @Override public void onCreate() { super.onCreate(); Log.d(TAG, "Starting application"+this.toString()); waiter=new Waiter(15*60*1000); //15 mins waiter.start(); } public void touch() { waiter.touch(); } } 

Класс, который будет родителем для всех ваших действий

 public class ControlActivity extends Activity { private static final String TAG=ControlActivity.class.getName(); /** * Gets reference to global Application * @return must always be type of ControlApplication! See AndroidManifest.xml */ public ControlApplication getApp() { return (ControlApplication )this.getApplication(); } @Override public void onUserInteraction() { super.onUserInteraction(); getApp().touch(); Log.d(TAG, "User interaction to "+this.toString()); } } 

И, наконец, сама тема

 public class Waiter extends Thread { private static final String TAG=Waiter.class.getName(); private long lastUsed; private long period; private boolean stop; public Waiter(long period) { this.period=period; stop=false; } public void run() { long idle=0; this.touch(); do { idle=System.currentTimeMillis()-lastUsed; Log.d(TAG, "Application is idle for "+idle +" ms"); try { Thread.sleep(5000); //check every 5 seconds } catch (InterruptedException e) { Log.d(TAG, "Waiter interrupted!"); } if(idle > period) { idle=0; //do something here - eg call popup or so } } while(!stop); Log.d(TAG, "Finishing Waiter thread"); } public synchronized void touch() { lastUsed=System.currentTimeMillis(); } public synchronized void forceInterrupt() { this.interrupt(); } //soft stopping of thread public synchronized void stop() { stop=true; } public synchronized void setPeriod(long period) { this.period=period; } } в public class Waiter extends Thread { private static final String TAG=Waiter.class.getName(); private long lastUsed; private long period; private boolean stop; public Waiter(long period) { this.period=period; stop=false; } public void run() { long idle=0; this.touch(); do { idle=System.currentTimeMillis()-lastUsed; Log.d(TAG, "Application is idle for "+idle +" ms"); try { Thread.sleep(5000); //check every 5 seconds } catch (InterruptedException e) { Log.d(TAG, "Waiter interrupted!"); } if(idle > period) { idle=0; //do something here - eg call popup or so } } while(!stop); Log.d(TAG, "Finishing Waiter thread"); } public synchronized void touch() { lastUsed=System.currentTimeMillis(); } public synchronized void forceInterrupt() { this.interrupt(); } //soft stopping of thread public synchronized void stop() { stop=true; } public synchronized void setPeriod(long period) { this.period=period; } } 

Поэтому я лично использовал AlarmService. Вы можете указать PendingIntent, который запустит операцию, которая отобразит диалог. После любого события, которое должно перезапустить таймер, вы просто отмените pendingIntent и перерегистрируете его.