AlarmManager
ক্লাসের উপর ভিত্তি করে) আপনাকে আপনার আবেদনের জীবনকালের বাইরে সময়-ভিত্তিক ক্রিয়াকলাপ সম্পাদন করার একটি উপায় দেয়। উদাহরণস্বরূপ, আপনি একটি দীর্ঘ-চলমান অপারেশন শুরু করতে একটি অ্যালার্ম ব্যবহার করতে পারেন, যেমন আবহাওয়ার পূর্বাভাস ডাউনলোড করতে দিনে একবার একটি পরিষেবা শুরু করা।অ্যালার্মগুলির এই বৈশিষ্ট্যগুলি রয়েছে:
তারা আপনাকে নির্দিষ্ট সময় এবং/অথবা ব্যবধানে ইন্টেন্টগুলি ফায়ার করতে দেয়।
আপনি এগুলিকে ব্রডকাস্ট রিসিভারের সাথে ব্যবহার করতে পারেন কাজের সময় নির্ধারণের জন্য বা অন্য ক্রিয়াকলাপগুলি সম্পাদনের জন্য কাজের অনুরোধগুলি ।
এগুলি আপনার অ্যাপ্লিকেশনের বাইরে কাজ করে, তাই আপনি ইভেন্ট বা অ্যাকশন ট্রিগার করার জন্য ব্যবহার করতে পারেন এমনকি আপনার অ্যাপটি না চললেও এবং ডিভাইসটি নিজে ঘুমিয়ে থাকলেও৷
তারা আপনাকে আপনার অ্যাপের রিসোর্স প্রয়োজনীয়তা কমাতে সাহায্য করে। আপনি টাইমারের উপর নির্ভর না করে বা ক্রমাগত পরিষেবা চালু না করেই ক্রিয়াকলাপ নির্ধারণ করতে পারেন।
একটি সঠিক অ্যালার্ম সেট করুন
যখন একটি অ্যাপ একটি সঠিক অ্যালার্ম সেট করে, সিস্টেমটি ভবিষ্যতে কোনো সময়ে অ্যালার্ম সরবরাহ করে। অযৌক্তিক অ্যালার্মগুলি অ্যালার্ম বিতরণের সময় সম্পর্কে কিছু গ্যারান্টি প্রদান করে যখন ব্যাটারি-সংরক্ষণের বিধিনিষেধকে সম্মান করে যেমন ডোজ ৷
অযৌক্তিক অ্যালার্ম বিতরণের সময় কাস্টমাইজ করতে বিকাশকারীরা নিম্নলিখিত API গ্যারান্টিগুলি ব্যবহার করতে পারে।
একটি নির্দিষ্ট সময়ের পরে একটি অ্যালার্ম সরবরাহ করুন
যদি আপনার অ্যাপ set()
, setInexactRepeating()
, অথবা setAndAllowWhileIdle()
কল করে, সরবরাহ করা ট্রিগার সময়ের আগে অ্যালার্ম কখনই বন্ধ হয় না।
অ্যান্ড্রয়েড 12 (এপিআই লেভেল 31) এবং উচ্চতর ক্ষেত্রে, সিস্টেম সরবরাহ করা ট্রিগার সময়ের এক ঘন্টার মধ্যে অ্যালার্ম আহ্বান করে, যদি না ব্যাটারি সেভার বা ডোজ- এর মতো ব্যাটারি-সাশ্রয়ী বিধিনিষেধ কার্যকর না হয়।
একটি টাইম উইন্ডোর সময় একটি অ্যালার্ম সরবরাহ করুন
যদি আপনার অ্যাপ setWindow()
কল করে, সরবরাহকৃত ট্রিগার সময়ের আগে অ্যালার্ম কখনই বন্ধ হয় না। কোনো ব্যাটারি-সংরক্ষণ বিধিনিষেধ কার্যকর না হলে, প্রদত্ত ট্রিগার সময় থেকে শুরু করে নির্দিষ্ট সময় উইন্ডোর মধ্যে অ্যালার্ম বিতরণ করা হয়।
যদি আপনার অ্যাপটি Android 12 বা উচ্চতরকে লক্ষ্য করে, তাহলে সিস্টেমটি অন্তত 10 মিনিটের জন্য একটি সময়-উইন্ডোড অযৌক্তিক অ্যালার্মের আহ্বানকে বিলম্বিত করতে পারে। এই কারণে, 600000
এর নিচে windowLengthMillis
প্যারামিটার মান 600000
এ ক্লিপ করা হয়েছে।
মোটামুটি নিয়মিত বিরতিতে একটি পুনরাবৃত্তি অ্যালার্ম সরবরাহ করুন
যদি আপনার অ্যাপ কল করে setInexactRepeating()
, সিস্টেম একাধিক অ্যালার্ম আহ্বান করে:
- প্রদত্ত ট্রিগার সময় থেকে শুরু করে, নির্দিষ্ট সময় উইন্ডোর মধ্যে প্রথম অ্যালার্মটি বন্ধ হয়ে যায়।
- পরবর্তী অ্যালার্মগুলি সাধারণত নির্দিষ্ট সময় উইন্ডো শেষ হওয়ার পরে বন্ধ হয়ে যায়। অ্যালার্মের পরপর দুটি আহ্বানের মধ্যে সময় পরিবর্তিত হতে পারে।
একটি সঠিক অ্যালার্ম সেট করুন
সিস্টেমটি ভবিষ্যতে একটি সুনির্দিষ্ট মুহূর্তে একটি সঠিক অ্যালার্ম আহ্বান করে।
বেশিরভাগ অ্যাপ্লিকেশানগুলি বেশ কয়েকটি সাধারণ ব্যবহারের ক্ষেত্রে সম্পূর্ণ করতে অযৌক্তিক অ্যালার্ম ব্যবহার করে কার্য এবং ইভেন্টগুলি নির্ধারণ করতে পারে৷ যদি আপনার অ্যাপের মূল কার্যকারিতা একটি সুনির্দিষ্ট-সময়ের অ্যালার্মের উপর নির্ভর করে—যেমন একটি অ্যালার্ম ক্লক অ্যাপ বা একটি ক্যালেন্ডার অ্যাপের জন্য—তাহলে এর পরিবর্তে একটি সঠিক অ্যালার্ম ব্যবহার করা ঠিক।
সঠিক অ্যালার্মের প্রয়োজন নাও হতে পারে এমন ক্ষেত্রে ব্যবহার করুন
নিম্নলিখিত তালিকাটি সাধারণ ওয়ার্কফ্লোগুলি দেখায় যেগুলির জন্য সঠিক অ্যালার্মের প্রয়োজন নাও হতে পারে:
- আপনার অ্যাপের জীবদ্দশায় সময় নির্ধারণের ক্রিয়াকলাপ
-
Handler
ক্লাসে টাইমিং ক্রিয়াকলাপগুলি পরিচালনা করার জন্য বেশ কয়েকটি ভাল পদ্ধতি রয়েছে, যেমন আপনার অ্যাপটি জীবিত থাকাকালীন প্রতি n সেকেন্ডে কিছু কাজ করা:postAtTime()
এবংpostDelayed()
। মনে রাখবেন যে এই APIগুলি সিস্টেম আপটাইমের উপর নির্ভর করে এবং রিয়েল টাইমে নয়। - নির্ধারিত ব্যাকগ্রাউন্ডের কাজ, যেমন আপনার অ্যাপ আপডেট করা এবং লগ আপলোড করা
-
WorkManager
সময়-সংবেদনশীল পর্যায়ক্রমিক কাজের সময়সূচী করার একটি উপায় প্রদান করে। কাজের জন্য দানাদার রানটাইম সংজ্ঞায়িত করতে আপনি একটি পুনরাবৃত্তি ব্যবধান এবংflexInterval
(15 মিনিট সর্বনিম্ন) প্রদান করতে পারেন। - ব্যবহারকারী-নির্দিষ্ট ক্রিয়া যা একটি নির্দিষ্ট সময়ের পরে হওয়া উচিত (এমনকি নিষ্ক্রিয় অবস্থায় সিস্টেম থাকলেও)
- একটি অযৌক্তিক অ্যালার্ম ব্যবহার করুন। বিশেষভাবে,
setAndAllowWhileIdle()
কল করুন। - ব্যবহারকারী-নির্দিষ্ট ক্রিয়া যা একটি নির্দিষ্ট সময়ের পরে হওয়া উচিত
- একটি অযৌক্তিক অ্যালার্ম ব্যবহার করুন। বিশেষত, কল
set()
। - ব্যবহারকারী-নির্দিষ্ট ক্রিয়া যা একটি নির্দিষ্ট সময় উইন্ডোর মধ্যে ঘটতে পারে
- একটি অযৌক্তিক অ্যালার্ম ব্যবহার করুন। বিশেষ করে,
setWindow()
কল করুন। মনে রাখবেন, যদি আপনার অ্যাপটি Android 12 বা উচ্চতরকে লক্ষ্য করে, তাহলে সবচেয়ে ছোট অনুমোদিত উইন্ডোর দৈর্ঘ্য 10 মিনিট।
একটি সঠিক অ্যালার্ম সেট করার উপায়
আপনার অ্যাপ নিম্নলিখিত পদ্ধতিগুলির মধ্যে একটি ব্যবহার করে সঠিক অ্যালার্ম সেট করতে পারে৷ এই পদ্ধতিগুলি এমনভাবে অর্ডার করা হয়েছে যে তালিকার নীচের কাছাকাছি থাকাগুলি আরও সময়-সমালোচনামূলক কাজগুলি পরিবেশন করে তবে আরও সিস্টেম সংস্থানগুলির দাবি করে৷
-
setExact()
ভবিষ্যতে প্রায় সুনির্দিষ্ট সময়ে একটি অ্যালার্ম চালু করুন, যতক্ষণ না অন্যান্য ব্যাটারি-সংরক্ষণ ব্যবস্থা কার্যকর না হয়।
সঠিক অ্যালার্ম সেট করতে এই পদ্ধতিটি ব্যবহার করুন, যদি না আপনার অ্যাপের কাজ ব্যবহারকারীর জন্য সময়-গুরুত্বপূর্ণ হয়।
-
setExactAndAllowWhileIdle()
ভবিষ্যতে প্রায় সুনির্দিষ্ট সময়ে একটি অ্যালার্ম আহ্বান করুন, এমনকি যদি ব্যাটারি-সংরক্ষণ ব্যবস্থা কার্যকর হয়।
-
setAlarmClock()
ভবিষ্যতে একটি সুনির্দিষ্ট সময়ে একটি অ্যালার্ম আহ্বান করুন। যেহেতু এই অ্যালার্মগুলি ব্যবহারকারীদের কাছে অত্যন্ত দৃশ্যমান, সিস্টেম কখনই তাদের ডেলিভারির সময় সামঞ্জস্য করে না। সিস্টেম এই অ্যালার্মগুলিকে সবচেয়ে গুরুত্বপূর্ণ হিসাবে চিহ্নিত করে এবং অ্যালার্মগুলি সরবরাহ করার জন্য প্রয়োজনে কম-পাওয়ার মোডগুলি ছেড়ে দেয়।
সিস্টেম সম্পদ খরচ
যখন সিস্টেমটি আপনার অ্যাপ সেট করা সঠিক অ্যালার্মগুলিকে ট্রিগার করে, তখন ডিভাইসটি ব্যাটারি লাইফের মতো প্রচুর সম্পদ ব্যবহার করে, বিশেষ করে যদি এটি পাওয়ার-সেভিং মোডে থাকে। তদুপরি, সংস্থানগুলি আরও দক্ষতার সাথে ব্যবহার করার জন্য সিস্টেম সহজেই এই অনুরোধগুলি ব্যাচ করতে পারে না।
এটি অত্যন্ত সুপারিশ করা হয় যে আপনি যখনই সম্ভব একটি অযৌক্তিক অ্যালার্ম তৈরি করুন৷ দীর্ঘ কাজ সম্পাদন করতে, আপনার অ্যালার্মের BroadcastReceiver
থেকে WorkManager
বা JobScheduler
ব্যবহার করে সময়সূচী করুন। ডিভাইসটি ডোজে থাকা অবস্থায় কাজ করতে, setAndAllowWhileIdle()
ব্যবহার করে একটি অযৌক্তিক অ্যালার্ম তৈরি করুন এবং অ্যালার্ম থেকে একটি কাজ শুরু করুন।
উপযুক্ত সঠিক অ্যালার্ম অনুমতি ঘোষণা করুন
যদি আপনার অ্যাপটি Android 12 বা তার বেশির দিকে লক্ষ্য করে, তাহলে আপনাকে অবশ্যই "অ্যালার্ম এবং রিমাইন্ডার" বিশেষ অ্যাপ অ্যাক্সেস পেতে হবে। এটি করতে, নিম্নলিখিত কোড স্নিপেটে দেখানো হিসাবে আপনার অ্যাপের ম্যানিফেস্ট ফাইলে SCHEDULE_EXACT_ALARM
অনুমতি ঘোষণা করুন:
<manifest ...> <uses-permission android:name="android.permission.SCHEDULE_EXACT_ALARM"/> <application ...> ... </application> </manifest>
যদি আপনার অ্যাপটি Android 13 (API স্তর 33) বা উচ্চতরকে লক্ষ্য করে, তাহলে আপনার কাছে SCHEDULE_EXACT_ALARM
বা USE_EXACT_ALARM
অনুমতি ঘোষণা করার বিকল্প রয়েছে।
<manifest ...> <uses-permission android:name="android.permission.USE_EXACT_ALARM"/> <application ...> ... </application> </manifest>
যদিও SCHEDULE_EXACT_ALARM
এবং USE_EXACT_ALARM
উভয় অনুমতিই একই ক্ষমতার সংকেত দেয়, সেগুলি আলাদাভাবে দেওয়া হয় এবং বিভিন্ন ব্যবহারের ক্ষেত্রে সমর্থন করে। আপনার অ্যাপের সঠিক অ্যালার্ম ব্যবহার করা উচিত এবং SCHEDULE_EXACT_ALARM
বা USE_EXACT_ALARM
অনুমতি ঘোষণা করা উচিত, শুধুমাত্র তখনই যদি আপনার অ্যাপে ব্যবহারকারী-মুখী ফাংশনের জন্য সঠিকভাবে সময়মতো পদক্ষেপের প্রয়োজন হয়।
USE_EXACT_ALARM
- স্বয়ংক্রিয়ভাবে মঞ্জুর করা হয়েছে
- ব্যবহারকারী দ্বারা প্রত্যাহার করা যাবে না
- একটি আসন্ন Google Play নীতি সাপেক্ষে
- সীমিত ব্যবহারের ক্ষেত্রে
SCHEDULE_EXACT_ALARM
- ব্যবহারকারী দ্বারা মঞ্জুর
- ব্যবহারের ক্ষেত্রে বিস্তৃত সেট
- অ্যাপগুলিকে নিশ্চিত করা উচিত যে অনুমতি প্রত্যাহার করা হয়নি
SCHEDULE_EXACT_ALARM
অনুমতিটি Android 13 (API স্তর 33) এবং উচ্চতর টার্গেট করা অ্যাপগুলির নতুন ইনস্টলের জন্য পূর্ব-মঞ্জুর করা হয় না। যদি কোনও ব্যবহারকারী ব্যাকআপ-এন্ড-রিস্টোর অপারেশনের মাধ্যমে Android 14 চালিত কোনও ডিভাইসে অ্যাপ ডেটা স্থানান্তর করে, তাহলে নতুন ডিভাইসে SCHEDULE_EXACT_ALARM
অনুমতি অস্বীকার করা হবে। যাইহোক, যদি একটি বিদ্যমান অ্যাপ ইতিমধ্যেই এই অনুমতি থাকে, তবে ডিভাইসটি Android 14 এ আপগ্রেড করার সময় এটি পূর্ব-মঞ্জুর করা হবে।
দ্রষ্টব্য : যদি সঠিক অ্যালার্মটি একটি OnAlarmListener
অবজেক্ট ব্যবহার করে সেট করা হয়, যেমন setExact
API সহ, SCHEDULE_EXACT_ALARM
অনুমতির প্রয়োজন হয় না৷
SCHEDULE_EXACT_ALARM
অনুমতি ব্যবহার করে৷
USE_EXACT_ALARM
বিপরীতে, SCHEDULE_EXACT_ALARM
অনুমতি অবশ্যই ব্যবহারকারীকে দিতে হবে। ব্যবহারকারী এবং সিস্টেম উভয়ই SCHEDULE_EXACT_ALARM
অনুমতি প্রত্যাহার করতে পারে৷
আপনার অ্যাপে অনুমতি দেওয়া হয়েছে কিনা তা পরীক্ষা করতে, সঠিক অ্যালার্ম সেট করার চেষ্টা করার আগে canScheduleExactAlarms()
কল করুন। যখন আপনার অ্যাপ্লিকেশানের জন্য SCHEDULE_EXACT_ALARM
অনুমতি প্রত্যাহার করা হয়, তখন আপনার অ্যাপ্লিকেশান বন্ধ হয়ে যায় এবং ভবিষ্যতের সমস্ত সঠিক অ্যালার্ম বাতিল হয়ে যায়৷ এর মানে হল canScheduleExactAlarms()
দ্বারা প্রত্যাবর্তিত মান আপনার অ্যাপের সমগ্র জীবনচক্রের জন্য বৈধ থাকে।
যখন আপনার অ্যাপে SCHEDULE_EXACT_ALARMS
অনুমতি দেওয়া হয়, তখন সিস্টেম এটিকে ACTION_SCHEDULE_EXACT_ALARM_PERMISSION_STATE_CHANGED
সম্প্রচার পাঠায়। আপনার অ্যাপের একটি ব্রডকাস্ট রিসিভার প্রয়োগ করা উচিত যা নিম্নলিখিতগুলি করে:
- নিশ্চিত করে যে আপনার অ্যাপে এখনও বিশেষ অ্যাপ অ্যাক্সেস আছে। এটি করতে,
canScheduleExactAlarms()
কল করুন। এই চেকটি আপনার অ্যাপটিকে সেই ক্ষেত্রে থেকে রক্ষা করে যেখানে ব্যবহারকারী আপনার অ্যাপটিকে অনুমতি দেয়, তারপর প্রায় সঙ্গে সঙ্গেই এটি প্রত্যাহার করে। - আপনার অ্যাপ্লিকেশানের বর্তমান অবস্থার উপর ভিত্তি করে প্রয়োজনীয় যেকোনও সঠিক অ্যালার্মগুলি পুনঃনির্ধারণ করে৷ এই যুক্তিটি
ACTION_BOOT_COMPLETED
সম্প্রচার গ্রহণ করার সময় আপনার অ্যাপ যা করে তার অনুরূপ হওয়া উচিত।
ব্যবহারকারীদেরকে SCHEDULE_EXACT_ALARM
অনুমতি দিতে বলুন
প্রয়োজনে, আপনি ব্যবহারকারীদের সিস্টেম সেটিংসে অ্যালার্ম এবং অনুস্মারক স্ক্রিনে পাঠাতে পারেন, যেমন চিত্র 1 এ দেখানো হয়েছে। এটি করতে, নিম্নলিখিত পদক্ষেপগুলি সম্পূর্ণ করুন:
- আপনার অ্যাপের UI-তে, ব্যবহারকারীকে ব্যাখ্যা করুন কেন আপনার অ্যাপকে সঠিক অ্যালার্ম নির্ধারণ করতে হবে।
-
ACTION_REQUEST_SCHEDULE_EXACT_ALARM
অভিপ্রায় ক্রিয়া অন্তর্ভুক্ত এমন একটি অভিপ্রায় আহ্বান করুন৷
একটি পুনরাবৃত্তি অ্যালার্ম সেট করুন
পুনরাবৃত্ত অ্যালার্ম সিস্টেমকে আপনার অ্যাপকে একটি পুনরাবৃত্ত সময়সূচীতে জানানোর অনুমতি দেয়।
একটি খারাপভাবে ডিজাইন করা অ্যালার্ম ব্যাটারি নিষ্কাশনের কারণ হতে পারে এবং সার্ভারে একটি উল্লেখযোগ্য লোড রাখতে পারে। এই কারণে, Android 4.4 (API স্তর 19) এবং উচ্চতর, সমস্ত পুনরাবৃত্তি করা অ্যালার্মগুলি অযৌক্তিক অ্যালার্ম ৷
একটি পুনরাবৃত্তি অ্যালার্মের নিম্নলিখিত বৈশিষ্ট্য রয়েছে:
একটি অ্যালার্ম টাইপ। আরও আলোচনার জন্য, একটি অ্যালার্ম টাইপ চয়ন করুন দেখুন।
একটি ট্রিগার সময়. আপনার উল্লেখ করা ট্রিগার সময় অতীতে থাকলে, অ্যালার্ম অবিলম্বে ট্রিগার হয়।
অ্যালার্মের ব্যবধান। উদাহরণস্বরূপ, দিনে একবার, প্রতি ঘন্টায়, বা প্রতি 5 মিনিটে।
একটি মুলতুবি অভিপ্রায় যেটি যখন অ্যালার্ম ট্রিগার হয় তখন ফায়ার হয়৷ আপনি যখন একই মুলতুবি থাকা অভিপ্রায় ব্যবহার করে একটি দ্বিতীয় অ্যালার্ম সেট করেন, তখন এটি আসল অ্যালার্মকে প্রতিস্থাপন করে।
একটি PendingIntent()
বাতিল করতে, অভিপ্রায়ের একটি উদাহরণ পেতে PendingIntent.getService()
এ FLAG_NO_CREATE
পাস করুন (যদি এটি বিদ্যমান থাকে), তারপর সেই অভিপ্রায়টি AlarmManager.cancel()
এ পাস করুন
কোটলিন
val alarmManager = context.getSystemService(Context.ALARM_SERVICE) as? AlarmManager val pendingIntent = PendingIntent.getService(context, requestId, intent, PendingIntent.FLAG_NO_CREATE) if (pendingIntent != null && alarmManager != null) { alarmManager.cancel(pendingIntent) }
জাভা
AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); PendingIntent pendingIntent = PendingIntent.getService(context, requestId, intent, PendingIntent.FLAG_NO_CREATE); if (pendingIntent != null && alarmManager != null) { alarmManager.cancel(pendingIntent); }
একটি অ্যালার্ম টাইপ চয়ন করুন
একটি পুনরাবৃত্তি অ্যালার্ম ব্যবহার করার ক্ষেত্রে প্রথম বিবেচ্য বিষয়গুলির মধ্যে একটি হল এর ধরনটি কী হওয়া উচিত৷
অ্যালার্মের জন্য দুটি সাধারণ ঘড়ির ধরন রয়েছে: "বিগত রিয়েল টাইম" এবং "রিয়েল টাইম ক্লক" (RTC)। অতিবাহিত রিয়েল টাইম একটি রেফারেন্স হিসাবে "সিস্টেম বুট থেকে সময়" ব্যবহার করে এবং বাস্তব সময় ঘড়ি UTC (ওয়াল ঘড়ি) সময় ব্যবহার করে। এর মানে হল যে অতিবাহিত বাস্তব সময় সময় অতিবাহিত হওয়ার উপর ভিত্তি করে একটি অ্যালার্ম সেট করার জন্য উপযুক্ত (উদাহরণস্বরূপ, একটি অ্যালার্ম যা প্রতি 30 সেকেন্ডে ফায়ার হয়) কারণ এটি সময় অঞ্চল বা লোকেল দ্বারা প্রভাবিত হয় না। রিয়েল টাইম ঘড়ির ধরন বর্তমান লোকেলের উপর নির্ভরশীল অ্যালার্মগুলির জন্য আরও উপযুক্ত।
উভয় প্রকারের একটি "ওয়েকআপ" সংস্করণ রয়েছে, যা স্ক্রীন বন্ধ থাকলে ডিভাইসের CPU কে জাগিয়ে তুলতে বলে। এটি নিশ্চিত করে যে অ্যালার্ম নির্ধারিত সময়ে বাজবে। আপনার অ্যাপের সময় নির্ভরতা থাকলে এটি কার্যকর। উদাহরণস্বরূপ, যদি একটি নির্দিষ্ট অপারেশন করার জন্য এটির একটি সীমিত উইন্ডো থাকে। আপনি যদি আপনার অ্যালার্ম প্রকারের ওয়েকআপ সংস্করণটি ব্যবহার না করেন, তাহলে আপনার ডিভাইসটি পরবর্তী জেগে উঠলে সমস্ত পুনরাবৃত্তি করা অ্যালার্মগুলি ফায়ার হবে৷
আপনি যদি একটি নির্দিষ্ট ব্যবধানে (উদাহরণস্বরূপ, প্রতি আধ ঘন্টা) আপনার অ্যালার্ম বাজানোর প্রয়োজন হয়, তাহলে অতিবাহিত রিয়েল টাইম প্রকারগুলির একটি ব্যবহার করুন। সাধারণভাবে, এটিই ভাল পছন্দ।
দিনের একটি নির্দিষ্ট সময়ে আপনার অ্যালার্ম ফায়ার করার প্রয়োজন হলে, ঘড়ি-ভিত্তিক রিয়েল টাইম ঘড়ির ধরনগুলির মধ্যে একটি বেছে নিন। উল্লেখ্য, যাইহোক, এই পদ্ধতির কিছু ত্রুটি থাকতে পারে। অ্যাপটি অন্য লোকেলে ভালোভাবে অনুবাদ নাও করতে পারে এবং ব্যবহারকারী যদি ডিভাইসের সময় সেটিং পরিবর্তন করে, তাহলে এটি আপনার অ্যাপে অপ্রত্যাশিত আচরণের কারণ হতে পারে। একটি রিয়েল টাইম ঘড়ি অ্যালার্ম টাইপ ব্যবহার করাও ভালভাবে পরিমাপ করে না, যেমন উপরে আলোচনা করা হয়েছে। আমরা সুপারিশ করি যে আপনি যদি পারেন তাহলে একটি "বিগত রিয়েল টাইম" অ্যালার্ম ব্যবহার করুন৷
এখানে প্রকারের তালিকা রয়েছে:
ELAPSED_REALTIME
: ডিভাইসটি বুট হওয়ার পর থেকে কত সময়ের জন্য মুলতুবি থাকা অভিপ্রায়কে ফায়ার করে, কিন্তু ডিভাইসটিকে জাগিয়ে তোলে না। অতিবাহিত সময়ের মধ্যে ডিভাইসটি ঘুমিয়ে থাকা যেকোনো সময় অন্তর্ভুক্ত।ELAPSED_REALTIME_WAKEUP
: ডিভাইস বুট হওয়ার পর থেকে নির্দিষ্ট সময় অতিবাহিত হওয়ার পরে ডিভাইসটিকে জাগিয়ে তোলে এবং মুলতুবি থাকা অভিপ্রায়কে ফায়ার করে।RTC
: নির্দিষ্ট সময়ে মুলতুবি অভিপ্রায় ফায়ার করে কিন্তু ডিভাইসটিকে জাগিয়ে তোলে না।RTC_WAKEUP
: নির্দিষ্ট সময়ে মুলতুবি থাকা উদ্দেশ্য ফায়ার করতে ডিভাইসটিকে জাগিয়ে তোলে।
অতিবাহিত রিয়েল টাইম অ্যালার্মের উদাহরণ
এখানে ELAPSED_REALTIME_WAKEUP
ব্যবহারের কিছু উদাহরণ রয়েছে৷
30 মিনিটের মধ্যে অ্যালার্ম ফায়ার করার জন্য ডিভাইসটিকে জাগিয়ে দিন এবং তার পরে প্রতি 30 মিনিটে:
কোটলিন
// Hopefully your alarm will have a lower frequency than this! alarmMgr?.setInexactRepeating( AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + AlarmManager.INTERVAL_HALF_HOUR, AlarmManager.INTERVAL_HALF_HOUR, alarmIntent )
জাভা
// Hopefully your alarm will have a lower frequency than this! alarmMgr.setInexactRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + AlarmManager.INTERVAL_HALF_HOUR, AlarmManager.INTERVAL_HALF_HOUR, alarmIntent);
এক মিনিটের মধ্যে একটি ওয়ান-টাইম (পুনরাবৃত্তি না হওয়া) অ্যালার্ম ফায়ার করতে ডিভাইসটিকে জাগাও:
কোটলিন
private var alarmMgr: AlarmManager? = null private lateinit var alarmIntent: PendingIntent ... alarmMgr = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager alarmIntent = Intent(context, AlarmReceiver::class.java).let { intent -> PendingIntent.getBroadcast(context, 0, intent, 0) } alarmMgr?.set( AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + 60 * 1000, alarmIntent )
জাভা
private AlarmManager alarmMgr; private PendingIntent alarmIntent; ... alarmMgr = (AlarmManager)context.getSystemService(Context.ALARM_SERVICE); Intent intent = new Intent(context, AlarmReceiver.class); alarmIntent = PendingIntent.getBroadcast(context, 0, intent, 0); alarmMgr.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + 60 * 1000, alarmIntent);
বাস্তব সময় ঘড়ি অ্যালার্ম উদাহরণ
এখানে RTC_WAKEUP
ব্যবহারের কিছু উদাহরণ রয়েছে।
আনুমানিক 2:00 pm এ অ্যালার্ম ফায়ার করার জন্য ডিভাইসটিকে জাগিয়ে দিন এবং একই সময়ে দিনে একবার পুনরাবৃত্তি করুন:
কোটলিন
// Set the alarm to start at approximately 2:00 p.m. val calendar: Calendar = Calendar.getInstance().apply { timeInMillis = System.currentTimeMillis() set(Calendar.HOUR_OF_DAY, 14) } // With setInexactRepeating(), you have to use one of the AlarmManager interval // constants--in this case, AlarmManager.INTERVAL_DAY. alarmMgr?.setInexactRepeating( AlarmManager.RTC_WAKEUP, calendar.timeInMillis, AlarmManager.INTERVAL_DAY, alarmIntent )
জাভা
// Set the alarm to start at approximately 2:00 p.m. Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(System.currentTimeMillis()); calendar.set(Calendar.HOUR_OF_DAY, 14); // With setInexactRepeating(), you have to use one of the AlarmManager interval // constants--in this case, AlarmManager.INTERVAL_DAY. alarmMgr.setInexactRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), AlarmManager.INTERVAL_DAY, alarmIntent);
ঠিক সকাল ৮:৩০ মিনিটে এবং তার পর প্রতি ২০ মিনিটে অ্যালার্ম বাজানোর জন্য ডিভাইসটিকে জাগাও:
কোটলিন
private var alarmMgr: AlarmManager? = null private lateinit var alarmIntent: PendingIntent ... alarmMgr = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager alarmIntent = Intent(context, AlarmReceiver::class.java).let { intent -> PendingIntent.getBroadcast(context, 0, intent, 0) } // Set the alarm to start at 8:30 a.m. val calendar: Calendar = Calendar.getInstance().apply { timeInMillis = System.currentTimeMillis() set(Calendar.HOUR_OF_DAY, 8) set(Calendar.MINUTE, 30) } // setRepeating() lets you specify a precise custom interval--in this case, // 20 minutes. alarmMgr?.setRepeating( AlarmManager.RTC_WAKEUP, calendar.timeInMillis, 1000 * 60 * 20, alarmIntent )
জাভা
private AlarmManager alarmMgr; private PendingIntent alarmIntent; ... alarmMgr = (AlarmManager)context.getSystemService(Context.ALARM_SERVICE); Intent intent = new Intent(context, AlarmReceiver.class); alarmIntent = PendingIntent.getBroadcast(context, 0, intent, 0); // Set the alarm to start at 8:30 a.m. Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(System.currentTimeMillis()); calendar.set(Calendar.HOUR_OF_DAY, 8); calendar.set(Calendar.MINUTE, 30); // setRepeating() lets you specify a precise custom interval--in this case, // 20 minutes. alarmMgr.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), 1000 * 60 * 20, alarmIntent);
আপনার অ্যালার্ম কতটা সুনির্দিষ্ট হওয়া দরকার তা নির্ধারণ করুন
পূর্বে বর্ণিত হিসাবে, অ্যালার্মের ধরন নির্বাচন করা প্রায়শই একটি অ্যালার্ম তৈরির প্রথম পদক্ষেপ। আরও একটি পার্থক্য হল আপনার অ্যালার্মটি কতটা সুনির্দিষ্ট হওয়া দরকার। বেশিরভাগ অ্যাপের জন্য, setInexactRepeating()
হল সঠিক পছন্দ। আপনি যখন এই পদ্ধতিটি ব্যবহার করেন, তখন Android একাধিক অযৌক্তিক পুনরাবৃত্তিকারী অ্যালার্ম সিঙ্ক্রোনাইজ করে এবং একই সময়ে সেগুলি ফায়ার করে। এটি ব্যাটারির ড্রেন হ্রাস করে।
সম্ভব হলে সঠিক অ্যালার্ম ব্যবহার এড়িয়ে চলুন। যাইহোক, বিরল অ্যাপের জন্য কঠোর সময়ের প্রয়োজনীয়তা রয়েছে, আপনি setRepeating()
কল করে একটি সঠিক অ্যালার্ম সেট করতে পারেন।
setInexactRepeating()
এর সাথে, আপনি setRepeating()
এর সাথে যেভাবে পারেন একটি কাস্টম ব্যবধান নির্দিষ্ট করতে পারবেন না। আপনাকে একটি ব্যবধান ধ্রুবক ব্যবহার করতে হবে, যেমন INTERVAL_FIFTEEN_MINUTES
, INTERVAL_DAY
, এবং আরও অনেক কিছু৷ সম্পূর্ণ তালিকার জন্য AlarmManager
দেখুন।
একটি অ্যালার্ম বাতিল করুন
আপনার অ্যাপের উপর নির্ভর করে, আপনি অ্যালার্ম বাতিল করার ক্ষমতা অন্তর্ভুক্ত করতে চাইতে পারেন। একটি অ্যালার্ম বাতিল করতে, অ্যালার্ম ম্যানেজারে cancel()
কল করুন, PendingIntent
এ পাস করে আপনি আর ফায়ার করতে চান না। যেমন:
কোটলিন
// If the alarm has been set, cancel it. alarmMgr?.cancel(alarmIntent)
জাভা
// If the alarm has been set, cancel it. if (alarmMgr!= null) { alarmMgr.cancel(alarmIntent); }
ডিভাইস পুনরায় চালু হলে একটি অ্যালার্ম শুরু করুন
ডিফল্টরূপে, একটি ডিভাইস বন্ধ হয়ে গেলে সমস্ত অ্যালার্ম বাতিল হয়ে যায়। এটি যাতে না ঘটে তার জন্য, ব্যবহারকারী যদি ডিভাইসটি পুনরায় বুট করে তবে আপনি একটি পুনরাবৃত্তি অ্যালার্ম স্বয়ংক্রিয়ভাবে পুনরায় চালু করার জন্য আপনার অ্যাপ্লিকেশনটি ডিজাইন করতে পারেন। এটি নিশ্চিত করে যে AlarmManager
ব্যবহারকারীকে ম্যানুয়ালি অ্যালার্ম পুনরায় চালু করার প্রয়োজন ছাড়াই তার কাজটি চালিয়ে যাবে।
এখানে পদক্ষেপগুলি রয়েছে:
আপনার অ্যাপ্লিকেশনের ম্যানিফেস্টে
RECEIVE_BOOT_COMPLETED
অনুমতি সেট করুন। এটি আপনার অ্যাপ্লিকেশানটিকেACTION_BOOT_COMPLETED
পাওয়ার অনুমতি দেয় যা সিস্টেম বুট করা শেষ হওয়ার পরে সম্প্রচারিত হয় (এটি শুধুমাত্র তখনই কাজ করে যদি ব্যবহারকারীরা অন্তত একবার অ্যাপটি চালু করে থাকেন):<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
সম্প্রচার গ্রহণের জন্য একটি
BroadcastReceiver
প্রয়োগ করুন:কোটলিন
class SampleBootReceiver : BroadcastReceiver() { override fun onReceive(context: Context, intent: Intent) { if (intent.action == "android.intent.action.BOOT_COMPLETED") { // Set the alarm here. } } }
জাভা
public class SampleBootReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (intent.getAction().equals("android.intent.action.BOOT_COMPLETED")) { // Set the alarm here. } } }
ACTION_BOOT_COMPLETED
অ্যাকশনে ফিল্টার করে এমন একটি অভিপ্রায় ফিল্টার সহ আপনার অ্যাপের ম্যানিফেস্ট ফাইলে রিসিভার যোগ করুন:<receiver android:name=".SampleBootReceiver" android:enabled="false"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED"></action> </intent-filter> </receiver>
লক্ষ্য করুন যে ম্যানিফেস্টে, বুট রিসিভার সেট করা আছে
android:enabled="false"
। এর মানে হল যে আবেদনটি স্পষ্টভাবে এটি সক্ষম না করলে রিসিভারকে কল করা হবে না। এটি বুট রিসিভারকে অপ্রয়োজনীয়ভাবে কল করা থেকে বাধা দেয়। আপনি একটি রিসিভার সক্ষম করতে পারেন (উদাহরণস্বরূপ, যদি ব্যবহারকারী একটি অ্যালার্ম সেট করে) নিম্নরূপ:কোটলিন
val receiver = ComponentName(context, SampleBootReceiver::class.java) context.packageManager.setComponentEnabledSetting( receiver, PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP )
জাভা
ComponentName receiver = new ComponentName(context, SampleBootReceiver.class); PackageManager pm = context.getPackageManager(); pm.setComponentEnabledSetting(receiver, PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP);
একবার আপনি এইভাবে রিসিভার সক্ষম করলে, ব্যবহারকারী ডিভাইসটি পুনরায় বুট করলেও এটি সক্রিয় থাকবে। অন্য কথায়, প্রোগ্রাম্যাটিকভাবে রিসিভার সক্রিয় করা ম্যানিফেস্ট সেটিংকে ওভাররাইড করে, এমনকি রিবুট জুড়েও। আপনার অ্যাপটি নিষ্ক্রিয় না করা পর্যন্ত রিসিভারটি সক্রিয় থাকবে। আপনি একটি রিসিভার অক্ষম করতে পারেন (উদাহরণস্বরূপ, যদি ব্যবহারকারী একটি অ্যালার্ম বাতিল করে) নিম্নরূপ:
কোটলিন
val receiver = ComponentName(context, SampleBootReceiver::class.java) context.packageManager.setComponentEnabledSetting( receiver, PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP )
জাভা
ComponentName receiver = new ComponentName(context, SampleBootReceiver.class); PackageManager pm = context.getPackageManager(); pm.setComponentEnabledSetting(receiver, PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP);
ডিভাইসটি ডোজ মোডে থাকা অবস্থায় অ্যালার্ম চালু করুন
Android 6.0 (API লেভেল 23) চালিত ডিভাইসগুলি Doze মোড সমর্থন করে, যা ডিভাইসের ব্যাটারির আয়ু বাড়াতে সাহায্য করে। ডিভাইসটি ডোজ মোডে থাকা অবস্থায় অ্যালার্মগুলি ফায়ার হয় না যতক্ষণ না ডিভাইসটি ডোজ থেকে বেরিয়ে আসে ততক্ষণ পর্যন্ত যে কোনও নির্ধারিত অ্যালার্ম স্থগিত করা হয়৷ ডিভাইসটি নিষ্ক্রিয় থাকা সত্ত্বেও আপনি যদি কাজটি সম্পূর্ণ করতে চান তবে বেশ কয়েকটি বিকল্প উপলব্ধ রয়েছে:
একটি সঠিক অ্যালার্ম সেট করুন।
WorkManager API ব্যবহার করুন, যা ব্যাকগ্রাউন্ডের কাজ সম্পাদন করার জন্য তৈরি করা হয়েছে। আপনি নির্দেশ করতে পারেন যে সিস্টেমটি আপনার কাজকে ত্বরান্বিত করবে যাতে কাজটি যত তাড়াতাড়ি সম্ভব শেষ হয়। আরও তথ্যের জন্য, WorkManager-এর সাথে কাজের সময়সূচী দেখুন
সর্বোত্তম অনুশীলন
আপনার পুনরাবৃত্ত অ্যালার্ম ডিজাইন করার ক্ষেত্রে আপনার করা প্রতিটি পছন্দ আপনার অ্যাপ কীভাবে সিস্টেম রিসোর্স ব্যবহার করে (বা অপব্যবহার করে) তার ফলাফল হতে পারে। উদাহরণস্বরূপ, একটি জনপ্রিয় অ্যাপ কল্পনা করুন যা একটি সার্ভারের সাথে সিঙ্ক করে। যদি সিঙ্ক অপারেশন ঘড়ির সময়ের উপর ভিত্তি করে হয় এবং অ্যাপের প্রতিটি ঘটনা রাত 11:00 টায় সিঙ্ক হয়, সার্ভারে লোডের ফলে উচ্চ বিলম্ব বা এমনকি "পরিষেবা অস্বীকার" হতে পারে। অ্যালার্ম ব্যবহার করার জন্য এই সেরা অনুশীলনগুলি অনুসরণ করুন:
যেকোন নেটওয়ার্ক অনুরোধে এলোমেলোতা (জিটার) যোগ করুন যা পুনরাবৃত্তি করা অ্যালার্মের ফলে ট্রিগার করে:
অ্যালার্ম ট্রিগার হলে স্থানীয় কোনো কাজ করুন। "স্থানীয় কাজ" মানে এমন কিছু যা সার্ভারে আঘাত করে না বা সার্ভার থেকে ডেটার প্রয়োজন হয় না।
একই সময়ে, কিছু এলোমেলো সময়ে ফায়ার করার জন্য নেটওয়ার্ক অনুরোধ ধারণ করে এমন অ্যালার্মের সময় নির্ধারণ করুন।
আপনার অ্যালার্ম ফ্রিকোয়েন্সি সর্বনিম্ন রাখুন।
অপ্রয়োজনীয়ভাবে ডিভাইসটিকে জাগাবেন না (এই আচরণটি অ্যালার্মের ধরন দ্বারা নির্ধারিত হয়, যেমন একটি অ্যালার্ম টাইপ চয়ন করুন )।
আপনার অ্যালার্মের ট্রিগার সময়কে যতটা প্রয়োজন তার চেয়ে বেশি সুনির্দিষ্ট করবেন না।
setRepeating
setInexactRepeating()
setRepeating()
ব্যবহার করুন। আপনি যখনsetInexactRepeating()
ব্যবহার করেন, তখন Android একাধিক অ্যাপ্লিকেশান থেকে পুনরাবৃত্তি করা অ্যালার্ম সিঙ্ক্রোনাইজ করে এবং একই সময়ে সেগুলিকে ফায়ার করে। এটি সিস্টেমটিকে ডিভাইসটিকে জাগ্রত করার মোট সংখ্যা হ্রাস করে, এইভাবে ব্যাটারির ড্রেন হ্রাস করে৷ অ্যান্ড্রয়েড 4.4 (এপিআই লেভেল 19) অনুসারে, সমস্ত পুনরাবৃত্তি করা অ্যালার্মগুলি অযৌক্তিক অ্যালার্ম । মনে রাখবেন যেsetInexactRepeating()
setRepeating()
তুলনায় একটি উন্নতি, এটি এখনও একটি সার্ভারকে অভিভূত করতে পারে যদি একটি অ্যাপের প্রতিটি ঘটনা একই সময়ে সার্ভারে আঘাত করে। অতএব, নেটওয়ার্ক অনুরোধের জন্য, আপনার অ্যালার্মে কিছু এলোমেলোতা যোগ করুন, যেমনটি পূর্বে আলোচনা করা হয়েছে।সম্ভব হলে ঘড়ির সময় আপনার অ্যালার্ম এড়িয়ে চলুন।
একটি সুনির্দিষ্ট ট্রিগার সময়ের উপর ভিত্তি করে পুনরাবৃত্তি করা অ্যালার্মগুলি ভালভাবে পরিমাপ করে না। আপনি যদি পারেন
ELAPSED_REALTIME
ব্যবহার করুন। বিভিন্ন অ্যালার্মের ধরনগুলি নিম্নলিখিত বিভাগে আরও বিশদে বর্ণনা করা হয়েছে।
AlarmManager
ক্লাসের উপর ভিত্তি করে) আপনাকে আপনার আবেদনের জীবনকালের বাইরে সময়-ভিত্তিক ক্রিয়াকলাপ সম্পাদন করার একটি উপায় দেয়। উদাহরণস্বরূপ, আপনি একটি দীর্ঘ-চলমান অপারেশন শুরু করতে একটি অ্যালার্ম ব্যবহার করতে পারেন, যেমন আবহাওয়ার পূর্বাভাস ডাউনলোড করতে দিনে একবার একটি পরিষেবা শুরু করা।অ্যালার্মগুলির এই বৈশিষ্ট্যগুলি রয়েছে:
তারা আপনাকে নির্দিষ্ট সময় এবং/অথবা ব্যবধানে ইন্টেন্টগুলি ফায়ার করতে দেয়।
আপনি এগুলিকে ব্রডকাস্ট রিসিভারের সাথে ব্যবহার করতে পারেন কাজের সময় নির্ধারণের জন্য বা অন্য ক্রিয়াকলাপগুলি সম্পাদনের জন্য কাজের অনুরোধগুলি ।
এগুলি আপনার অ্যাপ্লিকেশনের বাইরে কাজ করে, তাই আপনি ইভেন্ট বা অ্যাকশন ট্রিগার করার জন্য ব্যবহার করতে পারেন এমনকি আপনার অ্যাপটি না চললেও এবং ডিভাইসটি নিজে ঘুমিয়ে থাকলেও৷
তারা আপনাকে আপনার অ্যাপের রিসোর্স প্রয়োজনীয়তা কমাতে সাহায্য করে। আপনি টাইমারের উপর নির্ভর না করে বা ক্রমাগত পরিষেবা চালু না করেই ক্রিয়াকলাপ নির্ধারণ করতে পারেন।
একটি সঠিক অ্যালার্ম সেট করুন
যখন একটি অ্যাপ একটি সঠিক অ্যালার্ম সেট করে, সিস্টেমটি ভবিষ্যতে কোনো সময়ে অ্যালার্ম সরবরাহ করে। অযৌক্তিক অ্যালার্মগুলি অ্যালার্ম বিতরণের সময় সম্পর্কে কিছু গ্যারান্টি প্রদান করে যখন ব্যাটারি-সংরক্ষণের বিধিনিষেধকে সম্মান করে যেমন ডোজ ৷
অযৌক্তিক অ্যালার্ম বিতরণের সময় কাস্টমাইজ করতে বিকাশকারীরা নিম্নলিখিত API গ্যারান্টিগুলি ব্যবহার করতে পারে।
একটি নির্দিষ্ট সময়ের পরে একটি অ্যালার্ম সরবরাহ করুন
যদি আপনার অ্যাপ set()
, setInexactRepeating()
, অথবা setAndAllowWhileIdle()
কল করে, সরবরাহ করা ট্রিগার সময়ের আগে অ্যালার্ম কখনই বন্ধ হয় না।
অ্যান্ড্রয়েড 12 (এপিআই লেভেল 31) এবং উচ্চতর ক্ষেত্রে, সিস্টেম সরবরাহ করা ট্রিগার সময়ের এক ঘন্টার মধ্যে অ্যালার্ম আহ্বান করে, যদি না ব্যাটারি সেভার বা ডোজ- এর মতো ব্যাটারি-সাশ্রয়ী বিধিনিষেধ কার্যকর না হয়।
একটি টাইম উইন্ডোর সময় একটি অ্যালার্ম সরবরাহ করুন
যদি আপনার অ্যাপ setWindow()
কল করে, সরবরাহকৃত ট্রিগার সময়ের আগে অ্যালার্ম কখনই বন্ধ হয় না। কোনো ব্যাটারি-সংরক্ষণ বিধিনিষেধ কার্যকর না হলে, প্রদত্ত ট্রিগার সময় থেকে শুরু করে নির্দিষ্ট সময় উইন্ডোর মধ্যে অ্যালার্ম বিতরণ করা হয়।
যদি আপনার অ্যাপটি Android 12 বা উচ্চতরকে লক্ষ্য করে, তাহলে সিস্টেমটি অন্তত 10 মিনিটের জন্য একটি সময়-উইন্ডোড অযৌক্তিক অ্যালার্মের আহ্বানকে বিলম্বিত করতে পারে। এই কারণে, 600000
এর নিচে windowLengthMillis
প্যারামিটার মান 600000
এ ক্লিপ করা হয়েছে।
মোটামুটি নিয়মিত বিরতিতে একটি পুনরাবৃত্তি অ্যালার্ম সরবরাহ করুন
যদি আপনার অ্যাপ কল করে setInexactRepeating()
, সিস্টেম একাধিক অ্যালার্ম আহ্বান করে:
- প্রদত্ত ট্রিগার সময় থেকে শুরু করে, নির্দিষ্ট সময় উইন্ডোর মধ্যে প্রথম অ্যালার্মটি বন্ধ হয়ে যায়।
- পরবর্তী অ্যালার্মগুলি সাধারণত নির্দিষ্ট সময় উইন্ডো শেষ হওয়ার পরে বন্ধ হয়ে যায়। অ্যালার্মের পরপর দুটি আহ্বানের মধ্যে সময় পরিবর্তিত হতে পারে।
একটি সঠিক অ্যালার্ম সেট করুন
সিস্টেমটি ভবিষ্যতে একটি সুনির্দিষ্ট মুহূর্তে একটি সঠিক অ্যালার্ম আহ্বান করে।
বেশিরভাগ অ্যাপ্লিকেশানগুলি বেশ কয়েকটি সাধারণ ব্যবহারের ক্ষেত্রে সম্পূর্ণ করতে অযৌক্তিক অ্যালার্ম ব্যবহার করে কার্য এবং ইভেন্টগুলি নির্ধারণ করতে পারে৷ যদি আপনার অ্যাপের মূল কার্যকারিতা একটি সুনির্দিষ্ট-সময়ের অ্যালার্মের উপর নির্ভর করে—যেমন একটি অ্যালার্ম ক্লক অ্যাপ বা একটি ক্যালেন্ডার অ্যাপের জন্য—তাহলে এর পরিবর্তে একটি সঠিক অ্যালার্ম ব্যবহার করা ঠিক।
সঠিক অ্যালার্মের প্রয়োজন নাও হতে পারে এমন ক্ষেত্রে ব্যবহার করুন
নিম্নলিখিত তালিকাটি সাধারণ ওয়ার্কফ্লোগুলি দেখায় যেগুলির জন্য সঠিক অ্যালার্মের প্রয়োজন নাও হতে পারে:
- আপনার অ্যাপের জীবদ্দশায় সময় নির্ধারণের ক্রিয়াকলাপ
-
Handler
ক্লাসে টাইমিং ক্রিয়াকলাপগুলি পরিচালনা করার জন্য বেশ কয়েকটি ভাল পদ্ধতি রয়েছে, যেমন আপনার অ্যাপটি জীবিত থাকাকালীন প্রতি n সেকেন্ডে কিছু কাজ করা:postAtTime()
এবংpostDelayed()
। মনে রাখবেন যে এই APIগুলি সিস্টেম আপটাইমের উপর নির্ভর করে এবং রিয়েল টাইমে নয়। - নির্ধারিত ব্যাকগ্রাউন্ডের কাজ, যেমন আপনার অ্যাপ আপডেট করা এবং লগ আপলোড করা
-
WorkManager
সময়-সংবেদনশীল পর্যায়ক্রমিক কাজের সময়সূচী করার একটি উপায় প্রদান করে। কাজের জন্য দানাদার রানটাইম সংজ্ঞায়িত করতে আপনি একটি পুনরাবৃত্তি ব্যবধান এবংflexInterval
(15 মিনিট সর্বনিম্ন) প্রদান করতে পারেন। - ব্যবহারকারী-নির্দিষ্ট ক্রিয়া যা একটি নির্দিষ্ট সময়ের পরে হওয়া উচিত (এমনকি নিষ্ক্রিয় অবস্থায় সিস্টেম থাকলেও)
- একটি অযৌক্তিক অ্যালার্ম ব্যবহার করুন। বিশেষভাবে,
setAndAllowWhileIdle()
কল করুন। - ব্যবহারকারী-নির্দিষ্ট ক্রিয়া যা একটি নির্দিষ্ট সময়ের পরে হওয়া উচিত
- একটি অযৌক্তিক অ্যালার্ম ব্যবহার করুন। বিশেষত, কল
set()
। - ব্যবহারকারী-নির্দিষ্ট ক্রিয়া যা একটি নির্দিষ্ট সময় উইন্ডোর মধ্যে ঘটতে পারে
- একটি অযৌক্তিক অ্যালার্ম ব্যবহার করুন। বিশেষ করে,
setWindow()
কল করুন। মনে রাখবেন, যদি আপনার অ্যাপটি Android 12 বা উচ্চতরকে লক্ষ্য করে, তাহলে সবচেয়ে ছোট অনুমোদিত উইন্ডোর দৈর্ঘ্য 10 মিনিট।
একটি সঠিক অ্যালার্ম সেট করার উপায়
আপনার অ্যাপ নিম্নলিখিত পদ্ধতিগুলির মধ্যে একটি ব্যবহার করে সঠিক অ্যালার্ম সেট করতে পারে৷ এই পদ্ধতিগুলি এমনভাবে অর্ডার করা হয়েছে যে তালিকার নীচের কাছাকাছি থাকাগুলি আরও সময়-সমালোচনামূলক কাজগুলি পরিবেশন করে তবে আরও সিস্টেম সংস্থানগুলির দাবি করে৷
-
setExact()
ভবিষ্যতে প্রায় সুনির্দিষ্ট সময়ে একটি অ্যালার্ম চালু করুন, যতক্ষণ না অন্যান্য ব্যাটারি-সংরক্ষণ ব্যবস্থা কার্যকর না হয়।
সঠিক অ্যালার্ম সেট করতে এই পদ্ধতিটি ব্যবহার করুন, যদি না আপনার অ্যাপের কাজ ব্যবহারকারীর জন্য সময়-গুরুত্বপূর্ণ হয়।
-
setExactAndAllowWhileIdle()
ভবিষ্যতে প্রায় সুনির্দিষ্ট সময়ে একটি অ্যালার্ম আহ্বান করুন, এমনকি যদি ব্যাটারি-সংরক্ষণ ব্যবস্থা কার্যকর হয়।
-
setAlarmClock()
ভবিষ্যতে একটি সুনির্দিষ্ট সময়ে একটি অ্যালার্ম আহ্বান করুন। যেহেতু এই অ্যালার্মগুলি ব্যবহারকারীদের কাছে অত্যন্ত দৃশ্যমান, সিস্টেম কখনই তাদের ডেলিভারির সময় সামঞ্জস্য করে না। সিস্টেম এই অ্যালার্মগুলিকে সবচেয়ে গুরুত্বপূর্ণ হিসাবে চিহ্নিত করে এবং অ্যালার্মগুলি সরবরাহ করার জন্য প্রয়োজনে কম-পাওয়ার মোডগুলি ছেড়ে দেয়।
সিস্টেম সম্পদ খরচ
যখন সিস্টেমটি আপনার অ্যাপ সেট করা সঠিক অ্যালার্মগুলিকে ট্রিগার করে, তখন ডিভাইসটি ব্যাটারি লাইফের মতো প্রচুর সম্পদ ব্যবহার করে, বিশেষ করে যদি এটি পাওয়ার-সেভিং মোডে থাকে। তদুপরি, সংস্থানগুলি আরও দক্ষতার সাথে ব্যবহার করার জন্য সিস্টেম সহজেই এই অনুরোধগুলি ব্যাচ করতে পারে না।
এটি অত্যন্ত সুপারিশ করা হয় যে আপনি যখনই সম্ভব একটি অযৌক্তিক অ্যালার্ম তৈরি করুন৷ দীর্ঘ কাজ সম্পাদন করতে, আপনার অ্যালার্মের BroadcastReceiver
থেকে WorkManager
বা JobScheduler
ব্যবহার করে সময়সূচী করুন। ডিভাইসটি ডোজে থাকা অবস্থায় কাজ করতে, setAndAllowWhileIdle()
ব্যবহার করে একটি অযৌক্তিক অ্যালার্ম তৈরি করুন এবং অ্যালার্ম থেকে একটি কাজ শুরু করুন।
উপযুক্ত সঠিক অ্যালার্ম অনুমতি ঘোষণা করুন
যদি আপনার অ্যাপটি Android 12 বা তার বেশির দিকে লক্ষ্য করে, তাহলে আপনাকে অবশ্যই "অ্যালার্ম এবং রিমাইন্ডার" বিশেষ অ্যাপ অ্যাক্সেস পেতে হবে। এটি করতে, নিম্নলিখিত কোড স্নিপেটে দেখানো হিসাবে আপনার অ্যাপের ম্যানিফেস্ট ফাইলে SCHEDULE_EXACT_ALARM
অনুমতি ঘোষণা করুন:
<manifest ...> <uses-permission android:name="android.permission.SCHEDULE_EXACT_ALARM"/> <application ...> ... </application> </manifest>
যদি আপনার অ্যাপটি Android 13 (API স্তর 33) বা উচ্চতরকে লক্ষ্য করে, তাহলে আপনার কাছে SCHEDULE_EXACT_ALARM
বা USE_EXACT_ALARM
অনুমতি ঘোষণা করার বিকল্প রয়েছে।
<manifest ...> <uses-permission android:name="android.permission.USE_EXACT_ALARM"/> <application ...> ... </application> </manifest>
যদিও SCHEDULE_EXACT_ALARM
এবং USE_EXACT_ALARM
উভয় অনুমতিই একই ক্ষমতার সংকেত দেয়, সেগুলি আলাদাভাবে দেওয়া হয় এবং বিভিন্ন ব্যবহারের ক্ষেত্রে সমর্থন করে। আপনার অ্যাপের সঠিক অ্যালার্ম ব্যবহার করা উচিত এবং SCHEDULE_EXACT_ALARM
বা USE_EXACT_ALARM
অনুমতি ঘোষণা করা উচিত, শুধুমাত্র তখনই যদি আপনার অ্যাপে ব্যবহারকারী-মুখী ফাংশনের জন্য সঠিকভাবে সময়মতো পদক্ষেপের প্রয়োজন হয়।
USE_EXACT_ALARM
- স্বয়ংক্রিয়ভাবে মঞ্জুর করা হয়েছে
- ব্যবহারকারী দ্বারা প্রত্যাহার করা যাবে না
- একটি আসন্ন Google Play নীতি সাপেক্ষে
- সীমিত ব্যবহারের ক্ষেত্রে
SCHEDULE_EXACT_ALARM
- ব্যবহারকারী দ্বারা মঞ্জুর
- ব্যবহারের ক্ষেত্রে বিস্তৃত সেট
- অ্যাপগুলিকে নিশ্চিত করা উচিত যে অনুমতি প্রত্যাহার করা হয়নি
SCHEDULE_EXACT_ALARM
অনুমতিটি Android 13 (API স্তর 33) এবং উচ্চতর টার্গেট করা অ্যাপগুলির নতুন ইনস্টলের জন্য পূর্ব-মঞ্জুর করা হয় না। যদি কোনও ব্যবহারকারী ব্যাকআপ-এন্ড-রিস্টোর অপারেশনের মাধ্যমে Android 14 চালিত কোনও ডিভাইসে অ্যাপ ডেটা স্থানান্তর করে, তাহলে নতুন ডিভাইসে SCHEDULE_EXACT_ALARM
অনুমতি অস্বীকার করা হবে। যাইহোক, যদি একটি বিদ্যমান অ্যাপ ইতিমধ্যেই এই অনুমতি থাকে, তবে ডিভাইসটি Android 14 এ আপগ্রেড করার সময় এটি পূর্ব-মঞ্জুর করা হবে।
দ্রষ্টব্য : যদি সঠিক অ্যালার্মটি একটি OnAlarmListener
অবজেক্ট ব্যবহার করে সেট করা হয়, যেমন setExact
API সহ, SCHEDULE_EXACT_ALARM
অনুমতির প্রয়োজন হয় না৷
SCHEDULE_EXACT_ALARM
অনুমতি ব্যবহার করে৷
USE_EXACT_ALARM
বিপরীতে, SCHEDULE_EXACT_ALARM
অনুমতি অবশ্যই ব্যবহারকারীকে দিতে হবে। ব্যবহারকারী এবং সিস্টেম উভয়ই SCHEDULE_EXACT_ALARM
অনুমতি প্রত্যাহার করতে পারে৷
আপনার অ্যাপে অনুমতি দেওয়া হয়েছে কিনা তা পরীক্ষা করতে, সঠিক অ্যালার্ম সেট করার চেষ্টা করার আগে canScheduleExactAlarms()
কল করুন। যখন আপনার অ্যাপ্লিকেশানের জন্য SCHEDULE_EXACT_ALARM
অনুমতি প্রত্যাহার করা হয়, তখন আপনার অ্যাপ্লিকেশান বন্ধ হয়ে যায় এবং ভবিষ্যতের সমস্ত সঠিক অ্যালার্ম বাতিল হয়ে যায়৷ এর মানে হল canScheduleExactAlarms()
দ্বারা প্রত্যাবর্তিত মান আপনার অ্যাপের সমগ্র জীবনচক্রের জন্য বৈধ থাকে।
যখন আপনার অ্যাপে SCHEDULE_EXACT_ALARMS
অনুমতি দেওয়া হয়, তখন সিস্টেম এটিকে ACTION_SCHEDULE_EXACT_ALARM_PERMISSION_STATE_CHANGED
সম্প্রচার পাঠায়। আপনার অ্যাপের একটি ব্রডকাস্ট রিসিভার প্রয়োগ করা উচিত যা নিম্নলিখিতগুলি করে:
- নিশ্চিত করে যে আপনার অ্যাপে এখনও বিশেষ অ্যাপ অ্যাক্সেস আছে। এটি করতে,
canScheduleExactAlarms()
কল করুন। এই চেকটি আপনার অ্যাপটিকে সেই ক্ষেত্রে থেকে রক্ষা করে যেখানে ব্যবহারকারী আপনার অ্যাপটিকে অনুমতি দেয়, তারপর প্রায় সঙ্গে সঙ্গেই এটি প্রত্যাহার করে। - আপনার অ্যাপ্লিকেশানের বর্তমান অবস্থার উপর ভিত্তি করে প্রয়োজনীয় যেকোনও সঠিক অ্যালার্মগুলি পুনঃনির্ধারণ করে৷ এই যুক্তিটি
ACTION_BOOT_COMPLETED
সম্প্রচার গ্রহণ করার সময় আপনার অ্যাপ যা করে তার অনুরূপ হওয়া উচিত।
ব্যবহারকারীদেরকে SCHEDULE_EXACT_ALARM
অনুমতি দিতে বলুন
প্রয়োজনে, আপনি ব্যবহারকারীদের সিস্টেম সেটিংসে অ্যালার্ম এবং অনুস্মারক স্ক্রিনে পাঠাতে পারেন, যেমন চিত্র 1 এ দেখানো হয়েছে। এটি করতে, নিম্নলিখিত পদক্ষেপগুলি সম্পূর্ণ করুন:
- আপনার অ্যাপের UI-তে, ব্যবহারকারীকে ব্যাখ্যা করুন কেন আপনার অ্যাপকে সঠিক অ্যালার্ম নির্ধারণ করতে হবে।
-
ACTION_REQUEST_SCHEDULE_EXACT_ALARM
অভিপ্রায় ক্রিয়া অন্তর্ভুক্ত এমন একটি অভিপ্রায় আহ্বান করুন৷
একটি পুনরাবৃত্তি অ্যালার্ম সেট করুন
পুনরাবৃত্ত অ্যালার্ম সিস্টেমকে আপনার অ্যাপকে একটি পুনরাবৃত্ত সময়সূচীতে জানানোর অনুমতি দেয়।
একটি খারাপভাবে ডিজাইন করা অ্যালার্ম ব্যাটারি নিষ্কাশনের কারণ হতে পারে এবং সার্ভারে একটি উল্লেখযোগ্য লোড রাখতে পারে। এই কারণে, Android 4.4 (API স্তর 19) এবং উচ্চতর, সমস্ত পুনরাবৃত্তি করা অ্যালার্মগুলি অযৌক্তিক অ্যালার্ম ৷
একটি পুনরাবৃত্তি অ্যালার্মের নিম্নলিখিত বৈশিষ্ট্য রয়েছে:
একটি অ্যালার্ম টাইপ। আরও আলোচনার জন্য, একটি অ্যালার্ম টাইপ চয়ন করুন দেখুন।
একটি ট্রিগার সময়. আপনার উল্লেখ করা ট্রিগার সময় অতীতে থাকলে, অ্যালার্ম অবিলম্বে ট্রিগার হয়।
অ্যালার্মের ব্যবধান। উদাহরণস্বরূপ, দিনে একবার, প্রতি ঘন্টায়, বা প্রতি 5 মিনিটে।
একটি মুলতুবি অভিপ্রায় যেটি যখন অ্যালার্ম ট্রিগার হয় তখন ফায়ার হয়৷ আপনি যখন একই মুলতুবি থাকা অভিপ্রায় ব্যবহার করে একটি দ্বিতীয় অ্যালার্ম সেট করেন, তখন এটি আসল অ্যালার্মকে প্রতিস্থাপন করে।
একটি PendingIntent()
বাতিল করতে, অভিপ্রায়ের একটি উদাহরণ পেতে PendingIntent.getService()
এ FLAG_NO_CREATE
পাস করুন (যদি এটি বিদ্যমান থাকে), তারপর সেই অভিপ্রায়টি AlarmManager.cancel()
এ পাস করুন
কোটলিন
val alarmManager = context.getSystemService(Context.ALARM_SERVICE) as? AlarmManager val pendingIntent = PendingIntent.getService(context, requestId, intent, PendingIntent.FLAG_NO_CREATE) if (pendingIntent != null && alarmManager != null) { alarmManager.cancel(pendingIntent) }
জাভা
AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); PendingIntent pendingIntent = PendingIntent.getService(context, requestId, intent, PendingIntent.FLAG_NO_CREATE); if (pendingIntent != null && alarmManager != null) { alarmManager.cancel(pendingIntent); }
একটি অ্যালার্ম টাইপ চয়ন করুন
একটি পুনরাবৃত্তি অ্যালার্ম ব্যবহার করার ক্ষেত্রে প্রথম বিবেচ্য বিষয়গুলির মধ্যে একটি হল এর ধরনটি কী হওয়া উচিত৷
অ্যালার্মের জন্য দুটি সাধারণ ঘড়ির ধরন রয়েছে: "বিগত রিয়েল টাইম" এবং "রিয়েল টাইম ক্লক" (RTC)। অতিবাহিত রিয়েল টাইম একটি রেফারেন্স হিসাবে "সিস্টেম বুট থেকে সময়" ব্যবহার করে এবং বাস্তব সময় ঘড়ি UTC (ওয়াল ঘড়ি) সময় ব্যবহার করে। এর মানে হল যে অতিবাহিত বাস্তব সময় সময় অতিবাহিত হওয়ার উপর ভিত্তি করে একটি অ্যালার্ম সেট করার জন্য উপযুক্ত (উদাহরণস্বরূপ, একটি অ্যালার্ম যা প্রতি 30 সেকেন্ডে ফায়ার হয়) কারণ এটি সময় অঞ্চল বা লোকেল দ্বারা প্রভাবিত হয় না। রিয়েল টাইম ঘড়ির ধরন বর্তমান লোকেলের উপর নির্ভরশীল অ্যালার্মগুলির জন্য আরও উপযুক্ত।
উভয় প্রকারের একটি "ওয়েকআপ" সংস্করণ রয়েছে, যা স্ক্রীন বন্ধ থাকলে ডিভাইসের CPU কে জাগিয়ে তুলতে বলে। এটি নিশ্চিত করে যে অ্যালার্ম নির্ধারিত সময়ে বাজবে। আপনার অ্যাপের সময় নির্ভরতা থাকলে এটি কার্যকর। উদাহরণস্বরূপ, যদি একটি নির্দিষ্ট অপারেশন করার জন্য এটির একটি সীমিত উইন্ডো থাকে। আপনি যদি আপনার অ্যালার্ম প্রকারের ওয়েকআপ সংস্করণটি ব্যবহার না করেন, তাহলে আপনার ডিভাইসটি পরবর্তী জেগে উঠলে সমস্ত পুনরাবৃত্তি করা অ্যালার্মগুলি ফায়ার হবে৷
আপনি যদি একটি নির্দিষ্ট ব্যবধানে (উদাহরণস্বরূপ, প্রতি আধ ঘন্টা) আপনার অ্যালার্ম বাজানোর প্রয়োজন হয়, তাহলে অতিবাহিত রিয়েল টাইম প্রকারগুলির একটি ব্যবহার করুন। সাধারণভাবে, এটিই ভাল পছন্দ।
দিনের একটি নির্দিষ্ট সময়ে আপনার অ্যালার্ম ফায়ার করার প্রয়োজন হলে, ঘড়ি-ভিত্তিক রিয়েল টাইম ঘড়ির ধরনগুলির মধ্যে একটি বেছে নিন। উল্লেখ্য, যাইহোক, এই পদ্ধতির কিছু ত্রুটি থাকতে পারে। অ্যাপটি অন্য লোকেলে ভালোভাবে অনুবাদ নাও করতে পারে এবং ব্যবহারকারী যদি ডিভাইসের সময় সেটিং পরিবর্তন করে, তাহলে এটি আপনার অ্যাপে অপ্রত্যাশিত আচরণের কারণ হতে পারে। একটি রিয়েল টাইম ঘড়ি অ্যালার্ম টাইপ ব্যবহার করাও ভালভাবে পরিমাপ করে না, যেমন উপরে আলোচনা করা হয়েছে। আমরা সুপারিশ করি যে আপনি যদি পারেন তাহলে একটি "বিগত রিয়েল টাইম" অ্যালার্ম ব্যবহার করুন৷
এখানে প্রকারের তালিকা রয়েছে:
ELAPSED_REALTIME
: ডিভাইসটি বুট হওয়ার পর থেকে কত সময়ের জন্য মুলতুবি থাকা অভিপ্রায়কে ফায়ার করে, কিন্তু ডিভাইসটিকে জাগিয়ে তোলে না। অতিবাহিত সময়ের মধ্যে ডিভাইসটি ঘুমিয়ে থাকা যেকোনো সময় অন্তর্ভুক্ত।ELAPSED_REALTIME_WAKEUP
: ডিভাইস বুট হওয়ার পর থেকে নির্দিষ্ট সময় অতিবাহিত হওয়ার পরে ডিভাইসটিকে জাগিয়ে তোলে এবং মুলতুবি থাকা অভিপ্রায়কে ফায়ার করে।RTC
: নির্দিষ্ট সময়ে মুলতুবি অভিপ্রায় ফায়ার করে কিন্তু ডিভাইসটিকে জাগিয়ে তোলে না।RTC_WAKEUP
: নির্দিষ্ট সময়ে মুলতুবি থাকা উদ্দেশ্য ফায়ার করতে ডিভাইসটিকে জাগিয়ে তোলে।
অতিবাহিত রিয়েল টাইম অ্যালার্মের উদাহরণ
এখানে ELAPSED_REALTIME_WAKEUP
ব্যবহারের কিছু উদাহরণ রয়েছে৷
30 মিনিটের মধ্যে অ্যালার্ম ফায়ার করার জন্য ডিভাইসটিকে জাগিয়ে দিন এবং তার পরে প্রতি 30 মিনিটে:
কোটলিন
// Hopefully your alarm will have a lower frequency than this! alarmMgr?.setInexactRepeating( AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + AlarmManager.INTERVAL_HALF_HOUR, AlarmManager.INTERVAL_HALF_HOUR, alarmIntent )
জাভা
// Hopefully your alarm will have a lower frequency than this! alarmMgr.setInexactRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + AlarmManager.INTERVAL_HALF_HOUR, AlarmManager.INTERVAL_HALF_HOUR, alarmIntent);
এক মিনিটের মধ্যে একটি ওয়ান-টাইম (পুনরাবৃত্তি না হওয়া) অ্যালার্ম ফায়ার করতে ডিভাইসটিকে জাগাও:
কোটলিন
private var alarmMgr: AlarmManager? = null private lateinit var alarmIntent: PendingIntent ... alarmMgr = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager alarmIntent = Intent(context, AlarmReceiver::class.java).let { intent -> PendingIntent.getBroadcast(context, 0, intent, 0) } alarmMgr?.set( AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + 60 * 1000, alarmIntent )
জাভা
private AlarmManager alarmMgr; private PendingIntent alarmIntent; ... alarmMgr = (AlarmManager)context.getSystemService(Context.ALARM_SERVICE); Intent intent = new Intent(context, AlarmReceiver.class); alarmIntent = PendingIntent.getBroadcast(context, 0, intent, 0); alarmMgr.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + 60 * 1000, alarmIntent);
বাস্তব সময় ঘড়ি অ্যালার্ম উদাহরণ
এখানে RTC_WAKEUP
ব্যবহারের কিছু উদাহরণ রয়েছে।
আনুমানিক 2:00 pm এ অ্যালার্ম ফায়ার করার জন্য ডিভাইসটিকে জাগিয়ে দিন এবং একই সময়ে দিনে একবার পুনরাবৃত্তি করুন:
কোটলিন
// Set the alarm to start at approximately 2:00 p.m. val calendar: Calendar = Calendar.getInstance().apply { timeInMillis = System.currentTimeMillis() set(Calendar.HOUR_OF_DAY, 14) } // With setInexactRepeating(), you have to use one of the AlarmManager interval // constants--in this case, AlarmManager.INTERVAL_DAY. alarmMgr?.setInexactRepeating( AlarmManager.RTC_WAKEUP, calendar.timeInMillis, AlarmManager.INTERVAL_DAY, alarmIntent )
জাভা
// Set the alarm to start at approximately 2:00 p.m. Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(System.currentTimeMillis()); calendar.set(Calendar.HOUR_OF_DAY, 14); // With setInexactRepeating(), you have to use one of the AlarmManager interval // constants--in this case, AlarmManager.INTERVAL_DAY. alarmMgr.setInexactRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), AlarmManager.INTERVAL_DAY, alarmIntent);
ঠিক সকাল ৮:৩০ মিনিটে এবং তার পর প্রতি ২০ মিনিটে অ্যালার্ম বাজানোর জন্য ডিভাইসটিকে জাগাও:
কোটলিন
private var alarmMgr: AlarmManager? = null private lateinit var alarmIntent: PendingIntent ... alarmMgr = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager alarmIntent = Intent(context, AlarmReceiver::class.java).let { intent -> PendingIntent.getBroadcast(context, 0, intent, 0) } // Set the alarm to start at 8:30 a.m. val calendar: Calendar = Calendar.getInstance().apply { timeInMillis = System.currentTimeMillis() set(Calendar.HOUR_OF_DAY, 8) set(Calendar.MINUTE, 30) } // setRepeating() lets you specify a precise custom interval--in this case, // 20 minutes. alarmMgr?.setRepeating( AlarmManager.RTC_WAKEUP, calendar.timeInMillis, 1000 * 60 * 20, alarmIntent )
জাভা
private AlarmManager alarmMgr; private PendingIntent alarmIntent; ... alarmMgr = (AlarmManager)context.getSystemService(Context.ALARM_SERVICE); Intent intent = new Intent(context, AlarmReceiver.class); alarmIntent = PendingIntent.getBroadcast(context, 0, intent, 0); // Set the alarm to start at 8:30 a.m. Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(System.currentTimeMillis()); calendar.set(Calendar.HOUR_OF_DAY, 8); calendar.set(Calendar.MINUTE, 30); // setRepeating() lets you specify a precise custom interval--in this case, // 20 minutes. alarmMgr.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), 1000 * 60 * 20, alarmIntent);
আপনার অ্যালার্ম কতটা সুনির্দিষ্ট হওয়া দরকার তা নির্ধারণ করুন
পূর্বে বর্ণিত হিসাবে, অ্যালার্মের ধরন নির্বাচন করা প্রায়শই একটি অ্যালার্ম তৈরির প্রথম পদক্ষেপ। আরও একটি পার্থক্য হল আপনার অ্যালার্মটি কতটা সুনির্দিষ্ট হওয়া দরকার। বেশিরভাগ অ্যাপের জন্য, setInexactRepeating()
হল সঠিক পছন্দ। আপনি যখন এই পদ্ধতিটি ব্যবহার করেন, তখন Android একাধিক অযৌক্তিক পুনরাবৃত্তিকারী অ্যালার্ম সিঙ্ক্রোনাইজ করে এবং একই সময়ে সেগুলি ফায়ার করে। এটি ব্যাটারির ড্রেন হ্রাস করে।
সম্ভব হলে সঠিক অ্যালার্ম ব্যবহার এড়িয়ে চলুন। যাইহোক, বিরল অ্যাপের জন্য কঠোর সময়ের প্রয়োজনীয়তা রয়েছে, আপনি setRepeating()
কল করে একটি সঠিক অ্যালার্ম সেট করতে পারেন।
setInexactRepeating()
এর সাহায্যে আপনি setRepeating()
দিয়ে আপনি যেভাবে কাস্টম অন্তর নির্দিষ্ট করতে পারবেন না। আপনাকে বিরতি ধ্রুবকগুলির মধ্যে একটি যেমন INTERVAL_FIFTEEN_MINUTES
, INTERVAL_DAY
এবং আরও অনেক কিছু ব্যবহার করতে হবে। সম্পূর্ণ তালিকার জন্য AlarmManager
দেখুন।
একটি অ্যালার্ম বাতিল করুন
আপনার অ্যাপ্লিকেশনটির উপর নির্ভর করে আপনি অ্যালার্ম বাতিল করার ক্ষমতা অন্তর্ভুক্ত করতে চাইতে পারেন। একটি অ্যালার্ম বাতিল করতে, অ্যালার্ম ম্যানেজারের কাছে cancel()
কল করুন, আপনি আর PendingIntent
চালাতে চান না। যেমন:
কোটলিন
// If the alarm has been set, cancel it. alarmMgr?.cancel(alarmIntent)
জাভা
// If the alarm has been set, cancel it. if (alarmMgr!= null) { alarmMgr.cancel(alarmIntent); }
ডিভাইসটি পুনরায় চালু হয়ে গেলে একটি অ্যালার্ম শুরু করুন
ডিফল্টরূপে, কোনও ডিভাইস বন্ধ হয়ে গেলে সমস্ত অ্যালার্ম বাতিল করা হয়। এটি ঘটতে বাধা দেওয়ার জন্য, ব্যবহারকারী যদি ডিভাইসটি পুনরায় বুট করে তবে আপনি স্বয়ংক্রিয়ভাবে পুনরাবৃত্তি অ্যালার্ম পুনরায় চালু করতে আপনার অ্যাপ্লিকেশনটি ডিজাইন করতে পারেন। এটি নিশ্চিত করে যে AlarmManager
ব্যবহারকারীকে ম্যানুয়ালি অ্যালার্ম পুনরায় চালু করার প্রয়োজন ছাড়াই তার কাজটি চালিয়ে যাবে।
এখানে পদক্ষেপগুলি রয়েছে:
আপনার অ্যাপ্লিকেশনটির ম্যানিফেস্টে
RECEIVE_BOOT_COMPLETED
অনুমতি সেট করুন। এটি আপনার অ্যাপ্লিকেশনটিকে সিস্টেম বুট করার পরে সম্প্রচারিতACTION_BOOT_COMPLETED
গ্রহণ করার অনুমতি দেয় (এটি কেবলমাত্র যদি ইতিমধ্যে ব্যবহারকারী দ্বারা অ্যাপ্লিকেশনটি ইতিমধ্যে চালু করা হয় তবে এটি কেবল কাজ করে):<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
সম্প্রচারটি গ্রহণের জন্য একটি
BroadcastReceiver
প্রয়োগ করুন:কোটলিন
class SampleBootReceiver : BroadcastReceiver() { override fun onReceive(context: Context, intent: Intent) { if (intent.action == "android.intent.action.BOOT_COMPLETED") { // Set the alarm here. } } }
জাভা
public class SampleBootReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (intent.getAction().equals("android.intent.action.BOOT_COMPLETED")) { // Set the alarm here. } } }
ACTION_BOOT_COMPLETED
অ্যাকশনে ফিল্টার করে এমন একটি অভিপ্রায় ফিল্টার সহ আপনার অ্যাপের ম্যানিফেস্ট ফাইলটিতে রিসিভার যুক্ত করুন:<receiver android:name=".SampleBootReceiver" android:enabled="false"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED"></action> </intent-filter> </receiver>
লক্ষ্য করুন যে ম্যানিফেস্টে, বুট রিসিভারটি
android:enabled="false"
। এর অর্থ হ'ল অ্যাপ্লিকেশনটি স্পষ্টভাবে এটি সক্ষম না করে রিসিভারকে কল করা হবে না। এটি বুট রিসিভারকে অযথা কল করা থেকে বাধা দেয়। আপনি নিম্নলিখিত হিসাবে একটি রিসিভার সক্ষম করতে পারেন (উদাহরণস্বরূপ, যদি ব্যবহারকারী একটি অ্যালার্ম সেট করে):কোটলিন
val receiver = ComponentName(context, SampleBootReceiver::class.java) context.packageManager.setComponentEnabledSetting( receiver, PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP )
জাভা
ComponentName receiver = new ComponentName(context, SampleBootReceiver.class); PackageManager pm = context.getPackageManager(); pm.setComponentEnabledSetting(receiver, PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP);
আপনি একবার রিসিভারটিকে এইভাবে সক্ষম করার পরে, এটি সক্ষম থাকবে, এমনকি ব্যবহারকারী ডিভাইসটি পুনরায় বুট করে। অন্য কথায়, প্রোগ্রামিকভাবে রিসিভারটি সক্ষম করা এমনকি রিবুটগুলি জুড়ে এমনকি ম্যানিফেস্ট সেটিংসকে ওভাররাইড করে। আপনার অ্যাপ্লিকেশন এটি অক্ষম না করা পর্যন্ত রিসিভার সক্ষম থাকবে। আপনি নিম্নলিখিত হিসাবে একটি রিসিভার (উদাহরণস্বরূপ, যদি কোনও অ্যালার্ম বাতিল করে) অক্ষম করতে পারেন:
কোটলিন
val receiver = ComponentName(context, SampleBootReceiver::class.java) context.packageManager.setComponentEnabledSetting( receiver, PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP )
জাভা
ComponentName receiver = new ComponentName(context, SampleBootReceiver.class); PackageManager pm = context.getPackageManager(); pm.setComponentEnabledSetting(receiver, PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP);
ডিভাইসটি ডোজ মোডে থাকাকালীন অ্যালার্মগুলি প্রার্থনা করুন
অ্যান্ড্রয়েড 6.0 (এপিআই স্তর 23) চালানো ডিভাইসগুলি ডোজ মোডকে সমর্থন করে, যা ডিভাইসের ব্যাটারির আয়ু প্রসারিত করতে সহায়তা করে। ডিভাইসটি ডোজ মোডে থাকলে অ্যালার্মগুলি গুলি চালায় না যে কোনও নির্ধারিত অ্যালার্মগুলি ডিভাইসটি ডোজ থেকে বেরিয়ে না যাওয়া পর্যন্ত স্থগিত করা হয়। ডিভাইসটি অলস থাকলেও যদি আপনার কাজ শেষ করতে হয় তবে বেশ কয়েকটি বিকল্প উপলব্ধ রয়েছে:
একটি সঠিক অ্যালার্ম সেট করুন।
ব্যাকগ্রাউন্ড কাজ সম্পাদনের জন্য নির্মিত ওয়ার্কম্যানেজার এপিআই ব্যবহার করুন। আপনি নির্দেশ করতে পারেন যে সিস্টেমটি আপনার কাজটি ত্বরান্বিত করা উচিত যাতে কাজটি যত তাড়াতাড়ি সম্ভব শেষ হয়। আরও তথ্যের জন্য, ওয়ার্কম্যানেজারের সাথে তফসিল কার্যগুলি দেখুন
সর্বোত্তম অনুশীলন
আপনার পুনরাবৃত্তি অ্যালার্মটি ডিজাইনে আপনি যে প্রতিটি পছন্দ করেন তা আপনার অ্যাপ্লিকেশন কীভাবে সিস্টেম সংস্থানগুলি ব্যবহার করে (বা অপব্যবহার) ব্যবহার করে তার পরিণতি হতে পারে। উদাহরণস্বরূপ, একটি জনপ্রিয় অ্যাপ্লিকেশন কল্পনা করুন যা কোনও সার্ভারের সাথে সিঙ্ক করে। যদি সিঙ্ক অপারেশনটি ঘড়ির সময় এবং অ্যাপ্লিকেশনটির প্রতিটি উদাহরণের উপর ভিত্তি করে 11:00 pm এ সিঙ্ক হয় তবে সার্ভারের লোডের ফলে উচ্চ বিলম্ব বা এমনকি "পরিষেবা অস্বীকার" হতে পারে। অ্যালার্ম ব্যবহার করে এই সেরা অনুশীলনগুলি অনুসরণ করুন:
পুনরাবৃত্তি অ্যালার্মের ফলে ট্রিগার যে কোনও নেটওয়ার্ক অনুরোধগুলিতে এলোমেলো (জিটার) যুক্ত করুন:
অ্যালার্ম যখন ট্রিগার করে তখন কোনও স্থানীয় কাজ করুন। "স্থানীয় কাজ" এর অর্থ এমন কোনও কিছু যা কোনও সার্ভারকে আঘাত করে না বা সার্ভার থেকে ডেটা প্রয়োজন।
একই সময়ে, অ্যালার্মটি নির্ধারণ করুন যাতে কিছু এলোমেলো সময়কালে নেটওয়ার্কের অনুরোধগুলি আগুনের জন্য অনুরোধ করে।
আপনার অ্যালার্ম ফ্রিকোয়েন্সি সর্বনিম্ন রাখুন।
অকারণে ডিভাইসটি জাগ্রত করবেন না (এই আচরণটি অ্যালার্মের ধরণ দ্বারা নির্ধারিত হয়, যেমন একটি অ্যালার্ম প্রকার চয়ন করুন )।
আপনার অ্যালার্মের ট্রিগার সময়টিকে আরও সুনির্দিষ্ট করার চেয়ে আরও সুনির্দিষ্ট করবেন না।
setRepeating()
setInexactRepeating()
() ব্যবহার করুন। আপনি যখনsetInexactRepeating()
ব্যবহার করেন, অ্যান্ড্রয়েড একাধিক অ্যাপ্লিকেশন থেকে পুনরাবৃত্তি অ্যালার্মগুলি সিঙ্ক্রোনাইজ করে এবং একই সাথে সেগুলি আগুন দেয়। এটি সিস্টেমকে অবশ্যই ডিভাইসটি জাগিয়ে তুলতে মোট বার সংখ্যা হ্রাস করে, এইভাবে ব্যাটারিতে ড্রেন হ্রাস করে। অ্যান্ড্রয়েড 4.4 (এপিআই স্তর 19) হিসাবে, সমস্ত পুনরাবৃত্তি অ্যালার্মগুলি অবিচ্ছিন্ন অ্যালার্ম । মনে রাখবেন যেsetInexactRepeating()
setRepeating()
চেয়ে উন্নতি হওয়ার সময়, এটি এখনও কোনও সার্ভারকে অভিভূত করতে পারে যদি কোনও অ্যাপের প্রতিটি উদাহরণ একই সময়ে সার্ভারকে আঘাত করে। অতএব, নেটওয়ার্ক অনুরোধগুলির জন্য, পূর্বে আলোচিত হিসাবে আপনার অ্যালার্মগুলিতে কিছু এলোমেলো যোগ করুন।সম্ভব হলে ঘড়ির সময় আপনার অ্যালার্মটি বেস করা এড়িয়ে চলুন।
একটি সুনির্দিষ্ট ট্রিগার সময়ের উপর ভিত্তি করে অ্যালার্মগুলি পুনরাবৃত্তি করা ভাল স্কেল করে না। আপনি যদি পারেন তবে
ELAPSED_REALTIME
ব্যবহার করুন। বিভিন্ন অ্যালার্ম প্রকারগুলি নিম্নলিখিত বিভাগে আরও বিশদে বর্ণিত হয়েছে।