পূর্ববর্তী রিলিজের মতো, Android 15-এ এমন আচরণের পরিবর্তন অন্তর্ভুক্ত রয়েছে যা আপনার অ্যাপকে প্রভাবিত করতে পারে। নিম্নলিখিত আচরণ পরিবর্তনগুলি শুধুমাত্র Android 15 বা উচ্চতর সংস্করণগুলিকে লক্ষ্য করে এমন অ্যাপগুলিতে প্রযোজ্য৷ যদি আপনার অ্যাপটি Android 15 বা উচ্চতরকে লক্ষ্য করে থাকে, তাহলে প্রযোজ্য ক্ষেত্রে এই আচরণগুলিকে সঠিকভাবে সমর্থন করার জন্য আপনার অ্যাপটি সংশোধন করা উচিত।
আপনার অ্যাপের targetSdkVersion নির্বিশেষে Android 15-এ চলমান সমস্ত অ্যাপকে প্রভাবিত করে এমন আচরণের পরিবর্তনের তালিকাটিও পর্যালোচনা করতে ভুলবেন না।
মূল কার্যকারিতা
Android 15 অ্যান্ড্রয়েড সিস্টেমের বিভিন্ন মূল ক্ষমতাগুলিকে সংশোধন বা প্রসারিত করে।
ফোরগ্রাউন্ড পরিষেবাতে পরিবর্তন
আমরা Android 15 এর সাথে ফোরগ্রাউন্ড পরিষেবাগুলিতে নিম্নলিখিত পরিবর্তনগুলি করছি৷
- ডেটা সিঙ্ক ফোরগ্রাউন্ড পরিষেবা সময় শেষ আচরণ
- নতুন মিডিয়া প্রক্রিয়াকরণ ফোরগ্রাউন্ড পরিষেবার ধরন
-
BOOT_COMPLETEDসম্প্রচার রিসিভার ফোরগ্রাউন্ড পরিষেবা চালু করার উপর নিষেধাজ্ঞা - একটি অ্যাপের
SYSTEM_ALERT_WINDOWঅনুমতি থাকাকালীন ফোরগ্রাউন্ড পরিষেবাগুলি শুরু করার উপর বিধিনিষেধ
ডেটা সিঙ্ক ফোরগ্রাউন্ড পরিষেবা সময় শেষ আচরণ
Android 15 Android 15 (API স্তর 35) বা উচ্চতরকে লক্ষ্য করে এমন অ্যাপগুলির জন্য dataSync একটি নতুন টাইমআউট আচরণ প্রবর্তন করে৷ এই আচরণটি নতুন mediaProcessing ফোরগ্রাউন্ড পরিষেবা প্রকারের ক্ষেত্রেও প্রযোজ্য।
সিস্টেমটি একটি অ্যাপের dataSync পরিষেবাগুলিকে 24-ঘন্টা সময়ের মধ্যে মোট 6 ঘন্টা চালানোর অনুমতি দেয়, তারপরে সিস্টেমটি চলমান পরিষেবাটির Service.onTimeout(int, int) পদ্ধতিতে কল করে (Android 15 এ চালু করা হয়েছে)৷ এই সময়ে, পরিষেবাটিতে Service.stopSelf() কল করার জন্য কয়েক সেকেন্ড সময় আছে। যখন Service.onTimeout() কল করা হয়, তখন পরিষেবাটিকে আর অগ্রভাগের পরিষেবা হিসাবে বিবেচনা করা হয় না। যদি পরিষেবাটি Service.stopSelf() কল না করে, তবে সিস্টেমটি একটি অভ্যন্তরীণ ব্যতিক্রম নিক্ষেপ করে৷ ব্যতিক্রমটি নিম্নলিখিত বার্তার সাথে লগক্যাটে লগ ইন করা হয়েছে:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type dataSync did not stop within its timeout: [component name]"
এই আচরণ পরিবর্তনের সমস্যাগুলি এড়াতে, আপনি নিম্নলিখিতগুলির মধ্যে এক বা একাধিক করতে পারেন:
- আপনার পরিষেবাকে নতুন
Service.onTimeout(int, int)পদ্ধতি প্রয়োগ করতে দিন। আপনার অ্যাপ কলব্যাক গ্রহণ করলে, কয়েক সেকেন্ডের মধ্যেstopSelf()কল করতে ভুলবেন না। (যদি আপনি এখনই অ্যাপটি বন্ধ না করেন তবে সিস্টেমটি একটি ব্যর্থতা তৈরি করে।) - নিশ্চিত করুন যে আপনার অ্যাপের
dataSyncপরিষেবাগুলি যে কোনও 24-ঘণ্টার সময়ের মধ্যে মোট 6 ঘন্টার বেশি চলবে না (যদি না ব্যবহারকারী অ্যাপটির সাথে ইন্টারঅ্যাক্ট করে, টাইমার রিসেট করে)। - শুধুমাত্র
dataSyncফোরগ্রাউন্ড পরিষেবাগুলি সরাসরি ব্যবহারকারীর ইন্টারঅ্যাকশনের ফলে শুরু করুন; যেহেতু পরিষেবাটি শুরু হওয়ার সময় আপনার অ্যাপটি ফোরগ্রাউন্ডে থাকে, তাই অ্যাপটি ব্যাকগ্রাউন্ডে যাওয়ার পরে আপনার পরিষেবার পুরো ছয় ঘন্টা থাকে। - একটি
dataSyncফোরগ্রাউন্ড পরিষেবা ব্যবহার করার পরিবর্তে, একটি বিকল্প API ব্যবহার করুন৷
যদি আপনার অ্যাপের dataSync ফোরগ্রাউন্ড পরিষেবাগুলি গত 24-এর মধ্যে 6 ঘন্টা ধরে চলে থাকে, তবে ব্যবহারকারী আপনার অ্যাপটিকে ফোরগ্রাউন্ডে না আনলে আপনি অন্য dataSync ফোরগ্রাউন্ড পরিষেবা শুরু করতে পারবেন না (যা টাইমার রিসেট করে)। আপনি যদি অন্য একটি dataSync ফোরগ্রাউন্ড পরিষেবা শুরু করার চেষ্টা করেন, তাহলে সিস্টেমটি "ফোরগ্রাউন্ড সার্ভিস টাইপ ডেটাসিঙ্কের জন্য সময়সীমা ইতিমধ্যেই শেষ" এর মতো একটি ত্রুটি বার্তা সহ ForegroundServiceStartNotAllowedException ছুড়ে দেয়৷
টেস্টিং
আপনার অ্যাপের আচরণ পরীক্ষা করার জন্য, আপনি ডেটা সিঙ্ক টাইমআউট সক্ষম করতে পারেন এমনকি যদি আপনার অ্যাপ অ্যান্ড্রয়েড 15 টার্গেট না করে (যতক্ষণ অ্যাপটি একটি Android 15 ডিভাইসে চলছে)। টাইমআউট সক্ষম করতে, নিম্নলিখিত adb কমান্ডটি চালান:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
আপনি টাইমআউট পিরিয়ড সামঞ্জস্য করতে পারেন, সীমা পৌঁছে গেলে আপনার অ্যাপ কীভাবে আচরণ করে তা পরীক্ষা করা সহজ করতে। একটি নতুন টাইমআউট পিরিয়ড সেট করতে, নিম্নলিখিত adb কমান্ডটি চালান:
adb shell device_config put activity_manager data_sync_fgs_timeout_duration duration-in-milliseconds
নতুন মিডিয়া প্রক্রিয়াকরণ ফোরগ্রাউন্ড পরিষেবার ধরন
Android 15 একটি নতুন ফোরগ্রাউন্ড পরিষেবার ধরণ প্রবর্তন করেছে, mediaProcessing । এই পরিষেবার ধরন মিডিয়া ফাইল ট্রান্সকোড করার মত অপারেশনের জন্য উপযুক্ত। উদাহরণস্বরূপ, একটি মিডিয়া অ্যাপ একটি অডিও ফাইল ডাউনলোড করতে পারে এবং এটি চালানোর আগে এটিকে একটি ভিন্ন বিন্যাসে রূপান্তর করতে হবে। আপনি একটি mediaProcessing ফোরগ্রাউন্ড পরিষেবা ব্যবহার করতে পারেন যাতে অ্যাপটি ব্যাকগ্রাউন্ডে থাকা সত্ত্বেও রূপান্তর অব্যাহত থাকে।
সিস্টেমটি একটি অ্যাপের mediaProcessing পরিষেবাগুলিকে 24-ঘণ্টার মধ্যে মোট 6 ঘন্টা চালানোর অনুমতি দেয়, তারপরে সিস্টেমটি চলমান পরিষেবাটির Service.onTimeout(int, int) পদ্ধতিকে কল করে (অ্যান্ড্রয়েড 15 এ প্রবর্তিত)৷ এই সময়ে, পরিষেবাটিতে Service.stopSelf() কল করার জন্য কয়েক সেকেন্ড সময় আছে। যদি পরিষেবাটি Service.stopSelf() কল না করে, তবে সিস্টেমটি একটি অভ্যন্তরীণ ব্যতিক্রম নিক্ষেপ করে৷ ব্যতিক্রম নিম্নলিখিত বার্তার সাথে Logcat লগ ইন করা হয়েছে:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type mediaProcessing did not stop within its timeout: [component name]"
ব্যতিক্রম এড়াতে, আপনি নিম্নলিখিতগুলির মধ্যে একটি করতে পারেন:
- আপনার পরিষেবাকে নতুন
Service.onTimeout(int, int)পদ্ধতি প্রয়োগ করতে দিন। আপনার অ্যাপ কলব্যাক গ্রহণ করলে, কয়েক সেকেন্ডের মধ্যেstopSelf()কল করতে ভুলবেন না। (যদি আপনি এখনই অ্যাপটি বন্ধ না করেন তবে সিস্টেমটি একটি ব্যর্থতা তৈরি করে।) - নিশ্চিত করুন যে আপনার অ্যাপের
mediaProcessingপরিষেবাগুলি যে কোনও 24-ঘন্টা সময়ের মধ্যে মোট 6 ঘন্টার বেশি চলবে না (যদি না ব্যবহারকারী অ্যাপের সাথে ইন্টারঅ্যাক্ট করে, টাইমার রিসেট করে)। - শুধুমাত্র সরাসরি ব্যবহারকারীর মিথস্ক্রিয়ার ফলে
mediaProcessingফোরগ্রাউন্ড পরিষেবা শুরু করুন; যেহেতু পরিষেবাটি শুরু হওয়ার সময় আপনার অ্যাপটি ফোরগ্রাউন্ডে থাকে, তাই অ্যাপটি ব্যাকগ্রাউন্ডে যাওয়ার পরে আপনার পরিষেবার পুরো ছয় ঘন্টা থাকে। -
mediaProcessingফোরগ্রাউন্ড পরিষেবা ব্যবহার করার পরিবর্তে, একটি বিকল্প API ব্যবহার করুন, যেমন WorkManager।
যদি আপনার অ্যাপের mediaProcessing ফোরগ্রাউন্ড পরিষেবাগুলি গত 24-এর মধ্যে 6 ঘন্টা ধরে চলে থাকে, তবে ব্যবহারকারী আপনার অ্যাপটিকে ফোরগ্রাউন্ডে না আনলে আপনি অন্য mediaProcessing ফোরগ্রাউন্ড পরিষেবা শুরু করতে পারবেন না (যা টাইমার রিসেট করে)। আপনি যদি অন্য mediaProcessing ফোরগ্রাউন্ড পরিষেবা শুরু করার চেষ্টা করেন, তাহলে সিস্টেমটি "ফোরগ্রাউন্ড সার্ভিস টাইপ মিডিয়াপ্রসেসিং এর জন্য ইতিমধ্যেই শেষ হয়ে গেছে" এর মতো একটি ত্রুটি বার্তা সহ ForegroundServiceStartNotAllowedException ছুড়ে দেয়।
mediaProcessing পরিষেবার ধরন সম্পর্কে আরও তথ্যের জন্য, Android 15: মিডিয়া প্রসেসিং-এর জন্য অগ্রভাগের পরিষেবার প্রকারগুলিতে পরিবর্তনগুলি দেখুন৷
টেস্টিং
আপনার অ্যাপের আচরণ পরীক্ষা করার জন্য, আপনি মিডিয়া প্রসেসিং টাইমআউট সক্ষম করতে পারেন এমনকি যদি আপনার অ্যাপ অ্যান্ড্রয়েড 15 টার্গেট না করে (যতক্ষণ অ্যাপটি অ্যান্ড্রয়েড 15 ডিভাইসে চলছে)। টাইমআউট সক্ষম করতে, নিম্নলিখিত adb কমান্ডটি চালান:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
আপনি টাইমআউট পিরিয়ড সামঞ্জস্য করতে পারেন, সীমা পৌঁছে গেলে আপনার অ্যাপ কীভাবে আচরণ করে তা পরীক্ষা করা সহজ করতে। একটি নতুন টাইমআউট পিরিয়ড সেট করতে, নিম্নলিখিত adb কমান্ডটি চালান:
adb shell device_config put activity_manager media_processing_fgs_timeout_duration duration-in-milliseconds
BOOT_COMPLETED সম্প্রচার রিসিভার ফোরগ্রাউন্ড পরিষেবা চালু করার উপর নিষেধাজ্ঞা
BOOT_COMPLETED সম্প্রচার রিসিভার ফোরগ্রাউন্ড পরিষেবা চালু করার জন্য নতুন বিধিনিষেধ রয়েছে৷ BOOT_COMPLETED রিসিভারদের নিম্নলিখিত ধরনের অগ্রভাগের পরিষেবা চালু করার অনুমতি নেই :
-
dataSync -
camera -
mediaPlayback -
phoneCall -
mediaProjection -
microphone(অ্যান্ড্রয়েড 14 সাল থেকেmicrophoneজন্য এই সীমাবদ্ধতা রয়েছে)
যদি একটি BOOT_COMPLETED রিসিভার এই ধরনের ফোরগ্রাউন্ড পরিষেবাগুলির মধ্যে যেকোনো একটি চালু করার চেষ্টা করে, তাহলে সিস্টেমটি ForegroundServiceStartNotAllowedException থ্রো করে।
টেস্টিং
আপনার অ্যাপ্লিকেশানের আচরণ পরীক্ষা করার জন্য, আপনি এই নতুন বিধিনিষেধগুলি সক্ষম করতে পারেন এমনকি যদি আপনার অ্যাপটি Android 15 টার্গেট না করে (যতক্ষণ অ্যাপটি একটি Android 15 ডিভাইসে চলছে)। নিম্নলিখিত adb কমান্ড চালান:
adb shell am compat enable FGS_BOOT_COMPLETED_RESTRICTIONS your-package-name
ডিভাইসটি পুনরায় চালু না করে একটি BOOT_COMPLETED সম্প্রচার পাঠাতে, নিম্নলিখিত adb কমান্ডটি চালান:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED your-package-name
একটি অ্যাপের SYSTEM_ALERT_WINDOW অনুমতি থাকাকালীন ফোরগ্রাউন্ড পরিষেবাগুলি শুরু করার উপর বিধিনিষেধ
পূর্বে, যদি একটি অ্যাপের কাছে SYSTEM_ALERT_WINDOW অনুমতি থাকে, তবে অ্যাপটি বর্তমানে ব্যাকগ্রাউন্ডে থাকলেও এটি একটি ফোরগ্রাউন্ড পরিষেবা চালু করতে পারে (যেমন ব্যাকগ্রাউন্ড শুরু সীমাবদ্ধতা থেকে অব্যাহতি নিয়ে আলোচনা করা হয়েছে)।
যদি কোনো অ্যাপ Android 15 কে লক্ষ্য করে, তাহলে এই ছাড় এখন আরও সংকুচিত। অ্যাপটির এখন SYSTEM_ALERT_WINDOW অনুমতি থাকতে হবে এবং একটি দৃশ্যমান ওভারলে উইন্ডোও থাকতে হবে । অর্থাৎ, অ্যাপটিকে প্রথমে একটি TYPE_APPLICATION_OVERLAY উইন্ডো চালু করতে হবে এবং আপনি একটি ফোরগ্রাউন্ড পরিষেবা শুরু করার আগে উইন্ডোটি দৃশ্যমান হওয়া প্রয়োজন৷
যদি আপনার অ্যাপ এই নতুন প্রয়োজনীয়তাগুলি পূরণ না করে ব্যাকগ্রাউন্ড থেকে একটি ফোরগ্রাউন্ড পরিষেবা শুরু করার চেষ্টা করে (এবং এটিতে অন্য কিছু ছাড় নেই), সিস্টেমটি ForegroundServiceStartNotAllowedException থ্রো করে।
যদি আপনার অ্যাপটি SYSTEM_ALERT_WINDOW অনুমতি ঘোষণা করে এবং পটভূমি থেকে ফোরগ্রাউন্ড পরিষেবা চালু করে, তাহলে এটি এই পরিবর্তন দ্বারা প্রভাবিত হতে পারে। যদি আপনার অ্যাপটি একটি ForegroundServiceStartNotAllowedException পায়, তাহলে আপনার অ্যাপের ক্রিয়াকলাপের ক্রম পরীক্ষা করুন এবং নিশ্চিত করুন যে আপনার অ্যাপটি ব্যাকগ্রাউন্ড থেকে ফোরগ্রাউন্ড পরিষেবা শুরু করার চেষ্টা করার আগে ইতিমধ্যেই একটি সক্রিয় ওভারলে উইন্ডো রয়েছে৷ আপনি View.getWindowVisibility() এ কল করে আপনার ওভারলে উইন্ডোটি বর্তমানে দৃশ্যমান কিনা তা পরীক্ষা করতে পারেন, অথবা যখনই দৃশ্যমানতা পরিবর্তন হয় তখন বিজ্ঞপ্তি পেতে আপনি View.onWindowVisibilityChanged() ওভাররাইড করতে পারেন।
টেস্টিং
আপনার অ্যাপ্লিকেশানের আচরণ পরীক্ষা করার জন্য, আপনি এই নতুন বিধিনিষেধগুলি সক্ষম করতে পারেন এমনকি যদি আপনার অ্যাপটি Android 15 টার্গেট না করে (যতক্ষণ অ্যাপটি একটি Android 15 ডিভাইসে চলছে)। পটভূমি থেকে ফোরগ্রাউন্ড পরিষেবাগুলি শুরু করার জন্য এই নতুন বিধিনিষেধগুলি সক্ষম করতে, নিম্নলিখিত adb কমান্ডটি চালান:
adb shell am compat enable FGS_SAW_RESTRICTIONS your-package-name
অ্যাপ্লিকেশানগুলি কখন বিরক্ত করবে না মোডের বৈশ্বিক অবস্থা পরিবর্তন করতে পারে তার পরিবর্তন৷
যে অ্যাপগুলি Android 15 (API লেভেল 35) এবং উচ্চতরকে টার্গেট করে তারা আর কোনও ডিভাইসে গ্লোবাল স্টেট বা Do Not Disturb (DND) এর নীতি পরিবর্তন করতে পারে না (হয় ব্যবহারকারী সেটিংস পরিবর্তন করে বা DND মোড বন্ধ করে)। পরিবর্তে, অ্যাপগুলিকে অবশ্যই একটি AutomaticZenRule অবদান রাখতে হবে, যা সিস্টেমটি বিদ্যমান সর্বাধিক-নিষেধমূলক-নীতি-জয় স্কিমের সাথে একটি বৈশ্বিক নীতিতে একত্রিত করে। বিদ্যমান API-এ কল যা পূর্বে গ্লোবাল স্টেটকে প্রভাবিত করেছিল ( setInterruptionFilter , setNotificationPolicy ) এর ফলে একটি অন্তর্নিহিত AutomaticZenRule তৈরি বা আপডেট হয়, যা সেই API কলগুলির কল-চক্রের উপর নির্ভর করে টগল করা এবং বন্ধ করা হয়।
মনে রাখবেন যে এই পরিবর্তনটি শুধুমাত্র পর্যবেক্ষণযোগ্য আচরণকে প্রভাবিত করে যদি অ্যাপটি setInterruptionFilter(INTERRUPTION_FILTER_ALL) কল করে এবং আশা করে যে কলটি একটি AutomaticZenRule নিষ্ক্রিয় করবে যা আগে তাদের মালিকদের দ্বারা সক্রিয় করা হয়েছিল৷
OpenJDK API পরিবর্তন
Android 15 সর্বশেষ OpenJDK LTS রিলিজের বৈশিষ্ট্যগুলির সাথে সারিবদ্ধ করার জন্য Android এর মূল লাইব্রেরিগুলিকে রিফ্রেশ করার কাজ চালিয়ে যাচ্ছে।
এই পরিবর্তনগুলির মধ্যে কিছু Android 15 (API স্তর 35) টার্গেট করা অ্যাপগুলির জন্য অ্যাপের সামঞ্জস্যকে প্রভাবিত করতে পারে:
স্ট্রিং ফরম্যাটিং API-তে পরিবর্তন : নিম্নলিখিত
String.format()এবংFormatter.format()API ব্যবহার করার সময় আর্গুমেন্ট ইনডেক্স, ফ্ল্যাগ, প্রস্থ এবং নির্ভুলতার বৈধতা এখন আরও কঠোর:-
String.format(String, Object[]) -
String.format(Locale, String, Object[]) -
Formatter.format(String, Object[]) -
Formatter.format(Locale, String, Object[])
উদাহরণস্বরূপ, নিম্নলিখিত ব্যতিক্রমটি ছুঁড়ে দেওয়া হয় যখন 0 এর একটি আর্গুমেন্ট সূচক ব্যবহার করা হয় (
%0বিন্যাসে স্ট্রিং):IllegalFormatArgumentIndexException: Illegal format argument index = 0এই ক্ষেত্রে, 1 এর আর্গুমেন্ট ইনডেক্স ব্যবহার করে সমস্যাটি ঠিক করা যেতে পারে ( ফরম্যাট স্ট্রিংয়ে
%1)।-
Arrays.asList(...).toArray()এর কম্পোনেন্ট টাইপের পরিবর্তন :Arrays.asList(...).toArray()ব্যবহার করার সময়, ফলাফল পাওয়া অ্যারের কম্পোনেন্ট টাইপ এখন একটিObject- অন্তর্নিহিত অ্যারের উপাদানের ধরন নয়। সুতরাং নিম্নলিখিত কোডটি একটিClassCastExceptionনিক্ষেপ করে:String[] elements = (String[]) Arrays.asList("one", "two").toArray();এই ক্ষেত্রে,
Stringকম্পোনেন্ট টাইপ হিসাবে ফলস্বরূপ অ্যারে সংরক্ষণ করতে, আপনি পরিবর্তেCollection.toArray(Object[])ব্যবহার করতে পারেন:String[] elements = Arrays.asList("two", "one").toArray(new String[0]);ভাষা কোড পরিচালনায় পরিবর্তন :
LocaleAPI ব্যবহার করার সময়, হিব্রু, ইদ্দিশ এবং ইন্দোনেশিয়ান ভাষার কোডগুলি আর তাদের অপ্রচলিত ফর্মগুলিতে রূপান্তরিত হয় না (হিব্রু:iw, য়িদ্দিশ:ji, এবং ইন্দোনেশিয়ান:in)। এই লোকেলগুলির মধ্যে একটির জন্য ভাষা কোড নির্দিষ্ট করার সময়, পরিবর্তে ISO 639-1 থেকে কোডগুলি ব্যবহার করুন (হিব্রু:he, য়িদ্দিশ:yi, এবং ইন্দোনেশিয়ান:id)।এলোমেলো int সিকোয়েন্সে পরিবর্তন : https://bugs.openjdk.org/browse/JDK-8301574 এ করা পরিবর্তনগুলি অনুসরণ করে, নিম্নলিখিত
Random.ints()পদ্ধতিগুলি এখনRandom.nextInt()পদ্ধতিগুলির তুলনায় সংখ্যার একটি ভিন্ন ক্রম ফেরত দেয়:সাধারণত, এই পরিবর্তনের ফলে অ্যাপ-ব্রেকিং আচরণ করা উচিত নয়, তবে আপনার কোড
Random.ints()পদ্ধতি থেকে তৈরি হওয়া ক্রমRandom.nextInt()সাথে মিলবে বলে আশা করা উচিত নয়।
আপনি Android 15 (API স্তর 35) ব্যবহার করার জন্য আপনার অ্যাপের বিল্ড কনফিগারেশনে compileSdk আপডেট করার পরে নতুন SequencedCollection API আপনার অ্যাপের সামঞ্জস্যকে প্রভাবিত করতে পারে :
kotlin-stdlibএMutableList.removeFirst()এবংMutableList.removeLast()এক্সটেনশন ফাংশনের সাথে সংঘর্ষজাভাতে
Listধরনটি Kotlin-এরMutableListপ্রকারে ম্যাপ করা হয়েছে। যেহেতুList.removeFirst()এবংList.removeLast()APIগুলি Android 15 (API স্তর 35) এ চালু করা হয়েছে, তাই Kotlin কম্পাইলার ফাংশন কলগুলি সমাধান করে, উদাহরণস্বরূপlist.removeFirst(),kotlin-stdlibএ এক্সটেনশন ফাংশনগুলির পরিবর্তে নতুনListAPIগুলিতে স্থিরভাবে।যদি একটি অ্যাপ পুনরায় কম্পাইল করা হয়
compileSdk35সেট করে এবংminSdkসেট করে34বা তার নিচে, এবং তারপরে অ্যাপটি Android 14 এবং তার নিচের সংস্করণে চালানো হয়, একটি রানটাইম ত্রুটি নিক্ষেপ করা হয়:java.lang.NoSuchMethodError: No virtual method removeFirst()Ljava/lang/Object; in class Ljava/util/ArrayList;Android Gradle Plugin-এ বিদ্যমান
NewApilint বিকল্পটি এই নতুন API ব্যবহারগুলি ধরতে পারে।./gradlew lintMainActivity.kt:41: Error: Call requires API level 35 (current min is 34): java.util.List#removeFirst [NewApi] list.removeFirst()রানটাইম ব্যতিক্রম এবং লিন্ট ত্রুটিগুলি ঠিক করতে, Kotlin-এ
removeFirst()এবংremoveLast()ফাংশন কল যথাক্রমেremoveAt(0)এবংremoveAt(list.lastIndex)দিয়ে প্রতিস্থাপন করা যেতে পারে। আপনি যদি Android Studio Ladybug ব্যবহার করেন | 2024.1.3 বা উচ্চতর, এটি এই ত্রুটিগুলির জন্য একটি দ্রুত সমাধানের বিকল্পও প্রদান করে।@SuppressLint("NewApi")অপসারণ করার কথা বিবেচনা করুন এবং লিন্ট বিকল্পটি নিষ্ক্রিয় করা থাকলেlintOptions { disable 'NewApi' }।জাভাতে অন্যান্য পদ্ধতির সাথে সংঘর্ষ
বিদ্যমান প্রকারগুলিতে নতুন পদ্ধতি যোগ করা হয়েছে, উদাহরণস্বরূপ,
ListএবংDeque। এই নতুন পদ্ধতিগুলি অন্যান্য ইন্টারফেস এবং ক্লাসে একই নাম এবং আর্গুমেন্ট প্রকারের পদ্ধতিগুলির সাথে সামঞ্জস্যপূর্ণ নাও হতে পারে। অসঙ্গতি সহ একটি পদ্ধতি স্বাক্ষর সংঘর্ষের ক্ষেত্রে,javacকম্পাইলার একটি বিল্ড-টাইম ত্রুটি আউটপুট করে। যেমন:উদাহরণ ত্রুটি 1:
javac MyList.javaMyList.java:135: error: removeLast() in MyList cannot implement removeLast() in List public void removeLast() { ^ return type void is not compatible with Object where E is a type-variable: E extends Object declared in interface Listউদাহরণ ত্রুটি 2:
javac MyList.javaMyList.java:7: error: types Deque<Object> and List<Object> are incompatible; public class MyList implements List<Object>, Deque<Object> { both define reversed(), but with unrelated return types 1 errorউদাহরণ ত্রুটি 3:
javac MyList.javaMyList.java:43: error: types List<E#1> and MyInterface<E#2> are incompatible; public static class MyList implements List<Object>, MyInterface<Object> { class MyList inherits unrelated defaults for getFirst() from types List and MyInterface where E#1,E#2 are type-variables: E#1 extends Object declared in interface List E#2 extends Object declared in interface MyInterface 1 errorএই বিল্ড ত্রুটিগুলি ঠিক করার জন্য, এই ইন্টারফেসগুলি বাস্তবায়নকারী ক্লাসটি একটি সামঞ্জস্যপূর্ণ রিটার্ন টাইপের সাথে পদ্ধতিটিকে ওভাররাইড করবে। যেমন:
@Override public Object getFirst() { return List.super.getFirst(); }
নিরাপত্তা
অ্যান্ড্রয়েড 15-এ এমন পরিবর্তনগুলি অন্তর্ভুক্ত রয়েছে যা অ্যাপ এবং ব্যবহারকারীদের ক্ষতিকারক অ্যাপ থেকে রক্ষা করতে সিস্টেম নিরাপত্তার প্রচার করে।
সীমাবদ্ধ TLS সংস্করণ
Android 15 TLS সংস্করণ 1.0 এবং 1.1 ব্যবহার সীমাবদ্ধ করে। এই সংস্করণগুলি পূর্বে অ্যান্ড্রয়েডে অবহেলিত ছিল, কিন্তু এখন Android 15 টার্গেট করা অ্যাপগুলির জন্য অননুমোদিত।
সুরক্ষিত ব্যাকগ্রাউন্ড কার্যকলাপ চালু হয়
অ্যান্ড্রয়েড 15 ব্যবহারকারীদের ক্ষতিকারক অ্যাপ থেকে রক্ষা করে এবং ক্ষতিকারক ব্যাকগ্রাউন্ড অ্যাপগুলিকে অন্য অ্যাপগুলিকে অগ্রভাগে আনতে, তাদের বিশেষাধিকারগুলিকে উন্নত করতে এবং ব্যবহারকারীর ইন্টারঅ্যাকশনের অপব্যবহার করে এমন পরিবর্তনগুলি যোগ করে তাদের ডিভাইসের উপর আরও নিয়ন্ত্রণ দেয়। Android 10 (API স্তর 29) থেকে পটভূমি কার্যকলাপ লঞ্চ সীমাবদ্ধ করা হয়েছে।
অন্যান্য পরিবর্তন
UID মিলের জন্য সীমাবদ্ধতা ছাড়াও, এই অন্যান্য পরিবর্তনগুলিও অন্তর্ভুক্ত:
- ডিফল্টরূপে ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চ ব্লক করতে
PendingIntentনির্মাতাদের পরিবর্তন করুন । এটি অ্যাপগুলিকে দুর্ঘটনাক্রমে একটিPendingIntentতৈরি করা থেকে আটকাতে সাহায্য করে যা দূষিত অভিনেতাদের দ্বারা অপব্যবহার হতে পারে৷ -
PendingIntentপ্রেরক এটির অনুমতি না দিলে অগ্রভাগে একটি অ্যাপ আনবেন না ৷ এই পরিবর্তনের লক্ষ্য হল দূষিত অ্যাপগুলিকে ব্যাকগ্রাউন্ডে ক্রিয়াকলাপ শুরু করার ক্ষমতা অপব্যবহার করা থেকে আটকানো৷ ডিফল্টরূপে, অ্যাপ্লিকেশানগুলিকে অগ্রভাগে টাস্ক স্ট্যাক আনার অনুমতি দেওয়া হয় না যদি না স্রষ্টা ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চের বিশেষাধিকার বা প্রেরকের ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চের বিশেষাধিকার না থাকে। - একটি টাস্ক স্ট্যাকের শীর্ষ কার্যকলাপ কিভাবে তার কাজ শেষ করতে পারে তা নিয়ন্ত্রণ করুন । যদি শীর্ষ ক্রিয়াকলাপ একটি টাস্ক শেষ করে, তবে Android সর্বশেষ সক্রিয় যে কোনও টাস্কে ফিরে যাবে। অধিকন্তু, যদি একটি নন-টপ অ্যাক্টিভিটি তার কাজ শেষ করে, তাহলে অ্যান্ড্রয়েড হোম স্ক্রিনে ফিরে যাবে; এটি এই অ-শীর্ষ কার্যকলাপের সমাপ্তি ব্লক করবে না।
- আপনার নিজের টাস্কে অন্য অ্যাপ থেকে স্বেচ্ছাচারী ক্রিয়াকলাপ চালু করা প্রতিরোধ করুন । এই পরিবর্তনটি ক্ষতিকারক অ্যাপগুলিকে ফিশিং ব্যবহারকারীদের থেকে আটকায় এমন ক্রিয়াকলাপগুলি তৈরি করে যা অন্যান্য অ্যাপ থেকে দেখা যায়৷
- পটভূমি কার্যকলাপ লঞ্চের জন্য বিবেচনা করা থেকে অ-দৃশ্যমান উইন্ডোগুলিকে ব্লক করুন ৷ এটি ব্যবহারকারীদের কাছে অবাঞ্ছিত বা দূষিত সামগ্রী প্রদর্শন করতে ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চের অপব্যবহার থেকে ক্ষতিকারক অ্যাপগুলিকে প্রতিরোধ করতে সহায়তা করে৷
অ্যান্ড্রয়েড 15 ব্যবহারকারীদের ক্ষতিকারক অ্যাপ থেকে রক্ষা করে এবং ক্ষতিকারক ব্যাকগ্রাউন্ড অ্যাপগুলিকে অন্য অ্যাপগুলিকে অগ্রভাগে আনতে, তাদের বিশেষাধিকারগুলিকে উন্নত করতে এবং ব্যবহারকারীর ইন্টারঅ্যাকশনের অপব্যবহার করে এমন পরিবর্তনগুলি যোগ করে তাদের ডিভাইসের উপর আরও নিয়ন্ত্রণ দেয়। Android 10 (API স্তর 29) থেকে পটভূমি কার্যকলাপ লঞ্চ সীমাবদ্ধ করা হয়েছে।
অন্যান্য পরিবর্তন
UID মিলের জন্য সীমাবদ্ধতা ছাড়াও, এই অন্যান্য পরিবর্তনগুলিও অন্তর্ভুক্ত:
- ডিফল্টরূপে ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চ ব্লক করতে
PendingIntentনির্মাতাদের পরিবর্তন করুন । এটি অ্যাপগুলিকে দুর্ঘটনাক্রমে একটিPendingIntentতৈরি করা থেকে আটকাতে সাহায্য করে যা দূষিত অভিনেতাদের দ্বারা অপব্যবহার হতে পারে৷ -
PendingIntentপ্রেরক এটির অনুমতি না দিলে অগ্রভাগে একটি অ্যাপ আনবেন না ৷ এই পরিবর্তনের লক্ষ্য হল দূষিত অ্যাপগুলিকে ব্যাকগ্রাউন্ডে ক্রিয়াকলাপ শুরু করার ক্ষমতা অপব্যবহার করা থেকে আটকানো৷ ডিফল্টরূপে, অ্যাপ্লিকেশানগুলিকে অগ্রভাগে টাস্ক স্ট্যাক আনার অনুমতি দেওয়া হয় না যদি না স্রষ্টা ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চের বিশেষাধিকার বা প্রেরকের ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চের বিশেষাধিকার না থাকে। - একটি টাস্ক স্ট্যাকের শীর্ষ কার্যকলাপ কিভাবে তার কাজ শেষ করতে পারে তা নিয়ন্ত্রণ করুন । যদি শীর্ষ ক্রিয়াকলাপ একটি টাস্ক শেষ করে, তবে Android সর্বশেষ সক্রিয় যে কোনও টাস্কে ফিরে যাবে। অধিকন্তু, যদি একটি নন-টপ অ্যাক্টিভিটি তার কাজ শেষ করে, তাহলে অ্যান্ড্রয়েড হোম স্ক্রিনে ফিরে যাবে; এটি এই অ-শীর্ষ কার্যকলাপের সমাপ্তি ব্লক করবে না।
- আপনার নিজের টাস্কে অন্য অ্যাপ থেকে স্বেচ্ছাচারী ক্রিয়াকলাপ চালু করা প্রতিরোধ করুন । এই পরিবর্তনটি ক্ষতিকারক অ্যাপগুলিকে ফিশিং ব্যবহারকারীদের থেকে আটকায় এমন ক্রিয়াকলাপগুলি তৈরি করে যা অন্যান্য অ্যাপ থেকে দেখা যায়৷
- পটভূমি কার্যকলাপ লঞ্চের জন্য বিবেচনা করা থেকে অ-দৃশ্যমান উইন্ডোগুলিকে ব্লক করুন ৷ এটি ব্যবহারকারীদের কাছে অবাঞ্ছিত বা দূষিত সামগ্রী প্রদর্শন করতে ব্যাকগ্রাউন্ড অ্যাক্টিভিটি লঞ্চের অপব্যবহার থেকে ক্ষতিকারক অ্যাপগুলিকে প্রতিরোধ করতে সহায়তা করে৷
নিরাপদ অভিপ্রায়
অ্যান্ড্রয়েড 15 অভিপ্রায়কে নিরাপদ এবং আরও শক্তিশালী করতে নতুন ঐচ্ছিক নিরাপত্তা ব্যবস্থা প্রবর্তন করেছে। এই পরিবর্তনগুলি সম্ভাব্য দুর্বলতা এবং অভিপ্রায়গুলির অপব্যবহার রোধ করার লক্ষ্যে যা দূষিত অ্যাপগুলির দ্বারা শোষিত হতে পারে৷ অ্যান্ড্রয়েড 15-এ উদ্দেশ্যগুলির নিরাপত্তার জন্য দুটি প্রধান উন্নতি রয়েছে:
- লক্ষ্য অভিপ্রায়-ফিল্টারগুলি মেলে: নির্দিষ্ট উপাদানগুলিকে লক্ষ্য করে এমন অভিপ্রায়গুলি অবশ্যই লক্ষ্যের উদ্দেশ্য-ফিল্টার বৈশিষ্ট্যগুলির সাথে সঠিকভাবে মেলে৷ আপনি যদি অন্য অ্যাপের ক্রিয়াকলাপ চালু করার জন্য একটি অভিপ্রায় পাঠান, তাহলে লক্ষ্য অভিপ্রায় উপাদানটি গ্রহণকারী কার্যকলাপের ঘোষিত অভিপ্রায়-ফিল্টারগুলির সাথে সারিবদ্ধ হতে হবে।
- ইন্টেন্টে অবশ্যই অ্যাকশন থাকতে হবে: অ্যাকশন ছাড়া ইন্টেন্ট আর কোনো ইনটেন্ট-ফিল্টারের সাথে মিলবে না। এর মানে হল যে ক্রিয়াকলাপ বা পরিষেবাগুলি শুরু করার জন্য ব্যবহৃত উদ্দেশ্যগুলির একটি স্পষ্টভাবে সংজ্ঞায়িত ক্রিয়া থাকতে হবে।
আপনার অ্যাপ এই পরিবর্তনগুলিতে কীভাবে সাড়া দেয় তা পরীক্ষা করার জন্য, আপনার অ্যাপে StrictMode ব্যবহার করুন। Intent ব্যবহার লঙ্ঘন সম্পর্কে বিস্তারিত লগ দেখতে, নিম্নলিখিত পদ্ধতি যোগ করুন:
কোটলিন
fun onCreate() { StrictMode.setVmPolicy(VmPolicy.Builder() .detectUnsafeIntentLaunch() .build() ) }
জাভা
public void onCreate() { StrictMode.setVmPolicy(new VmPolicy.Builder() .detectUnsafeIntentLaunch() .build()); }
অ্যান্ড্রয়েড 15 নতুন ঐচ্ছিক নিরাপত্তা ব্যবস্থা প্রবর্তন করে যাতে উদ্দেশ্যগুলিকে নিরাপদ এবং আরও শক্তিশালী করে তোলা যায়। এই পরিবর্তনগুলি সম্ভাব্য দুর্বলতা এবং উদ্দেশ্যগুলির অপব্যবহার রোধ করার লক্ষ্যে যা দূষিত অ্যাপগুলির দ্বারা শোষিত হতে পারে৷ অ্যান্ড্রয়েড 15-এ উদ্দেশ্যগুলির নিরাপত্তার জন্য দুটি প্রধান উন্নতি রয়েছে:
- লক্ষ্য অভিপ্রায়-ফিল্টারগুলি মেলে: নির্দিষ্ট উপাদানগুলিকে লক্ষ্য করে এমন অভিপ্রায়গুলি অবশ্যই লক্ষ্যের উদ্দেশ্য-ফিল্টার বৈশিষ্ট্যগুলির সাথে সঠিকভাবে মেলে৷ আপনি যদি অন্য অ্যাপের ক্রিয়াকলাপ চালু করার জন্য একটি অভিপ্রায় পাঠান, তাহলে লক্ষ্য অভিপ্রায় উপাদানটি গ্রহণকারী কার্যকলাপের ঘোষিত অভিপ্রায়-ফিল্টারগুলির সাথে সারিবদ্ধ হতে হবে।
- ইন্টেন্টে অবশ্যই অ্যাকশন থাকতে হবে: অ্যাকশন ছাড়া ইন্টেন্ট আর কোনো ইনটেন্ট-ফিল্টারের সাথে মিলবে না। এর মানে হল যে ক্রিয়াকলাপ বা পরিষেবাগুলি শুরু করার জন্য ব্যবহৃত উদ্দেশ্যগুলির একটি স্পষ্টভাবে সংজ্ঞায়িত ক্রিয়া থাকতে হবে।
আপনার অ্যাপ এই পরিবর্তনগুলিতে কীভাবে সাড়া দেয় তা পরীক্ষা করার জন্য, আপনার অ্যাপে StrictMode ব্যবহার করুন। Intent ব্যবহার লঙ্ঘন সম্পর্কে বিস্তারিত লগ দেখতে, নিম্নলিখিত পদ্ধতি যোগ করুন:
কোটলিন
fun onCreate() { StrictMode.setVmPolicy(VmPolicy.Builder() .detectUnsafeIntentLaunch() .build() ) }
জাভা
public void onCreate() { StrictMode.setVmPolicy(new VmPolicy.Builder() .detectUnsafeIntentLaunch() .build()); }
ব্যবহারকারীর অভিজ্ঞতা এবং সিস্টেম UI
অ্যান্ড্রয়েড 15-এ এমন কিছু পরিবর্তন রয়েছে যা আরও সামঞ্জস্যপূর্ণ, স্বজ্ঞাত ব্যবহারকারীর অভিজ্ঞতা তৈরি করার উদ্দেশ্যে করা হয়েছে।
উইন্ডো ইনসেট পরিবর্তন
অ্যান্ড্রয়েড 15-এ উইন্ডো ইনসেটগুলির সাথে সম্পর্কিত দুটি পরিবর্তন রয়েছে: এজ-টু-এজ ডিফল্টরূপে প্রয়োগ করা হয় এবং কনফিগারেশন পরিবর্তনগুলিও রয়েছে, যেমন সিস্টেম বারের ডিফল্ট কনফিগারেশন।
প্রান্ত থেকে প্রান্ত প্রয়োগ
অ্যাপ্লিকেশানগুলি যদি Android 15 (API স্তর 35) কে লক্ষ্য করে তাহলে Android 15 চালিত ডিভাইসগুলিতে ডিফল্টরূপে এজ-টু-এজ থাকে৷

এটি একটি ব্রেকিং পরিবর্তন যা আপনার অ্যাপের UI কে নেতিবাচকভাবে প্রভাবিত করতে পারে। পরিবর্তনগুলি নিম্নলিখিত UI অঞ্চলগুলিকে প্রভাবিত করে:
- অঙ্গভঙ্গি হ্যান্ডেল নেভিগেশন বার
- ডিফল্টরূপে স্বচ্ছ।
- নীচের অফসেট অক্ষম করা হয়েছে তাই ইনসেটগুলি প্রয়োগ করা না হলে বিষয়বস্তু সিস্টেম নেভিগেশন বারের পিছনে চলে যায়৷
-
setNavigationBarColorএবংR.attr#navigationBarColorবাতিল করা হয়েছে এবং অঙ্গভঙ্গি নেভিগেশনকে প্রভাবিত করে না। -
setNavigationBarContrastEnforcedএবংR.attr#navigationBarContrastEnforcedজেসচার নেভিগেশনের উপর কোন প্রভাব নেই।
- 3-বোতাম নেভিগেশন
- অস্বচ্ছতা ডিফল্টরূপে 80% এ সেট করা হয়েছে, সম্ভবত উইন্ডোর পটভূমির সাথে রঙের সাথে মিল রয়েছে।
- নীচের অফসেট অক্ষম করা হয়েছে যাতে ইনসেটগুলি প্রয়োগ না করা হলে বিষয়বস্তু সিস্টেম নেভিগেশন বারের পিছনে চলে যায়৷
-
setNavigationBarColorএবংR.attr#navigationBarColorডিফল্টরূপে উইন্ডোর পটভূমির সাথে মেলে সেট করা আছে। এই ডিফল্টটি প্রয়োগ করার জন্য উইন্ডোর পটভূমিতে অবশ্যই একটি রঙ আঁকতে হবে। এই APIটি বাতিল করা হয়েছে কিন্তু 3-বোতাম নেভিগেশনকে প্রভাবিত করে চলেছে৷ -
setNavigationBarContrastEnforcedএবংR.attr#navigationBarContrastEnforcedডিফল্টভাবে সত্য, যা 3-বোতাম নেভিগেশন জুড়ে একটি 80% অস্বচ্ছ পটভূমি যোগ করে।
- স্ট্যাটাস বার
- ডিফল্টরূপে স্বচ্ছ।
- শীর্ষ অফসেটটি অক্ষম করা হয়েছে তাই ইনসেটগুলি প্রয়োগ করা না হলে বিষয়বস্তু স্ট্যাটাস বারের পিছনে চলে যায়৷
-
setStatusBarColorএবংR.attr#statusBarColorবাতিল করা হয়েছে এবং Android 15-এ কোনো প্রভাব নেই। -
setStatusBarContrastEnforcedএবংR.attr#statusBarContrastEnforcedবাতিল করা হয়েছে কিন্তু এখনও Android 15-এ এর প্রভাব রয়েছে।
- ডিসপ্লে কাটআউট
- নন-ফ্লোটিং উইন্ডোগুলির
layoutInDisplayCutoutModeঅবশ্যইLAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYSহতে হবে।SHORT_EDGES,NEVER, এবংDEFAULTALWAYSহিসাবে ব্যাখ্যা করা হয় যাতে ব্যবহারকারীরা ডিসপ্লে কাটআউটের কারণে একটি কালো বার দেখতে না পায় এবং প্রান্ত থেকে প্রান্তে প্রদর্শিত হয়৷
- নন-ফ্লোটিং উইন্ডোগুলির
নিম্নলিখিত উদাহরণটি Android 15 (API স্তর 35) লক্ষ্য করার আগে এবং পরে এবং ইনসেটগুলি প্রয়োগ করার আগে এবং পরে একটি অ্যাপ দেখায়। এই উদাহরণটি ব্যাপক নয়, এটি Android Auto এ ভিন্নভাবে প্রদর্শিত হতে পারে।



আপনার অ্যাপটি ইতিমধ্যেই এজ-টু-এজ কিনা তা পরীক্ষা করতে হবে
যদি আপনার অ্যাপটি ইতিমধ্যেই এজ-টু-এজ হয়ে থাকে এবং ইনসেটগুলি প্রয়োগ করে, তবে নিম্নলিখিত পরিস্থিতিগুলি ব্যতীত আপনি বেশিরভাগ ক্ষেত্রেই প্রভাবিত হবেন না। যাইহোক, এমনকি যদি আপনি মনে করেন যে আপনি প্রভাবিত হননি, আমরা আপনাকে আপনার অ্যাপ পরীক্ষা করার পরামর্শ দিই।
- আপনার কাছে একটি নন-ফ্লোটিং উইন্ডো আছে, যেমন একটি
ActivityযাLAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYSএর পরিবর্তেSHORT_EDGES,NEVERবাDEFAULTব্যবহার করে। আপনার অ্যাপ লঞ্চের সময় ক্র্যাশ হলে, এটি আপনার স্প্ল্যাশস্ক্রিনের কারণে হতে পারে। আপনি হয় কোর স্প্ল্যাশস্ক্রিন নির্ভরতাকে 1.2.0-alpha01 বা পরবর্তীতে আপগ্রেড করতে পারেন অথবাwindow.attributes.layoutInDisplayCutoutMode = WindowManager.LayoutInDisplayCutoutMode.alwaysসেট করতে পারেন। - আবদ্ধ UI সহ নিম্ন-ট্রাফিক স্ক্রীন থাকতে পারে। এই কম পরিদর্শন করা স্ক্রীনে UI আটকানো নেই তা যাচাই করুন। নিম্ন-ট্র্যাফিক স্ক্রিনগুলির মধ্যে রয়েছে:
- অনবোর্ডিং বা সাইন-ইন স্ক্রীন
- সেটিংস পৃষ্ঠা
আপনার অ্যাপ ইতিমধ্যেই এজ-টু-এজ না হলে কী পরীক্ষা করবেন
যদি আপনার অ্যাপ ইতিমধ্যেই এজ-টু-এজ না হয়, তাহলে আপনি সম্ভবত প্রভাবিত হবেন। ইতিমধ্যেই এজ-টু-এজ অ্যাপ্লিকেশানগুলির জন্য পরিস্থিতিগুলি ছাড়াও, আপনার নিম্নলিখিতগুলি বিবেচনা করা উচিত:
- যদি আপনার অ্যাপটি কম্পোজে Material 3 উপাদান (
androidx.compose.material3) ব্যবহার করে, যেমনTopAppBar,BottomAppBar, এবংNavigationBar, তাহলে এই উপাদানগুলি সম্ভবত প্রভাবিত হবে না কারণ তারা স্বয়ংক্রিয়ভাবে ইনসেটগুলি পরিচালনা করে৷ - যদি আপনার অ্যাপটি রচনায় উপাদান 2 উপাদান (
androidx.compose.material) ব্যবহার করে, তাহলে এই উপাদানগুলি স্বয়ংক্রিয়ভাবে ইনসেটগুলি পরিচালনা করে না৷ যাইহোক, আপনি ইনসেটগুলিতে অ্যাক্সেস পেতে পারেন এবং সেগুলি ম্যানুয়ালি প্রয়োগ করতে পারেন। androidx.compose.material 1.6.0 এবং পরবর্তীতে,BottomAppBar,TopAppBar,BottomNavigationএবংNavigationRailজন্য ম্যানুয়ালি ইনসেটগুলি প্রয়োগ করতেwindowInsetsপ্যারামিটার ব্যবহার করুন। একইভাবে,Scaffoldজন্যcontentWindowInsetsপ্যারামিটার ব্যবহার করুন। - যদি আপনার অ্যাপটি ভিউ এবং ম্যাটেরিয়াল কম্পোনেন্ট (
com.google.android.material) ব্যবহার করে, তবে বেশিরভাগ ভিউ-ভিত্তিক মেটেরিয়াল কম্পোনেন্ট যেমনBottomNavigationView,BottomAppBar,NavigationRailView, বাNavigationView, ইনসেটগুলি পরিচালনা করে এবং কোনও অতিরিক্ত কাজের প্রয়োজন নেই৷ যাইহোক,AppBarLayoutব্যবহার করলে আপনাকেandroid:fitsSystemWindows="true"যোগ করতে হবে। - কাস্টম কম্পোজেবলের জন্য, প্যাডিং হিসাবে ম্যানুয়ালি ইনসেটগুলি প্রয়োগ করুন। যদি আপনার বিষয়বস্তু একটি
Scaffoldমধ্যে থাকে, তাহলে আপনিScaffoldপ্যাডিং মান ব্যবহার করে ইনসেটগুলি ব্যবহার করতে পারেন৷ অন্যথায়, একটিWindowInsetsব্যবহার করে প্যাডিং প্রয়োগ করুন। - আপনার অ্যাপ যদি ভিউ এবং
BottomSheet,SideSheetবা কাস্টম কন্টেনার ব্যবহার করে, তাহলেViewCompat.setOnApplyWindowInsetsListenerব্যবহার করে প্যাডিং প্রয়োগ করুন।RecyclerViewএর জন্য, এই শ্রোতা ব্যবহার করে প্যাডিং প্রয়োগ করুন এবংclipToPadding="false"যোগ করুন।
আপনার অ্যাপটি অবশ্যই কাস্টম ব্যাকগ্রাউন্ড সুরক্ষা প্রদান করবে কিনা তা পরীক্ষা করতে হবে
যদি আপনার অ্যাপটি অবশ্যই 3-বোতাম নেভিগেশন বা স্ট্যাটাস বারে কাস্টম ব্যাকগ্রাউন্ড সুরক্ষা প্রদান করে, তাহলে আপনার অ্যাপটি 3-বোতামের নেভিগেশন বারের উচ্চতা বা WindowInsets.Type#statusBars পেতে WindowInsets.Type#tappableElement() ব্যবহার করে সিস্টেম বারের পিছনে একটি কম্পোজেবল বা ভিউ রাখতে হবে।
অতিরিক্ত এজ-টু-এজ রিসোর্স
ইনসেট প্রয়োগ করার বিষয়ে অতিরিক্ত বিবেচনার জন্য এজ থেকে এজ ভিউ এবং এজ টু এজ কম্পোজ গাইড দেখুন।
অপ্রচলিত API
নিম্নোক্ত APIগুলিকে অবমূল্যায়ন করা হয়েছে কিন্তু নিষ্ক্রিয় করা হয়নি:
-
R.attr#enforceStatusBarContrast -
R.attr#navigationBarColor(3 বোতাম নেভিগেশনের জন্য, 80% আলফা সহ) -
Window#isStatusBarContrastEnforced -
Window#setNavigationBarColor(3 বোতাম নেভিগেশনের জন্য, 80% আলফা সহ) -
Window#setStatusBarContrastEnforced
নিম্নোক্ত API গুলি অবমূল্যায়িত এবং অক্ষম করা হয়েছে:
-
R.attr#navigationBarColor(জেসচার নেভিগেশনের জন্য) -
R.attr#navigationBarDividerColor -
R.attr#statusBarColor -
Window#setDecorFitsSystemWindows -
Window#getNavigationBarColor -
Window#getNavigationBarDividerColor -
Window#getStatusBarColor -
Window#setNavigationBarColor(জেসচার নেভিগেশনের জন্য) -
Window#setNavigationBarDividerColor -
Window#setStatusBarColor
স্থিতিশীল কনফিগারেশন
যদি আপনার অ্যাপটি Android 15 (API লেভেল 35) বা উচ্চতরকে লক্ষ্য করে, Configuration আর সিস্টেম বারগুলিকে বাদ দেয় না। আপনি যদি বিন্যাস গণনার জন্য Configuration ক্লাসে স্ক্রীনের আকার ব্যবহার করেন, তাহলে আপনার প্রয়োজনের উপর নির্ভর করে একটি উপযুক্ত ViewGroup , WindowInsets বা WindowMetricsCalculator মতো আরও ভাল বিকল্প দিয়ে প্রতিস্থাপন করা উচিত।
API 1 থেকে Configuration উপলব্ধ। এটি সাধারণত Activity.onConfigurationChanged থেকে প্রাপ্ত হয়। এটি জানালার ঘনত্ব, অভিযোজন এবং আকারের মতো তথ্য প্রদান করে। Configuration থেকে প্রত্যাবর্তিত উইন্ডোর আকার সম্পর্কে একটি গুরুত্বপূর্ণ বৈশিষ্ট্য হল যে এটি পূর্বে সিস্টেম বারগুলিকে বাদ দিয়েছিল।
কনফিগারেশন আকার সাধারণত সম্পদ নির্বাচনের জন্য ব্যবহৃত হয়, যেমন /res/layout-h500dp , এবং এটি এখনও একটি বৈধ ব্যবহারের ক্ষেত্রে। যাইহোক, লেআউট গণনার জন্য এটি ব্যবহার করা সবসময় নিরুৎসাহিত করা হয়েছে। আপনি যদি তা করেন তবে আপনার এখনই এটি থেকে দূরে সরে যাওয়া উচিত। আপনার ব্যবহারের ক্ষেত্রে নির্ভর করে আরও উপযুক্ত কিছু দিয়ে Configuration ব্যবহার প্রতিস্থাপন করা উচিত।
আপনি যদি লেআউটটি গণনা করতে এটি ব্যবহার করেন, তাহলে একটি উপযুক্ত ViewGroup ব্যবহার করুন, যেমন CoordinatorLayout বা ConstraintLayout । আপনি যদি সিস্টেম ন্যাভিবারের উচ্চতা নির্ধারণ করতে এটি ব্যবহার করেন, WindowInsets ব্যবহার করুন। আপনি যদি আপনার অ্যাপ উইন্ডোর বর্তমান আকার জানতে চান তাহলে computeCurrentWindowMetrics ব্যবহার করুন।
নিম্নলিখিত তালিকা এই পরিবর্তন দ্বারা প্রভাবিত ক্ষেত্র বর্ণনা করে:
-
Configuration.screenWidthDpএবংscreenHeightDpমাপ আর সিস্টেম বার বাদ দেয় না। -
Configuration.smallestScreenWidthDpপরোক্ষভাবেscreenWidthDpএবংscreenHeightDpএর পরিবর্তন দ্বারা প্রভাবিত হয়। -
Configuration.orientationপরোক্ষভাবে ক্লোজ-টু-স্কোয়ার ডিভাইসেscreenWidthDpএবংscreenHeightDpএর পরিবর্তন দ্বারা প্রভাবিত হয়। -
Display.getSize(Point)Configurationপরিবর্তনের দ্বারা পরোক্ষভাবে প্রভাবিত হয়। এপিআই লেভেল 30 থেকে শুরু করে এটি অবহেলিত ছিল। -
Display.getMetrics()এপিআই লেভেল 33 থেকে ইতিমধ্যেই এভাবে কাজ করেছে।
elegantTextHeight অ্যাট্রিবিউট ডিফল্টে সত্য
অ্যান্ড্রয়েড 15 (API স্তর 35) লক্ষ্য করা অ্যাপগুলির জন্য, elegantTextHeight TextView বৈশিষ্ট্যটি ডিফল্টরূপে true হয়ে যায়, ডিফল্টরূপে ব্যবহৃত কমপ্যাক্ট ফন্টটিকে এমন কিছু স্ক্রিপ্টের সাথে প্রতিস্থাপন করে যেখানে বড় উল্লম্ব মেট্রিক্স রয়েছে যা অনেক বেশি পাঠযোগ্য। বিন্যাস ভাঙা প্রতিরোধ করার জন্য কমপ্যাক্ট ফন্ট চালু করা হয়েছিল; অ্যান্ড্রয়েড 13 (এপিআই লেভেল 33) fallbackLineSpacing অ্যাট্রিবিউট ব্যবহার করে টেক্সট লেআউটকে উল্লম্ব উচ্চতা প্রসারিত করার অনুমতি দিয়ে এই ধরনের অনেক ভাঙন প্রতিরোধ করে।
অ্যান্ড্রয়েড 15-এ, কমপ্যাক্ট ফন্টটি এখনও সিস্টেমে রয়ে গেছে, তাই আপনার অ্যাপটি আগের মতো একই আচরণ পেতে elegantTextHeight false সেট করতে পারে, তবে এটি আসন্ন রিলিজে সমর্থিত হওয়ার সম্ভাবনা কম। সুতরাং, যদি আপনার অ্যাপ নিম্নলিখিত স্ক্রিপ্টগুলিকে সমর্থন করে: আরবি, লাও, মায়ানমার, তামিল, গুজরাটি, কন্নড়, মালয়ালম, ওড়িয়া, তেলুগু বা থাই, তাহলে আপনার অ্যাপটি true elegantTextHeight সেট করে পরীক্ষা করুন।

elegantTextHeight আচরণ। 
elegantTextHeight আচরণ।জটিল অক্ষর আকারের জন্য TextView প্রস্থ পরিবর্তন
অ্যান্ড্রয়েডের পূর্ববর্তী সংস্করণগুলিতে, কিছু অভিশাপযুক্ত ফন্ট বা ভাষা যা জটিল আকার ধারণ করে সেগুলি পূর্ববর্তী বা পরবর্তী অক্ষরের ক্ষেত্রে অক্ষরগুলি আঁকতে পারে। কিছু ক্ষেত্রে, এই জাতীয় অক্ষরগুলি শুরুতে বা শেষের অবস্থানে ক্লিপ করা হয়েছিল। অ্যান্ড্রয়েড 15 থেকে শুরু করে, একটি TextView এই ধরনের অক্ষরগুলির জন্য পর্যাপ্ত জায়গা আঁকার জন্য প্রস্থ বরাদ্দ করে এবং ক্লিপিং রোধ করতে অ্যাপগুলিকে বাম দিকে অতিরিক্ত প্যাডিংয়ের অনুরোধ করার অনুমতি দেয়।
যেহেতু এই পরিবর্তনটি একটি TextView কিভাবে প্রস্থ নির্ধারণ করে তা প্রভাবিত করে, তাই যদি অ্যাপটি Android 15 (API লেভেল 35) বা তার বেশি লক্ষ্য করে তাহলে TextView ডিফল্টভাবে আরও প্রস্থ বরাদ্দ করে। আপনি TextView এ setUseBoundsForWidth API-কে কল করে এই আচরণটি সক্ষম বা অক্ষম করতে পারেন।
যেহেতু বাম প্যাডিং যোগ করার ফলে বিদ্যমান লেআউটগুলির জন্য একটি মিসলাইনমেন্ট হতে পারে, প্যাডিংটি ডিফল্টরূপে যোগ করা হয় না এমনকি Android 15 বা উচ্চতরকে লক্ষ্য করে এমন অ্যাপগুলির জন্যও। যাইহোক, আপনি setShiftDrawingOffsetForStartOverhang এ কল করে ক্লিপিং প্রতিরোধে অতিরিক্ত প্যাডিং যোগ করতে পারেন।
নিম্নলিখিত উদাহরণগুলি দেখায় কিভাবে এই পরিবর্তনগুলি কিছু ফন্ট এবং ভাষার জন্য পাঠ্য বিন্যাস উন্নত করতে পারে৷

<TextView android:fontFamily="cursive" android:text="java" />

<TextView android:fontFamily="cursive" android:text="java" android:useBoundsForWidth="true" android:shiftDrawingOffsetForStartOverhang="true" />

<TextView android:text="คอมพิวเตอร์" />

<TextView android:text="คอมพิวเตอร์" android:useBoundsForWidth="true" android:shiftDrawingOffsetForStartOverhang="true" />
EditText-এর জন্য স্থানীয়-সচেতন ডিফল্ট লাইন উচ্চতা
অ্যান্ড্রয়েডের পূর্ববর্তী সংস্করণগুলিতে, বর্তমান লোকেলের সাথে মেলে ফন্টের লাইনের উচ্চতা মেটাতে পাঠ্য বিন্যাস পাঠ্যের উচ্চতাকে প্রসারিত করে। উদাহরণস্বরূপ, যদি বিষয়বস্তু জাপানি ভাষায় হয়, কারণ জাপানি ফন্টের লাইনের উচ্চতা একটি ল্যাটিন ফন্টের চেয়ে সামান্য বড়, পাঠ্যের উচ্চতা কিছুটা বড় হয়ে গেছে। যাইহোক, লাইনের উচ্চতায় এই পার্থক্য থাকা সত্ত্বেও, EditText উপাদানটি অভিন্ন আকারের ছিল, লোকেল ব্যবহার করা নির্বিশেষে, নিম্নলিখিত ছবিতে চিত্রিত হয়েছে:

EditText উপাদানের প্রতিনিধিত্বকারী তিনটি বাক্স যা ইংরেজি (en), জাপানি (ja), এবং বার্মিজ (my) থেকে পাঠ্য ধারণ করতে পারে। EditText এর উচ্চতা একই, যদিও এই ভাষাগুলির একে অপরের থেকে আলাদা লাইন উচ্চতা রয়েছে। Android 15 (API লেভেল 35) লক্ষ্য করা অ্যাপগুলির জন্য, একটি ন্যূনতম লাইন উচ্চতা এখন EditText এর জন্য নির্দিষ্ট লোকেলের রেফারেন্স ফন্টের সাথে মেলে, যা নিম্নলিখিত ছবিতে দেখানো হয়েছে:

EditText উপাদানের প্রতিনিধিত্বকারী তিনটি বাক্স যা ইংরেজি (en), জাপানি (ja), এবং বার্মিজ (my) থেকে পাঠ্য ধারণ করতে পারে। EditText এর উচ্চতায় এখন এই ভাষার ফন্টগুলির জন্য ডিফল্ট লাইনের উচ্চতা মিটমাট করার জন্য স্থান রয়েছে। প্রয়োজনে, আপনার অ্যাপ useLocalePreferredLineHeightForMinimum অ্যাট্রিবিউটটি false নির্দিষ্ট করে পূর্ববর্তী আচরণ পুনরুদ্ধার করতে পারে এবং আপনার অ্যাপটি Kotlin এবং Java এ setMinimumFontMetrics API ব্যবহার করে কাস্টম ন্যূনতম উল্লম্ব মেট্রিক্স সেট করতে পারে।
ক্যামেরা এবং মিডিয়া
Android 15 অ্যানড্রয়েড 15 বা উচ্চতরকে লক্ষ্য করে এমন অ্যাপগুলির জন্য ক্যামেরা এবং মিডিয়া আচরণে নিম্নলিখিত পরিবর্তনগুলি করে৷
অডিও ফোকাস অনুরোধের উপর সীমাবদ্ধতা
যে অ্যাপগুলি Android 15 (API স্তর 35) টার্গেট করে সেগুলিকে অবশ্যই শীর্ষ অ্যাপ হতে হবে বা অডিও ফোকাসের অনুরোধ করার জন্য একটি ফোরগ্রাউন্ড পরিষেবা চালাতে হবে৷ যদি কোনো অ্যাপ ফোকাসের অনুরোধ করার চেষ্টা করে যখন এটি এই প্রয়োজনীয়তার একটি পূরণ না করে, তাহলে কলটি AUDIOFOCUS_REQUEST_FAILED ফেরত দেয়।
আপনি অডিও ফোকাস পরিচালনা অডিও ফোকাস সম্পর্কে আরও জানতে পারেন।
নন-SDK সীমাবদ্ধতা আপডেট করা হয়েছে
Android 15-এ Android বিকাশকারীদের সাথে সহযোগিতা এবং সর্বশেষ অভ্যন্তরীণ পরীক্ষার উপর ভিত্তি করে সীমাবদ্ধ নন-SDK ইন্টারফেসের আপডেট করা তালিকা অন্তর্ভুক্ত রয়েছে। যখনই সম্ভব, আমরা নিশ্চিত করি যে আমরা নন-SDK ইন্টারফেস সীমাবদ্ধ করার আগে সর্বজনীন বিকল্পগুলি উপলব্ধ রয়েছে।
যদি আপনার অ্যাপটি Android 15 কে টার্গেট না করে, তবে এই পরিবর্তনগুলির মধ্যে কিছু আপনাকে অবিলম্বে প্রভাবিত করতে পারে না। যাইহোক, আপনার অ্যাপের টার্গেট API স্তরের উপর নির্ভর করে কিছু নন-SDK ইন্টারফেস অ্যাক্সেস করা আপনার অ্যাপের পক্ষে সম্ভব হলেও, যেকোনো নন-SDK পদ্ধতি বা ক্ষেত্র ব্যবহার করলে সবসময় আপনার অ্যাপ ভেঙে যাওয়ার উচ্চ ঝুঁকি থাকে।
আপনি যদি নিশ্চিত না হন যে আপনার অ্যাপ নন-SDK ইন্টারফেস ব্যবহার করে, তাহলে আপনি খুঁজে বের করতে আপনার অ্যাপ পরীক্ষা করতে পারেন। যদি আপনার অ্যাপ নন-SDK ইন্টারফেসের উপর নির্ভর করে, তাহলে আপনার SDK বিকল্পগুলিতে স্থানান্তরের পরিকল্পনা শুরু করা উচিত। তা সত্ত্বেও, আমরা বুঝি যে কিছু অ্যাপে নন-SDK ইন্টারফেস ব্যবহার করার জন্য বৈধ ব্যবহারের ক্ষেত্রে রয়েছে। আপনি যদি আপনার অ্যাপে একটি বৈশিষ্ট্যের জন্য একটি নন-SDK ইন্টারফেস ব্যবহার করার বিকল্প খুঁজে না পান, তাহলে আপনাকে একটি নতুন সর্বজনীন API অনুরোধ করা উচিত।
অ্যান্ড্রয়েডের এই প্রকাশের পরিবর্তনগুলি সম্পর্কে আরও জানতে, Android 15-এ নন-SDK ইন্টারফেস সীমাবদ্ধতার আপডেটগুলি দেখুন। সাধারণত নন-SDK ইন্টারফেস সম্পর্কে আরও জানতে, নন-SDK ইন্টারফেসের উপর সীমাবদ্ধতা দেখুন।