Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Application idle time

Tags:

In my application there are three activities A -> B -> C -> A. I want to detect application's idle time, so that after 15 mins it will pop up a message irrespective of activity. what is the best method to implement this.

like image 513
Harikrishnan R Avatar asked Nov 02 '10 05:11

Harikrishnan R


People also ask

What is App idle?

IDLE is Python's Integrated Development and Learning Environment. IDLE has the following features: coded in 100% pure Python, using the tkinter GUI toolkit. cross-platform: works mostly the same on Windows, Unix, and macOS.

What is idle timer?

Idle time is paid time that an employee, or machine, is unproductive due to factors that can either be controlled or uncontrolled by management. It normally applies to full-time workers rather than consultants, who typically have to bill for every hour of their time.

How is idle time calculated C#?

You can use user32. dll and LASTINPUTINFO[^] to calculate the system ideal time.


3 Answers

I would be doing it in this way:

  1. Create thread which will control idle activity
  2. Run this thread in Application environment
  3. At each user interaction just refresh idle time

Class for storing global Thread which will control idle time

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

Class which will be parent for all of your activities

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

And finally Thread itself

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 - e.g. 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;     }  } 
like image 185
Barmaley Avatar answered Oct 29 '22 08:10

Barmaley


So I would personally use the AlarmService. You can specify a PendingIntent that will start an activity which displays a dialog. After any event which should restart the timer you just cancel the pendingIntent and reregister it.

like image 32
Greg Giacovelli Avatar answered Oct 29 '22 10:10

Greg Giacovelli


I think CountDownTimer is the best way to do this.

    public class IdleCountDownTimer extends CountDownTimer {
        public IdleCountDownTimer(long startTime, long interval) {
            super(startTime, interval);
        }

        @Override
        public void onFinish() {
            //Time lapsed 
           Toast.makeText(getApplicationContext(),"The text you want to display",Toast.LENGTH_LONG)

        }

        @Override
        public void onTick(long millisUntilFinished) {
        }
    } 

Now declare the global object

IdleCountDownTimer idleCountDownTimer;

Now initialize and start the count down.

@Override
public void onCreate()
{
    super.onCreate();
    idleCountDownTimer = new IdleCountDownTimer(seconds * 60 * 1000, interval_in_seconds * 60 * 1000);
    idleCountDownTimer.start();
}

Now call cancel and start when you want to reset the count down.

Eg 1 : for all key, touch, or trackball events

@Override
public void onUserInteraction(){
    super.onUserInteraction();

    //Reset the count down
    idleCountDownTimer.cancel();             
    idleCountDownTimer.start();
}

Eg 2 : For Touch events only

@Override
public boolean onTouchEvent(MotionEvent event) {
        //Reset the count down
        idleCountDownTimer.cancel();             
        idleCountDownTimer.start();

        // Let the event flow
        return false;
}
like image 43
Nalin Avatar answered Oct 29 '22 08:10

Nalin