दिलचस्प पोस्ट
INSTALL_PARSE_FAILED_NO_CERTIFICATES त्रुटि क्या है? सी ++ में नेस्टेड कक्षाओं का उपयोग क्यों किया जाएगा? जेनेरिक में सी # का इस्तेमाल करते हुए मठ पुस्तकालय का निर्माण अगर मैं एक मौजूदा वितरण प्रमाण पत्र रद्द कर देता हूं, तो क्या यह मौजूदा ऐप्स के साथ कुछ गड़बड़ कर देगा? पायथन REST (वेब ​​सेवा) ढांचे की सिफारिशें? 64-बिट विंडोज पर सेट अप टूल्स स्थापित करना फ्लास्क / जिन्जा 2 का उपयोग करके टेम्पलेट को HTML पास करना फ़ायरफ़ॉक्स समर्थन की स्थिति है: टेबल तत्वों पर रिश्तेदार? सी ++: "std :: endl" बनाम "\ n" रेलवे और पोस्टग्रेएसक्यूएल में पूरी तरह समय-समय पर ध्यान न दें अजगर शब्दकोश के तत्वों तक पहुंच ड्रॉपडाउन सूची में ऑप्ट-ग्रुप के लिए सहायता .नेट एमवीसी? मैं बैच के बैच के लिए एक्सटेंशन का नाम कैसे बदलूं? इनपुट प्रकार = फाइल केवल बटन दिखाएँ आप C ++ में एक स्थिर वर्ग कैसे बना सकते हैं?

एप्लिकेशन निष्क्रिय समय

मेरे आवेदन में तीन गतिविधियों ए -> बी -> सी -> ए है। मैं आवेदन के निष्क्रिय समय का पता लगाना चाहता हूं, ताकि 15 मिनट बाद यह गतिविधि के बावजूद एक संदेश पॉप अप कर दे। इस को लागू करने के लिए सबसे अच्छा तरीका क्या है

वेब के समाधान से एकत्रित समाधान "एप्लिकेशन निष्क्रिय समय"

मैं इसे इस तरह से कर रहा होगा:

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

इसलिए मैं व्यक्तिगत रूप से अलार्मसेवा का उपयोग करूँगा आप एक लंबित पहचान निर्दिष्ट कर सकते हैं जो किसी गतिविधि को प्रारंभ करेगा जो एक संवाद प्रदर्शित करता है। किसी भी घटना के बाद जो टाइमर को पुनरारंभ करना चाहिए आप केवल लंबित सूचना को रद्द कर देते हैं और इसे पुन: पंजीकृत करें