Android 4.2 APIs

API স্তর: 17

Android 4.2 ( JELLY_BEAN_MR1 ) হল জেলি বিন রিলিজের একটি আপডেট যা ব্যবহারকারী এবং অ্যাপ বিকাশকারীদের জন্য নতুন বৈশিষ্ট্যগুলি অফার করে৷ এই নথিটি বিকাশকারীদের জন্য সবচেয়ে উল্লেখযোগ্য এবং দরকারী নতুন APIগুলির একটি ভূমিকা প্রদান করে৷

একজন অ্যাপ ডেভেলপার হিসেবে, আপনার যত তাড়াতাড়ি সম্ভব SDK ম্যানেজার থেকে Android 4.2 সিস্টেম ইমেজ এবং SDK প্ল্যাটফর্ম ডাউনলোড করা উচিত। আপনার অ্যাপটি পরীক্ষা করার জন্য Android 4.2 চালিত কোনো ডিভাইস না থাকলে, Android এমুলেটরে আপনার অ্যাপটি পরীক্ষা করতে Android 4.2 সিস্টেম ইমেজ ব্যবহার করুন। তারপরে সর্বশেষ APIs ব্যবহার শুরু করতে Android 4.2 প্ল্যাটফর্মের বিপরীতে আপনার অ্যাপগুলি তৈরি করুন৷

Android 4.2 চালিত ডিভাইসগুলির জন্য আপনার অ্যাপটিকে আরও ভালভাবে অপ্টিমাইজ করতে, আপনার targetSdkVersion "17" এ সেট করা উচিত, এটি একটি Android 4.2 সিস্টেম ছবিতে ইনস্টল করুন, এটি পরীক্ষা করুন, তারপর এই পরিবর্তনের সাথে একটি আপডেট প্রকাশ করুন৷

আপনি Android 4.2-এ APIs ব্যবহার করতে পারেন এবং আপনার কোডে শর্ত যোগ করে পুরানো সংস্করণগুলিকে সমর্থন করতে পারেন যা আপনার minSdkVersion দ্বারা সমর্থিত নয় এমন APIগুলি চালানোর আগে সিস্টেম API স্তরের জন্য পরীক্ষা করে। পশ্চাদগামী-সামঞ্জস্যতা বজায় রাখার বিষয়ে আরও জানতে, পশ্চাদপদ-সামঞ্জস্যপূর্ণ UI তৈরি করা পড়ুন।

API স্তরগুলি কীভাবে কাজ করে সে সম্পর্কে আরও তথ্য এপিআই স্তর কী?

গুরুত্বপূর্ণ আচরণ পরিবর্তন

আপনি যদি আগে অ্যান্ড্রয়েডের জন্য একটি অ্যাপ প্রকাশ করে থাকেন, তাহলে নিম্নলিখিত পরিবর্তনগুলি সম্পর্কে সচেতন হন যা আপনার অ্যাপের আচরণকে প্রভাবিত করতে পারে:

  • বিষয়বস্তু প্রদানকারীরা আর ডিফল্টরূপে রপ্তানি হয় না। অর্থাৎ, android:exported অ্যাট্রিবিউটের ডিফল্ট মান এখন “false" ৷ যদি এটি গুরুত্বপূর্ণ হয় যে অন্যান্য অ্যাপগুলি আপনার সামগ্রী প্রদানকারীকে অ্যাক্সেস করতে সক্ষম হবে, তাহলে আপনাকে এখন স্পষ্টভাবে android:exported="true" সেট করতে হবে৷

    আপনি android:targetSdkVersion বা android:minSdkVersion 17 বা উচ্চতর সেট করলেই এই পরিবর্তন কার্যকর হবে৷ অন্যথায়, Android 4.2 এবং উচ্চতর সংস্করণে চললেও ডিফল্ট মান এখনও “true" থাকে৷

  • Android এর পূর্ববর্তী সংস্করণগুলির তুলনায়, ব্যবহারকারীর অবস্থানের ফলাফল কম সঠিক হতে পারে যদি আপনার অ্যাপ ACCESS_COARSE_LOCATION অনুমতির অনুরোধ করে কিন্তু ACCESS_FINE_LOCATION অনুমতির অনুরোধ না করে।

    ব্যবহারকারীদের গোপনীয়তা প্রত্যাশা পূরণ করার জন্য যখন আপনার অ্যাপ মোটা অবস্থানের জন্য অনুমতির অনুরোধ করে (এবং সূক্ষ্ম অবস্থান নয়), সিস্টেমটি ব্যবহারকারীর অবস্থান অনুমান প্রদান করবে না যা একটি শহর ব্লকের চেয়ে বেশি সঠিক।

  • Settings.System দ্বারা সংজ্ঞায়িত কিছু ডিভাইস সেটিংস এখন শুধুমাত্র পঠনযোগ্য৷ আপনার অ্যাপ যদি Settings.System এ সংজ্ঞায়িত সেটিংসে পরিবর্তন লেখার চেষ্টা করে যা Settings.Global এ চলে গেছে, তাহলে Android 4.2 এবং উচ্চতর সংস্করণে চলার সময় লেখার ক্রিয়াকলাপ নিঃশব্দে ব্যর্থ হবে৷

    এমনকি android:targetSdkVersion এবং android:minSdkVersion এর জন্য আপনার মান 17-এর থেকে কম হলেও, আপনার অ্যাপ Android 4.2 এবং উচ্চতর সংস্করণে চলাকালীন Settings.Global এ সরানো সেটিংস পরিবর্তন করতে সক্ষম নয়৷

  • যদি আপনার অ্যাপ WebView ব্যবহার করে, তাহলে Android 4.2 নিরাপত্তার একটি অতিরিক্ত স্তর যোগ করে যাতে আপনি আরও নিরাপদে আপনার Android কোডে JavaScript আবদ্ধ করতে পারেন। আপনি যদি আপনার targetSdkVersion 17 বা তার বেশি সেট করেন, তাহলে আপনাকে এখন যে কোনো পদ্ধতিতে @JavascriptInterface টীকা যোগ করতে হবে যা আপনি আপনার JavaScript-এ উপলব্ধ করতে চান (পদ্ধতিটি অবশ্যই সর্বজনীন হতে হবে)। আপনি টীকা প্রদান না করলে, Android 4.2 বা উচ্চতর সংস্করণে চলাকালীন আপনার WebView এর একটি ওয়েব পৃষ্ঠার মাধ্যমে পদ্ধতিটি অ্যাক্সেসযোগ্য নয়৷ আপনি যদি targetSdkVersion 16 বা তার নিচে সেট করেন, তাহলে টীকাটির প্রয়োজন নেই, তবে আমরা সুপারিশ করছি যে আপনি আপনার টার্গেট সংস্করণ আপডেট করুন এবং অতিরিক্ত নিরাপত্তার জন্য টীকা যোগ করুন।

    অ্যান্ড্রয়েড কোডে জাভাস্ক্রিপ্ট কোড বাঁধাই সম্পর্কে আরও পড়ুন।

দিবাস্বপ্ন

Daydream Android ডিভাইসের জন্য একটি নতুন ইন্টারেক্টিভ স্ক্রিনসেভার মোড। এটি স্বয়ংক্রিয়ভাবে সক্রিয় হয় যখন ডিভাইসটি একটি ডকে ঢোকানো হয় বা যখন একটি চার্জারে প্লাগ ইন করার সময় ডিভাইসটি নিষ্ক্রিয় অবস্থায় থাকে (স্ক্রিনটি বন্ধ করার পরিবর্তে)। দিবাস্বপ্ন একবারে একটি স্বপ্ন প্রদর্শন করে, যা একটি সম্পূর্ণরূপে দৃশ্যমান, প্যাসিভ ডিসপ্লে হতে পারে যা স্পর্শ করলে বাতিল হয়ে যায়, অথবা ইনপুট ইভেন্টের সম্পূর্ণ স্যুটের জন্য ইন্টারেক্টিভ এবং প্রতিক্রিয়াশীল হতে পারে। আপনার স্বপ্নগুলি আপনার অ্যাপের প্রক্রিয়ায় চলে এবং ভিউ, লেআউট এবং অ্যানিমেশন সহ Android UI টুলকিটে সম্পূর্ণ অ্যাক্সেস রয়েছে, তাই তারা লাইভ ওয়ালপেপার বা অ্যাপ উইজেটগুলির চেয়ে আরও নমনীয় এবং শক্তিশালী।

DreamService এর একটি সাবক্লাস বাস্তবায়ন করে আপনি Daydream-এর জন্য একটি স্বপ্ন তৈরি করতে পারেন। DreamService API গুলিকে Activity মতো করে ডিজাইন করা হয়েছে৷ আপনার স্বপ্নের জন্য UI নির্দিষ্ট করতে, একটি লেআউট রিসোর্স আইডি পাস করুন বা আপনার কাছে একটি উইন্ডো থাকার পরে যেকোনো সময়ে setContentView() তে View , যেমন onAttachedToWindow() কলব্যাক থেকে।

DreamService ক্লাস বেস Service API-এর উপরে অন্যান্য গুরুত্বপূর্ণ লাইফসাইকেল কলব্যাক পদ্ধতি প্রদান করে, যেমন onDreamingStarted() , onDreamingStopped() এবং onDetachedFromWindow() । আপনি আপনার অ্যাপ থেকে একটি DreamService আরম্ভ করতে পারবেন না—এটি সিস্টেম দ্বারা স্বয়ংক্রিয়ভাবে চালু হয়।

যদি আপনার স্বপ্নটি ইন্টারেক্টিভ হয়, তাহলে আপনি আরও বিস্তারিত বা নিয়ন্ত্রণের জন্য ব্যবহারকারীকে আপনার অ্যাপের সম্পূর্ণ UI-তে পাঠাতে স্বপ্ন থেকে একটি কার্যকলাপ শুরু করতে পারেন। আপনি স্বপ্ন শেষ করতে finish() ব্যবহার করতে পারেন যাতে ব্যবহারকারী নতুন কার্যকলাপ দেখতে পারেন।

সিস্টেমে আপনার দিবাস্বপ্ন উপলব্ধ করতে, আপনার ম্যানিফেস্ট ফাইলে একটি <service> উপাদান সহ আপনার DreamService ঘোষণা করুন। তারপরে আপনাকে অবশ্যই "android.service.dreams.DreamService" অ্যাকশন সহ একটি অভিপ্রায় ফিল্টার অন্তর্ভুক্ত করতে হবে। যেমন:

<service android:name=".MyDream" android:exported="true"
    android:icon="@drawable/dream_icon" android:label="@string/dream_label" >
    <intent-filter>
        <action android:name="android.service.dreams.DreamService" />
        <category android:name="android.intent.category.DEFAULT" />
    </intent-filter>
</service>

DreamService আরও কিছু দরকারী পদ্ধতি রয়েছে যা সম্পর্কে সচেতন হতে হবে:

  • setInteractive(boolean) নিয়ন্ত্রণ করে যে স্বপ্নটি ইনপুট ইভেন্টগুলি গ্রহণ করে বা ব্যবহারকারীর ইনপুটের সাথে সাথে প্রস্থান করে। যদি স্বপ্নটি ইন্টারেক্টিভ হয়, তাহলে ব্যবহারকারী স্বপ্ন থেকে প্রস্থান করতে ব্যাক বা হোম বোতাম ব্যবহার করতে পারেন অথবা আপনি স্বপ্ন বন্ধ করতে finish() কল করতে পারেন।
  • আপনি যদি একটি সম্পূর্ণ নিমজ্জিত ডিসপ্লে চান, আপনি স্ট্যাটাস বার লুকানোর জন্য setFullscreen() কল করতে পারেন।
  • Daydream শুরু হওয়ার আগে, ডিসপ্লেটি ম্লান হয়ে যায় যাতে ব্যবহারকারীকে সংকেত দেয় যে নিষ্ক্রিয় সময় শেষ হয়ে আসছে। setScreenBright(true) কল করলে আপনি ডিসপ্লেটিকে তার স্বাভাবিক উজ্জ্বলতায় সেট করতে পারবেন।

আরও তথ্যের জন্য, DreamService ডকুমেন্টেশন দেখুন।

সেকেন্ডারি ডিসপ্লে

অ্যান্ড্রয়েড এখন আপনার অ্যাপটিকে অতিরিক্ত স্ক্রিনে অনন্য সামগ্রী প্রদর্শন করার অনুমতি দেয় যা ব্যবহারকারীর ডিভাইসের সাথে একটি তারযুক্ত সংযোগ বা Wi-Fi এর মাধ্যমে সংযুক্ত থাকে৷ একটি মাধ্যমিক প্রদর্শনের জন্য অনন্য সামগ্রী তৈরি করতে, Presentation ক্লাস প্রসারিত করুন এবং onCreate() কলব্যাক প্রয়োগ করুন। onCreate() এর মধ্যে, setContentView() কল করে সেকেন্ডারি প্রদর্শনের জন্য আপনার UI নির্দিষ্ট করুন। Dialog ক্লাসের এক্সটেনশন হিসেবে, Presentation ক্লাস সেই অঞ্চল প্রদান করে যেখানে আপনার অ্যাপ সেকেন্ডারি ডিসপ্লেতে একটি অনন্য UI প্রদর্শন করতে পারে।

সেকেন্ডারি ডিসপ্লে সনাক্ত করতে যেখানে আপনি আপনার Presentation প্রদর্শন করতে পারেন, DisplayManager বা MediaRouter API ব্যবহার করুন। যদিও DisplayManager API গুলি আপনাকে একাধিক ডিসপ্লে গণনা করার অনুমতি দেয় যা একসাথে সংযুক্ত হতে পারে, আপনার সাধারণত উপস্থাপনাগুলির জন্য সিস্টেমের ডিফল্ট ডিসপ্লেতে দ্রুত অ্যাক্সেস করার পরিবর্তে MediaRouter ব্যবহার করা উচিত।

আপনার উপস্থাপনার জন্য ডিফল্ট প্রদর্শন পেতে, MediaRouter.getSelectedRoute() কল করুন এবং এটি পাস করুন ROUTE_TYPE_LIVE_VIDEO । এটি একটি MediaRouter.RouteInfo অবজেক্ট প্রদান করে যা ভিডিও উপস্থাপনার জন্য সিস্টেমের বর্তমানে নির্বাচিত রুট বর্ণনা করে। যদি MediaRouter.RouteInfo শূন্য না হয়, তাহলে সংযোগ করা প্রদর্শনের প্রতিনিধিত্বকারী Display পেতে getPresentationDisplay() কল করুন।

তারপর আপনি আপনার Presentation ক্লাসের জন্য একটি কন্সট্রাক্টরের কাছে Display অবজেক্টটি পাস করে আপনার উপস্থাপনা প্রদর্শন করতে পারেন। আপনার উপস্থাপনা এখন সেকেন্ডারি ডিসপ্লেতে প্রদর্শিত হবে।

একটি নতুন ডিসপ্লে সংযুক্ত করা হলে রানটাইমে সনাক্ত করতে, MediaRouter.SimpleCallback এর একটি উদাহরণ তৈরি করুন যাতে আপনি onRoutePresentationDisplayChanged() কলব্যাক পদ্ধতিটি প্রয়োগ করেন, যা একটি নতুন উপস্থাপনা প্রদর্শন সংযুক্ত হলে সিস্টেম কল করবে। তারপর ROUTE_TYPE_LIVE_VIDEO রুট টাইপ সহ MediaRouter.addCallback() এ পাস করে MediaRouter.SimpleCallback নিবন্ধন করুন। আপনি যখন onRoutePresentationDisplayChanged() এ একটি কল পান, তখন উপরে উল্লিখিত হিসাবে কেবল MediaRouter.getSelectedRoute() কল করুন।

সেকেন্ডারি স্ক্রিনের জন্য আপনার Presentation UI আরও অপ্টিমাইজ করতে, আপনি আপনার অ্যাপ্লিকেশন বা কার্যকলাপে যে <style> প্রয়োগ করেছেন তাতে android:presentationTheme অ্যাট্রিবিউট উল্লেখ করে একটি ভিন্ন থিম প্রয়োগ করতে পারেন।

মনে রাখবেন যে ব্যবহারকারীর ডিভাইসের সাথে সংযুক্ত স্ক্রীনগুলির প্রায়শই একটি বড় স্ক্রীনের আকার থাকে এবং সম্ভবত একটি ভিন্ন স্ক্রীন ঘনত্ব থাকে৷ যেহেতু স্ক্রিনের বৈশিষ্ট্যগুলি ভিন্ন হতে পারে, তাই আপনার এমন সংস্থানগুলি সরবরাহ করা উচিত যা বিশেষভাবে এই জাতীয় বড় প্রদর্শনের জন্য অপ্টিমাইজ করা হয়েছে। আপনি যদি আপনার Presentation থেকে অতিরিক্ত সংস্থানগুলির জন্য অনুরোধ করতে চান, তাহলে প্রদর্শনের সাথে সম্পর্কিত Resources অবজেক্ট পেতে getContext() .getResources() এ কল করুন। এটি আপনার অ্যাপ থেকে উপযুক্ত সংস্থানগুলি সরবরাহ করে যা সেকেন্ডারি ডিসপ্লের স্ক্রীনের আকার এবং ঘনত্বের জন্য সবচেয়ে উপযুক্ত।

আরও তথ্য এবং কিছু কোড নমুনার জন্য, Presentation ক্লাস ডকুমেন্টেশন দেখুন।

লকস্ক্রিন উইজেট

অ্যান্ড্রয়েড এখন ব্যবহারকারীদের লক স্ক্রিনে অ্যাপ উইজেট যোগ করার অনুমতি দেয়। আপনার অ্যাপ উইজেটটিকে লক স্ক্রিনে ব্যবহারের জন্য উপলব্ধ করতে, আপনার XML ফাইলে android:widgetCategory অ্যাট্রিবিউট যোগ করুন যা AppWidgetProviderInfo নির্দিষ্ট করে। এই বৈশিষ্ট্য দুটি মান সমর্থন করে: home_screen এবং keyguard । ডিফল্টরূপে, বৈশিষ্ট্যটি home_screen সেট করা থাকে যাতে ব্যবহারকারীরা হোম স্ক্রিনে আপনার অ্যাপ উইজেট যোগ করতে পারে। আপনি যদি চান যে আপনার অ্যাপ উইজেটটি লক স্ক্রিনেও পাওয়া যাবে, তাহলে keyguard মান যোগ করুন:

<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    ...
    android:widgetCategory="keyguard|home_screen">
</appwidget-provider>

android:initialKeyguardLayout অ্যাট্রিবিউট সহ লক স্ক্রিনে থাকাকালীন আপনার অ্যাপ উইজেটের জন্য একটি প্রাথমিক লেআউটও নির্দিষ্ট করা উচিত। এটি android:initialLayout এর মতো একইভাবে কাজ করে, এতে এটি একটি লেআউট প্রদান করে যা আপনার অ্যাপ উইজেট আরম্ভ না হওয়া পর্যন্ত এবং লেআউট আপডেট করতে সক্ষম হওয়া পর্যন্ত অবিলম্বে উপস্থিত হতে পারে।

লক স্ক্রিনের জন্য অ্যাপ উইজেট তৈরি করার বিষয়ে আরও তথ্যের জন্য, লক স্ক্রিনে থাকাকালীন আপনার অ্যাপ উইজেটকে সঠিকভাবে আকার দেওয়া সহ, অ্যাপ উইজেট নির্দেশিকা দেখুন।

একাধিক ব্যবহারকারী

অ্যান্ড্রয়েড এখন ট্যাবলেটের মতো শেয়ারযোগ্য ডিভাইসে একাধিক ব্যবহারকারীর স্থানের অনুমতি দেয়। একটি ডিভাইসে প্রতিটি ব্যবহারকারীর নিজস্ব অ্যাকাউন্ট, অ্যাপস, সিস্টেম সেটিংস, ফাইল এবং অন্য কোনো ব্যবহারকারী-সম্পর্কিত ডেটা থাকে।

একজন অ্যাপ ডেভেলপার হিসেবে, আপনার অ্যাপকে একটি ডিভাইসে একাধিক ব্যবহারকারীর সাথে সঠিকভাবে কাজ করার জন্য আপনাকে আলাদা কিছু করতে হবে না। একটি ডিভাইসে কতজন ব্যবহারকারী থাকতে পারে তা নির্বিশেষে, আপনার অ্যাপ একটি প্রদত্ত ব্যবহারকারীর জন্য যে ডেটা সংরক্ষণ করে তা অন্য ব্যবহারকারীদের জন্য আপনার অ্যাপ সংরক্ষণ করে এমন ডেটা থেকে আলাদা রাখা হয়। সিস্টেমটি ট্র্যাক রাখে কোন ব্যবহারকারীর ডেটা ব্যবহারকারীর প্রক্রিয়ার অন্তর্গত যেখানে আপনার অ্যাপ চলছে এবং আপনার অ্যাপটিকে শুধুমাত্র সেই ব্যবহারকারীর ডেটাতে অ্যাক্সেস প্রদান করে এবং অন্য ব্যবহারকারীদের ডেটা অ্যাক্সেসের অনুমতি দেয় না।

বহু-ব্যবহারকারী পরিবেশে ডেটা সংরক্ষণ করা

যখনই আপনার অ্যাপ ব্যবহারকারীর পছন্দগুলি সংরক্ষণ করে, একটি ডাটাবেস তৈরি করে, বা ব্যবহারকারীর অভ্যন্তরীণ বা বাহ্যিক সঞ্চয়স্থানে একটি ফাইল লেখে, সেই ডেটা শুধুমাত্র সেই ব্যবহারকারী হিসাবে চালানোর সময় অ্যাক্সেসযোগ্য।

আপনার অ্যাপটি একটি বহু-ব্যবহারকারী পরিবেশে সঠিকভাবে আচরণ করছে তা নিশ্চিত করার জন্য, হার্ড-কোডেড পাথ ব্যবহার করে আপনার অভ্যন্তরীণ অ্যাপ ডিরেক্টরি বা বাহ্যিক স্টোরেজ অবস্থানের উল্লেখ করবেন না এবং পরিবর্তে সর্বদা উপযুক্ত API ব্যবহার করুন:

প্রদত্ত ব্যবহারকারীর জন্য ডেটা সংরক্ষণ করতে আপনি এই APIগুলির মধ্যে কোনটি ব্যবহার করেন না কেন, একটি ভিন্ন ব্যবহারকারী হিসাবে চলাকালীন ডেটা অ্যাক্সেসযোগ্য হবে না। আপনার অ্যাপের দৃষ্টিকোণ থেকে, প্রতিটি ব্যবহারকারী একটি সম্পূর্ণ আলাদা ডিভাইসে চলছে।

বহু-ব্যবহারকারী পরিবেশে ব্যবহারকারীদের সনাক্তকরণ

যদি আপনার অ্যাপ অনন্য ব্যবহারকারীদের সনাক্ত করতে চায় যেমন বিশ্লেষণ সংগ্রহ করতে বা অন্যান্য অ্যাকাউন্ট অ্যাসোসিয়েশন তৈরি করতে, তাহলে আপনাকে অনন্য ইনস্টলেশন শনাক্ত করার জন্য প্রস্তাবিত অনুশীলনগুলি অনুসরণ করা উচিত। আপনার অ্যাপটি প্রথমবার শুরু হলে একটি নতুন UUID তৈরি করার মাধ্যমে, আপনি নিশ্চিত যে প্রতিটি ব্যবহারকারীকে ট্র্যাক করার জন্য একটি অনন্য আইডি পাবেন, তা নির্বিশেষে একটি ডিভাইসে কতজন ব্যবহারকারী আপনার অ্যাপ ইনস্টল করুন। বিকল্পভাবে, আপনি আপনার সার্ভার থেকে আনা একটি স্থানীয় টোকেন সংরক্ষণ করতে পারেন বা Google ক্লাউড মেসেজিং দ্বারা প্রদত্ত রেজিস্ট্রেশন আইডি ব্যবহার করতে পারেন৷

সতর্ক থাকুন যে আপনার অ্যাপ যদি হার্ডওয়্যার ডিভাইস শনাক্তকারীর (যেমন ওয়াইফাই MAC ঠিকানা বা SERIAL নম্বর) একটির জন্য অনুরোধ করে তবে তারা প্রতিটি ব্যবহারকারীর জন্য একই মান প্রদান করবে কারণ এই শনাক্তকারীগুলি হার্ডওয়্যারের সাথে আবদ্ধ এবং ব্যবহারকারীর সাথে নয়। আইডেন্টিফাইং অ্যাপ ইন্সটলেশন ব্লগ পোস্টে আলোচনা করা এই শনাক্তকারীরা যে অন্যান্য সমস্যাগুলি উপস্থাপন করে তা উল্লেখ করার কথা নয়।

নতুন গ্লোবাল সেটিংস

Settings.Global যোগ করে একাধিক ব্যবহারকারীকে সমর্থন করার জন্য সিস্টেম সেটিংস আপডেট করা হয়েছে। সেটিংসের এই সংগ্রহটি Settings.Secure সেটিংসের অনুরূপ কারণ এগুলি শুধুমাত্র পঠনযোগ্য, কিন্তু ডিভাইসের সমস্ত ব্যবহারকারীর স্থান জুড়ে বিশ্বব্যাপী প্রযোজ্য৷

Settings.System বা Settings.Secure থেকে বেশ কিছু বিদ্যমান সেটিংস এখানে স্থানান্তর করা হয়েছে। যদি আপনার অ্যাপটি বর্তমানে Settings.System পূর্বে সংজ্ঞায়িত সেটিংসে পরিবর্তন করে থাকে (যেমন AIRPLANE_MODE_ON ), ​​তাহলে আপনার আশা করা উচিত যে সেটিংস Settings.Global সরানো হলে Android 4.2 বা তার বেশি চলমান ডিভাইসে এটি আর কাজ করবে না। আপনি Settings.Global এ থাকা সেটিংস পড়া চালিয়ে যেতে পারেন, কিন্তু যেহেতু সেটিংসগুলি আর অ্যাপগুলিকে পরিবর্তন করার জন্য নিরাপদ বলে মনে করা হয় না, তাই এটি করার চেষ্টা নিঃশব্দে ব্যর্থ হবে এবং আপনার অ্যাপ চালু করার সময় সিস্টেম সিস্টেম লগে একটি সতর্কতা লিখবে Android 4.2 বা উচ্চতর।

RTL লেআউট সমর্থন

অ্যান্ড্রয়েড এখন বেশ কয়েকটি এপিআই অফার করে যা আপনাকে এমন ব্যবহারকারী ইন্টারফেস তৈরি করতে দেয় যা লেআউট অভিযোজনকে সুন্দরভাবে রূপান্তরিত করে ডান-থেকে-বাম (RTL) UI এবং পড়ার দিকনির্দেশ, যেমন আরবি এবং হিব্রু ব্যবহার করে।

আপনার অ্যাপে RTL লেআউট সমর্থন করা শুরু করতে, আপনার ম্যানিফেস্ট ফাইলের <application> উপাদানটিতে android:supportsRtl অ্যাট্রিবিউট সেট করুন এবং এটিকে “true" সেট করুন। একবার আপনি এটি সক্ষম করলে, সিস্টেমটি বিভিন্ন RTL API গুলিকে RTL এর সাথে আপনার অ্যাপ প্রদর্শন করতে সক্ষম করবে। উদাহরণস্বরূপ, অ্যাকশন বারটি ডানদিকে আইকন এবং শিরোনাম এবং বাম দিকে অ্যাকশন বোতামগুলি দেখাবে এবং ফ্রেমওয়ার্ক-প্রদত্ত View ক্লাসগুলির সাথে আপনি যে লেআউট তৈরি করেছেন তাও বিপরীত হবে৷

RTL লেআউটের সাথে প্রদর্শিত হলে আপনার অ্যাপের চেহারা আরও অপ্টিমাইজ করার প্রয়োজন হলে, অপ্টিমাইজেশনের দুটি মৌলিক স্তর রয়েছে:

  1. বাম- এবং ডান-ভিত্তিক লেআউট বৈশিষ্ট্যগুলিকে স্টার্ট-ওরিয়েন্টেড লেআউট বৈশিষ্ট্যগুলিতে রূপান্তর করুন।

    উদাহরণস্বরূপ, android:layout_marginStart এর জায়গায় android:layout_marginLeft layout_marginStart এবং android:layout_marginEnd android:layout_marginRight layout_marginEnd ব্যবহার করুন।

    RelativeLayout ক্লাসটি বাম/ডান অবস্থান প্রতিস্থাপনের জন্য সংশ্লিষ্ট লেআউট বৈশিষ্ট্যগুলিও প্রদান করে, যেমন android:layout_alignParentStart প্রতিস্থাপন করার জন্য android:layout_alignParentLeft এবং android:layout_toStartOf এর পরিবর্তে android:layout_toLeftOf

  2. অথবা RTL লেআউটের জন্য সম্পূর্ণ অপ্টিমাইজেশন প্রদান করতে, আপনি ldrtl রিসোর্স কোয়ালিফায়ার ব্যবহার করে সম্পূর্ণ আলাদা লেআউট ফাইল প্রদান করতে পারেন ( ldrtl মানে লেআউট-নির্দেশ-ডান-থেকে-বামে})। উদাহরণস্বরূপ, আপনি আপনার ডিফল্ট লেআউট ফাইল res/layout/ এ সংরক্ষণ করতে পারেন এবং আপনার RTL অপ্টিমাইজ করা লেআউট res/layout-ldrtl/ এ সংরক্ষণ করতে পারেন।

    ldrtl কোয়ালিফায়ারটি অঙ্কনযোগ্য সংস্থানগুলির জন্য দুর্দান্ত, যাতে আপনি গ্রাফিক্স সরবরাহ করতে পারেন যা পড়ার দিকনির্দেশের সাথে সামঞ্জস্যপূর্ণ।

RTL লেআউট সমর্থন করার জন্য ফ্রেমওয়ার্ক জুড়ে বিভিন্ন অন্যান্য API পাওয়া যায়, যেমন View ক্লাসে যাতে আপনি কাস্টম ভিউ এবং বর্তমান লেআউট দিক অনুসন্ধানের জন্য Configuration জন্য সঠিক আচরণ বাস্তবায়ন করতে পারেন।

দ্রষ্টব্য: আপনি যদি SQlite ব্যবহার করেন এবং আপনার টেবিল বা কলামের নাম থাকে যা "শুধুমাত্র সংখ্যা" হয়, সতর্ক থাকুন: String.format(String, Object...) ব্যবহার করে ভুল হতে পারে যেখানে সংখ্যাগুলি তাদের আরবি সমতুল্যে রূপান্তরিত হয়েছে যদি আপনার String.format("%d", int) আরবি লোকেলে সেট String.format(Locale,String,Object...) হয়েছে সংখ্যা বিন্যাসের জন্য String.valueOf(int)

নেস্টেড ফ্র্যাগমেন্টস

আপনি এখন টুকরো টুকরো টুকরো ভিতরে এম্বেড করতে পারেন। এটি বিভিন্ন পরিস্থিতিতে উপযোগী যেখানে আপনি গতিশীল এবং পুনরায় ব্যবহারযোগ্য UI উপাদানগুলিকে একটি UI উপাদানে রাখতে চান যা নিজেই গতিশীল এবং পুনরায় ব্যবহারযোগ্য। উদাহরণস্বরূপ, যদি আপনি ViewPager ব্যবহার করে এমন টুকরো তৈরি করেন যা বাম এবং ডানদিকে সোয়াইপ করে এবং স্ক্রীনের বেশিরভাগ জায়গা ব্যবহার করে, আপনি এখন প্রতিটি খণ্ড পৃষ্ঠায় টুকরা সন্নিবেশ করতে পারেন।

একটি ফ্র্যাগমেন্ট নেস্ট করতে, যে Fragment আপনি একটি ফ্র্যাগমেন্ট যোগ করতে চান সেখানে getChildFragmentManager() কে কল করুন। এটি একটি FragmentManager ফেরত দেয় যা আপনি ফ্র্যাগমেন্ট লেনদেন তৈরি করতে শীর্ষ-স্তরের কার্যকলাপ থেকে সাধারণত ব্যবহার করতে পারেন। উদাহরণস্বরূপ, এখানে কিছু কোড রয়েছে যা বিদ্যমান Fragment ক্লাসের মধ্যে থেকে একটি খণ্ড যুক্ত করে:

কোটলিন

val videoFragment = VideoPlayerFragment()
childFragmentManager.beginTransaction().apply {
    add(R.id.video_fragment, videoFragment)
    commit()
}

জাভা

Fragment videoFragment = new VideoPlayerFragment();
FragmentTransaction transaction = getChildFragmentManager().beginTransaction();
transaction.add(R.id.video_fragment, videoFragment).commit();

একটি নেস্টেড ফ্র্যাগমেন্টের মধ্যে থেকে, আপনি getParentFragment() কল করে প্যারেন্ট ফ্র্যাগমেন্টের একটি রেফারেন্স পেতে পারেন।

অ্যান্ড্রয়েড সাপোর্ট লাইব্রেরিও এখন নেস্টেড ফ্র্যাগমেন্টগুলিকে সমর্থন করে, তাই আপনি Android 1.6 এবং উচ্চতর সংস্করণে নেস্টেড ফ্র্যাগমেন্ট ডিজাইনগুলি প্রয়োগ করতে পারেন৷

দ্রষ্টব্য: আপনি একটি লেআউটকে একটি খণ্ডে স্ফীত করতে পারবেন না যখন সেই বিন্যাসে একটি <fragment> অন্তর্ভুক্ত থাকে। নেস্টেড টুকরা শুধুমাত্র তখনই সমর্থিত হয় যখন একটি খণ্ডে গতিশীলভাবে যোগ করা হয়।

রেন্ডারস্ক্রিপ্ট

রেন্ডারস্ক্রিপ্ট গণনার কার্যকারিতা নিম্নলিখিত বৈশিষ্ট্যগুলির সাথে উন্নত করা হয়েছে:

স্ক্রিপ্ট অন্তর্নিহিত

আপনি রেন্ডারস্ক্রিপ্টের অন্তর্নির্মিত স্ক্রিপ্টের অন্তর্নিহিত ব্যবহার করতে পারেন যা আপনার জন্য সাধারণ ক্রিয়াকলাপগুলি প্রয়োগ করে যেমন:

একটি স্ক্রিপ্ট অভ্যন্তরীণ ব্যবহার করতে, স্ক্রিপ্টের একটি দৃষ্টান্ত তৈরি করতে প্রতিটি ইনস্ট্রিনসিকের স্ট্যাটিক create() পদ্ধতিতে কল করুন। তারপরে আপনি প্রয়োজনীয় ইনপুট এবং বিকল্প সেট করতে প্রতিটি স্ক্রিপ্টের অন্তর্নিহিত উপলব্ধ set() পদ্ধতিগুলিকে কল করুন। অবশেষে, স্ক্রিপ্ট চালানোর জন্য forEach() পদ্ধতিতে কল করুন।

স্ক্রিপ্ট গ্রুপ

ScriptGroup আপনাকে সম্পর্কিত রেন্ডারস্ক্রিপ্ট স্ক্রিপ্টগুলিকে একত্রে চেইন করতে এবং একটি কলের মাধ্যমে সেগুলি চালানোর অনুমতি দেয়।

addKernel() কল করে গ্রুপে সমস্ত স্ক্রিপ্ট যোগ করতে একটি ScriptGroup.Builder ব্যবহার করুন। একবার আপনি সমস্ত স্ক্রিপ্ট যোগ করলে, addConnection() কল করে স্ক্রিপ্টগুলির মধ্যে সংযোগ তৈরি করুন। আপনি সংযোগগুলি যোগ করা শেষ হলে, স্ক্রিপ্ট গ্রুপ তৈরি করতে create() কল করুন। স্ক্রিপ্ট গ্রুপ চালানোর আগে, setInput(Script.KernelID, Allocation) পদ্ধতির সাথে চালানোর জন্য ইনপুট Allocation এবং প্রাথমিক স্ক্রিপ্টটি নির্দিষ্ট করুন এবং আউটপুট Allocation প্রদান করুন যেখানে ফলাফলটি লেখা হবে এবং setOutput() দিয়ে চালানোর জন্য চূড়ান্ত স্ক্রিপ্ট। অবশেষে, স্ক্রিপ্ট গ্রুপ চালানোর জন্য execute() কল করুন।

ফিল্টারস্ক্রিপ্ট

ফিল্টারস্ক্রিপ্ট বিদ্যমান রেন্ডারস্ক্রিপ্ট এপিআইগুলির সীমাবদ্ধতাগুলিকে সংজ্ঞায়িত করে যা ফলাফল কোডকে বিভিন্ন প্রসেসরে (CPUs, GPUs, এবং DSPs) চালানোর অনুমতি দেয়। ফিল্টারস্ক্রিপ্ট ফাইল তৈরি করতে, .rs ফাইলের পরিবর্তে .fs ফাইল তৈরি করুন, এবং রেন্ডারস্ক্রিপ্ট রানটাইম বলার জন্য #pragma rs_fp_relaxed নির্দিষ্ট করুন আপনার স্ক্রিপ্টগুলির কঠোর IEEE 754-2008 ফ্লোটিং পয়েন্ট নির্ভুলতার প্রয়োজন নেই। এই নির্ভুলতা ডিনর্মের জন্য ফ্লাশ-থেকে-শূন্য এবং বৃত্তাকার-শূন্যের দিকে অনুমতি দেয়। উপরন্তু, আপনার ফিল্টারস্ক্রিপ্ট স্ক্রিপ্টগুলি অবশ্যই 32-বিট বিল্ট-ইন প্রকারগুলি ব্যবহার করবে না এবং __attribute__((kernel)) অ্যাট্রিবিউট ব্যবহার করে একটি কাস্টম রুট ফাংশন নির্দিষ্ট করতে হবে কারণ ফিল্টারস্ক্রিপ্ট পয়েন্টার সমর্থন করে না, যা root() ফাংশনের ডিফল্ট স্বাক্ষর। সংজ্ঞায়িত করে।

দ্রষ্টব্য: যদিও ফিল্টারস্ক্রিপ্ট সমর্থন প্ল্যাটফর্মে রয়েছে, বিকাশকারী সমর্থন SDK টুলস রিলিজ 21.0.1-এ উপলব্ধ হবে।

অ্যান্ড্রয়েড 4.2-এ সমস্ত API পরিবর্তনের বিশদ দর্শনের জন্য, API পার্থক্য রিপোর্ট দেখুন।