<আবেদন>

সিনট্যাক্স:
<application android:allowTaskReparenting=["true" | "false"]
             android:allowBackup=["true" | "false"]
             android:allowClearUserData=["true" | "false"]
             android:allowCrossUidActivitySwitchFromBelow=["true" | "false"]
             android:allowNativeHeapPointerTagging=["true" | "false"]
             android:appCategory=["accessibility" | "audio" | "game" |
             "image" | "maps" | "news" | "productivity" | "social" | "video"]
             android:backupAgent="string"
             android:backupInForeground=["true" | "false"]
             android:banner="drawable resource"
             android:dataExtractionRules="string resource"
             android:debuggable=["true" | "false"]
             android:description="string resource"
             android:enabled=["true" | "false"]
             android:extractNativeLibs=["true" | "false"]
             android:fullBackupContent="string"
             android:fullBackupOnly=["true" | "false"]
             android:gwpAsanMode=["always" | "never"]
             android:hasCode=["true" | "false"]
             android:hasFragileUserData=["true" | "false"]
             android:hardwareAccelerated=["true" | "false"]
             android:icon="drawable resource"
             android:isGame=["true" | "false"]
             android:isMonitoringTool=["parental_control" | "enterprise_management" |
             "other"]
             android:killAfterRestore=["true" | "false"]
             android:largeHeap=["true" | "false"]
             android:label="string resource"
             android:logo="drawable resource"
             android:manageSpaceActivity="string"
             android:name="string"
             android:networkSecurityConfig="xml resource"
             android:permission="string"
             android:persistent=["true" | "false"]
             android:process="string"
             android:restoreAnyVersion=["true" | "false"]
             android:requestLegacyExternalStorage=["true" | "false"]
             android:requiredAccountType="string"
             android:resizeableActivity=["true" | "false"]
             android:restrictedAccountType="string"
             android:supportsRtl=["true" | "false"]
             android:taskAffinity="string"
             android:testOnly=["true" | "false"]
             android:theme="resource or theme"
             android:uiOptions=["none" | "splitActionBarWhenNarrow"]
             android:usesCleartextTraffic=["true" | "false"]
             android:vmSafeMode=["true" | "false"] >
    . . .
</application>
এর মধ্যে রয়েছে:
<manifest>
থাকতে পারে:
<activity>
<activity-alias>
<meta-data>
<service>
<receiver>
<profileable>
<provider>
<uses-library>
<uses-native-library>
বর্ণনা:

আবেদনের ঘোষণা। এই উপাদানটিতে উপ-এলিমেন্ট রয়েছে যা অ্যাপ্লিকেশনের প্রতিটি উপাদান ঘোষণা করে এবং এমন বৈশিষ্ট্য রয়েছে যা সমস্ত উপাদানকে প্রভাবিত করতে পারে।

এই বৈশিষ্ট্যগুলির মধ্যে অনেকগুলি, যেমন icon , label , permission , process , taskAffinity , এবং allowTaskReparenting , উপাদান উপাদানগুলির সংশ্লিষ্ট বৈশিষ্ট্যগুলির জন্য ডিফল্ট মান সেট করে৷ অন্যান্য, যেমন debuggable , enabled , description , এবং allowClearUserData , সামগ্রিকভাবে অ্যাপ্লিকেশনের জন্য মান সেট করে এবং উপাদানগুলির দ্বারা ওভাররাইড করা হয় না৷

গুণাবলী
android:allowTaskReparenting
অ্যাপ্লিকেশানটি সংজ্ঞায়িত ক্রিয়াকলাপগুলি যে টাস্ক থেকে শুরু করে সেই টাস্কে যেতে পারে কিনা সেই টাস্কটি পরবর্তীতে সামনে আনা হলে তাদের সাথে সম্পর্ক রয়েছে কিনা। এটি "true" যদি তারা সরাতে পারে, এবং "false" যদি তারা যে কাজটি শুরু করেছিল তার সাথেই থাকে। ডিফল্ট মান হল "false"

<activity> উপাদানটির নিজস্ব allowTaskReparenting বৈশিষ্ট্য রয়েছে যা এখানে সেট করা মানকে ওভাররাইড করতে পারে।

android:allowBackup

অ্যাপ্লিকেশনটিকে ব্যাকআপে অংশ নিতে এবং পরিকাঠামো পুনরুদ্ধার করতে দেওয়া হবে কিনা। যদি এই অ্যাট্রিবিউটটি "false" এ সেট করা থাকে, তাহলে অ্যাপ্লিকেশনটির কোনো ব্যাকআপ বা পুনরুদ্ধার করা হয় না, এমনকি একটি পূর্ণ-সিস্টেম ব্যাকআপ দ্বারা যা অন্যথায় adb ব্যবহার করে সমস্ত অ্যাপ্লিকেশন ডেটা সংরক্ষণ করতে পারে। এই বৈশিষ্ট্যের ডিফল্ট মান হল "true"

দ্রষ্টব্য: Android 12 (API স্তর 31) বা উচ্চতরকে লক্ষ্য করা অ্যাপগুলির জন্য, এই আচরণটি পরিবর্তিত হয়। কিছু ডিভাইস নির্মাতার ডিভাইসে, আপনি আপনার অ্যাপের ফাইলের ডিভাইস থেকে ডিভাইস মাইগ্রেশন অক্ষম করতে পারবেন না।

যাইহোক, আপনি ক্লাউড-ভিত্তিক ব্যাকআপ অক্ষম করতে পারেন এবং এই অ্যাট্রিবিউটটিকে "false" তে সেট করে আপনার অ্যাপের ফাইলগুলি পুনরুদ্ধার করতে পারেন, এমনকি যদি আপনার অ্যাপটি Android 12 (API স্তর 31) বা উচ্চতরকে লক্ষ্য করে।

আরও তথ্যের জন্য, পৃষ্ঠাটির ব্যাকআপ এবং পুনরুদ্ধার বিভাগটি দেখুন যা Android 12 (API স্তর 31) বা উচ্চতর টার্গেট করা অ্যাপগুলির আচরণের পরিবর্তনগুলি বর্ণনা করে৷

android:allowClearUserData

অ্যাপ্লিকেশনটিকে ব্যবহারকারীর ডেটা পুনরায় সেট করতে দেওয়া হবে কিনা। এই ডেটাতে ফ্ল্যাগ রয়েছে, যেমন ব্যবহারকারী পরিচায়ক টুলটিপ দেখেছেন কিনা, সেইসাথে ব্যবহারকারী-কাস্টমাইজযোগ্য সেটিংস এবং পছন্দগুলি। এই বৈশিষ্ট্যের ডিফল্ট মান হল "true"

দ্রষ্টব্য: শুধুমাত্র যে অ্যাপগুলি সিস্টেম ইমেজের অংশ তারাই এই বৈশিষ্ট্যটি স্পষ্টভাবে ঘোষণা করতে পারে৷ তৃতীয় পক্ষের অ্যাপগুলি তাদের ম্যানিফেস্ট ফাইলগুলিতে এই বৈশিষ্ট্যটি অন্তর্ভুক্ত করতে পারে না৷

আরও তথ্যের জন্য, ডেটা ব্যাকআপ ওভারভিউ দেখুন।

android:allowCrossUidActivitySwitchFromBelow

টাস্কে এর নিচের ক্রিয়াকলাপগুলি অন্যান্য কার্যক্রম শুরু করতে বা কাজটি শেষ করতে পারে কিনা তা নির্দিষ্ট করে।

টার্গেট SDK লেভেল Build.VERSION_CODES.VANILLA_ICE_CREAM VERSION_CODES.VANILLA_ICE_CREAM থেকে শুরু করে, অ্যাপগুলিকে নতুন ক্রিয়াকলাপ শুরু করা বা তাদের কাজ শেষ করা থেকে ব্লক করা হতে পারে যদি না এই ধরনের টাস্কের শীর্ষ ক্রিয়াকলাপটি নিরাপত্তার কারণে একই UID-এর অন্তর্গত হয়৷

এই ফ্ল্যাগটিকে true সেট করা হলে এই কার্যকলাপটি শীর্ষে থাকলে লঞ্চিং অ্যাপটিকে সীমাবদ্ধতা উপেক্ষা করার অনুমতি দেবে৷ এই ক্রিয়াকলাপের UID-এর সাথে মিলে যাওয়া অ্যাপগুলিকে সর্বদা ছাড় দেওয়া হয়।

আরও তথ্যের জন্য, সুরক্ষিত পটভূমি কার্যকলাপ লঞ্চ দেখুন।

android:allowNativeHeapPointerTagging

অ্যাপটি হিপ পয়েন্টার ট্যাগিং বৈশিষ্ট্য সক্ষম করে কিনা। এই বৈশিষ্ট্যের ডিফল্ট মান হল "true"

দ্রষ্টব্য: এই বৈশিষ্ট্যটি অক্ষম করা অন্তর্নিহিত কোড স্বাস্থ্য সমস্যা সমাধান করে না । ভবিষ্যতের হার্ডওয়্যার ডিভাইসগুলি এই ম্যানিফেস্ট ট্যাগকে সমর্থন নাও করতে পারে৷

আরও তথ্যের জন্য, ট্যাগ করা পয়েন্টার দেখুন।

android:appCategory

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

নিম্নলিখিত ধ্রুবক মানগুলির মধ্যে একটি হতে হবে।

মান বর্ণনা
accessibility যে অ্যাপগুলি প্রাথমিকভাবে অ্যাক্সেসযোগ্যতা অ্যাপ, যেমন স্ক্রিন-রিডার।
audio যে অ্যাপগুলি প্রাথমিকভাবে অডিও বা মিউজিকের সাথে কাজ করে, যেমন মিউজিক প্লেয়ার।
game যে অ্যাপগুলো মূলত গেম।
image যে অ্যাপগুলি প্রাথমিকভাবে ছবি বা ফটোর সাথে কাজ করে, যেমন ক্যামেরা বা গ্যালারি অ্যাপ।
maps যে অ্যাপগুলি প্রাথমিকভাবে ম্যাপ অ্যাপ, যেমন নেভিগেশন অ্যাপ।
news যে অ্যাপগুলি প্রাথমিকভাবে খবরের অ্যাপ, যেমন সংবাদপত্র, ম্যাগাজিন বা স্পোর্টস অ্যাপ।
productivity যে অ্যাপগুলি প্রাথমিকভাবে উত্পাদনশীলতার অ্যাপ, যেমন ক্লাউড স্টোরেজ বা কর্মক্ষেত্রের অ্যাপ।
social যে অ্যাপগুলি প্রাথমিকভাবে সামাজিক অ্যাপ, যেমন মেসেজিং, যোগাযোগ, ইমেল বা সামাজিক নেটওয়ার্ক অ্যাপ।
video যে অ্যাপগুলি প্রাথমিকভাবে ভিডিও বা সিনেমার সাথে কাজ করে, যেমন স্ট্রিমিং ভিডিও অ্যাপ।

android:backupAgent
অ্যাপ্লিকেশনের ব্যাকআপ এজেন্ট প্রয়োগ করে এমন ক্লাসের নাম, BackupAgent এর একটি সাবক্লাস। অ্যাট্রিবিউট মান হল একটি সম্পূর্ণ যোগ্য শ্রেণীর নাম, যেমন "com.example.project.MyBackupAgent" । যাইহোক, শর্টহ্যান্ড হিসাবে, যদি নামের প্রথম অক্ষরটি একটি পিরিয়ড হয়, উদাহরণস্বরূপ, ".MyBackupAgent" , এটি <manifest> উপাদানে নির্দিষ্ট করা প্যাকেজের নামের সাথে যুক্ত করা হয়।

কোন ডিফল্ট নেই. নাম নির্দিষ্ট হতে হবে।

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

ডিফল্ট মান হল "false" , যার মানে হল যে OS অগ্রভাগে চলার সময় অ্যাপটির ব্যাক আপ নেওয়া এড়িয়ে যায়, যেমন একটি মিউজিক অ্যাপ যেটি startForeground() অবস্থায় একটি পরিষেবা ব্যবহার করে সক্রিয়ভাবে মিউজিক চালাচ্ছে।

android:banner
একটি অঙ্কনযোগ্য সংস্থান যা এর সাথে সম্পর্কিত আইটেমের জন্য একটি বর্ধিত গ্রাফিকাল ব্যানার প্রদান করে। সমস্ত অ্যাপ্লিকেশন ক্রিয়াকলাপের জন্য একটি ডিফল্ট ব্যানার সরবরাহ করতে <application> ট্যাগ ব্যবহার করুন বা একটি নির্দিষ্ট কার্যকলাপের জন্য একটি ব্যানার সরবরাহ করতে <activity> ট্যাগের সাথে ব্যবহার করুন।

অ্যান্ড্রয়েড টিভি হোম স্ক্রিনে একটি অ্যাপ উপস্থাপন করতে সিস্টেমটি ব্যানার ব্যবহার করে। অতএব, শুধুমাত্র CATEGORY_LEANBACK_LAUNCHER উদ্দেশ্য পরিচালনা করে এমন একটি কার্যকলাপ সহ অ্যাপ্লিকেশনগুলির জন্য এটি নির্দিষ্ট করুন৷

এই অ্যাট্রিবিউটটি ইমেজ ধারণকারী একটি অঙ্কনযোগ্য সম্পদের রেফারেন্স হিসাবে সেট করা হয়েছে, উদাহরণস্বরূপ "@drawable/banner" । কোন ডিফল্ট ব্যানার নেই.

আরও তথ্যের জন্য, একটি হোম স্ক্রীন ব্যানার প্রদান দেখুন।

android:dataExtractionRules

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

XML ফাইলের বিন্যাস সম্পর্কে তথ্যের জন্য, ব্যাকআপ এবং পুনরুদ্ধার দেখুন।

android:debuggable
অ্যাপ্লিকেশনটি ডিবাগ করা যাবে কি না, এমনকি ব্যবহারকারী মোডে একটি ডিভাইসে চললেও। এটা হতে পারে "true" এবং না হলে "false" । ডিফল্ট মান হল "false"
android:description
অ্যাপ্লিকেশন সম্পর্কে ব্যবহারকারী-পাঠযোগ্য পাঠ্য, যা অ্যাপ্লিকেশন লেবেলের চেয়ে দীর্ঘ এবং আরও বর্ণনামূলক৷ মান একটি স্ট্রিং সম্পদ একটি রেফারেন্স হিসাবে সেট করা হয়. লেবেল থেকে ভিন্ন, এটি একটি কাঁচা স্ট্রিং হতে পারে না। কোন ডিফল্ট মান নেই।
android:enabled
অ্যান্ড্রয়েড সিস্টেম অ্যাপ্লিকেশনটির উপাদানগুলিকে তাত্ক্ষণিক করতে পারে কিনা৷ এটা করতে পারলে "true" এবং না হলে "false" । মানটি "true" হলে, প্রতিটি উপাদানের enabled বৈশিষ্ট্য নির্ধারণ করে যে সেই উপাদানটি সক্ষম কিনা। মানটি "false" হলে, এটি উপাদান-নির্দিষ্ট মানগুলিকে ওভাররাইড করে এবং সমস্ত উপাদান অক্ষম করা হয়৷

ডিফল্ট মান হল "true"

android:extractNativeLibs

AGP 4.2.0 দিয়ে শুরু করে, DSL অপশন useLegacyPackaging এক্সট্রাক্ট extractNativeLibs ম্যানিফেস্ট অ্যাট্রিবিউটকে প্রতিস্থাপন করে। নেটিভ লাইব্রেরি কম্প্রেশন আচরণ কনফিগার করতে ম্যানিফেস্ট ফাইলে extractNativeLibs এর পরিবর্তে আপনার অ্যাপের build.gradle ফাইলে useLegacyPackaging ব্যবহার করুন। আরও তথ্যের জন্য, রিলিজ নোট দেখুন সংকুচিত নেটিভ লাইব্রেরি প্যাকেজ করতে DSL ব্যবহার করুন

এই বৈশিষ্ট্যটি নির্দেশ করে যে প্যাকেজ ইনস্টলার APK থেকে ফাইল সিস্টেমে নেটিভ লাইব্রেরিগুলি বের করে কিনা। যদি "false" তে সেট করা থাকে, তাহলে আপনার নেটিভ লাইব্রেরিগুলি APK-এ সংকুচিত না হয়ে সংরক্ষণ করা হয়৷ যদিও আপনার APK বড় হতে পারে, আপনার অ্যাপ্লিকেশন দ্রুত লোড হয় কারণ লাইব্রেরিগুলি রানটাইমে APK থেকে সরাসরি লোড হয়।

extractNativeLibs এর ডিফল্ট মান minSdkVersion এবং আপনি যে AGP ব্যবহার করছেন তার উপর নির্ভর করে। বেশিরভাগ ক্ষেত্রে, ডিফল্ট আচরণ সম্ভবত আপনি যা চান, এবং আপনাকে এই বৈশিষ্ট্যটি স্পষ্টভাবে সেট করতে হবে না।

android:fullBackupContent
এই বৈশিষ্ট্যটি একটি XML ফাইলের দিকে নির্দেশ করে যাতে অটো ব্যাকআপের জন্য সম্পূর্ণ ব্যাকআপ নিয়ম রয়েছে৷ এই নিয়মগুলি নির্ধারণ করে কোন ফাইলগুলি ব্যাক আপ করা হবে। আরও তথ্যের জন্য, স্বয়ংক্রিয় ব্যাকআপের জন্য XML কনফিগারেশন সিনট্যাক্স দেখুন।

এই বৈশিষ্ট্য ঐচ্ছিক. যদি এটি নির্দিষ্ট করা না থাকে, ডিফল্টরূপে, স্বয়ংক্রিয় ব্যাকআপ আপনার অ্যাপের বেশিরভাগ ফাইল অন্তর্ভুক্ত করে। আরও তথ্যের জন্য, ব্যাক আপ করা ফাইলগুলি দেখুন।

android:fullBackupOnly
এই বৈশিষ্ট্যটি নির্দেশ করে যে ডিভাইসগুলি যেখানে এটি উপলব্ধ সেখানে স্বয়ংক্রিয় ব্যাকআপ ব্যবহার করবেন কিনা৷ যদি "true" তে সেট করা হয়, তাহলে Android 6.0 (API স্তর 23) বা উচ্চতর চলমান ডিভাইসে ইনস্টল করার সময় আপনার অ্যাপটি স্বতঃ ব্যাকআপ করে। পুরানো ডিভাইসগুলিতে, আপনার অ্যাপ এই বৈশিষ্ট্যটিকে উপেক্ষা করে এবং কী/মান ব্যাকআপগুলি সম্পাদন করে।

ডিফল্ট মান হল "false"

android:gwpAsanMode
এই বৈশিষ্ট্যটি নির্দেশ করে যে GWP-ASan ব্যবহার করতে হবে, একটি নেটিভ মেমরি বরাদ্দকারী বৈশিষ্ট্য যা ব্যবহার-পর-মুক্ত এবং হিপ-বাফার-ওভারফ্লো বাগগুলি খুঁজে পেতে সহায়তা করে।

ডিফল্ট মান হল "never"

android:hasCode
অ্যাপ্লিকেশনটিতে কোনো DEX কোড আছে কিনা—অর্থাৎ, কোটলিন বা জাভা প্রোগ্রামিং ভাষা ব্যবহার করে কোড। এটা যদি হয় "true" এবং না হলে "false" । যখন মানটি "false" হয়, তখন উপাদান চালু করার সময় সিস্টেম কোনো অ্যাপ্লিকেশন কোড লোড করার চেষ্টা করে না। ডিফল্ট মান হল "true"

যদি অ্যাপ্লিকেশনে নেটিভ (C/C++) কোড থাকে, কিন্তু কোনো DEX কোড থাকে না, তাহলে এটি "false" এ সেট করা উচিত। APK-এ কোনো DEX কোড না থাকলে "true" হিসেবে সেট করা থাকলে, অ্যাপটি লোড হতে ব্যর্থ হতে পারে।

এই সম্পত্তি নির্ভরতা দ্বারা অ্যাপ্লিকেশন অন্তর্ভুক্ত কোড জন্য অ্যাকাউন্ট আবশ্যক. যদি অ্যাপ্লিকেশনটি জাভা/কোটলিন কোড ব্যবহার করে এমন একটি AAR-এর উপর নির্ভর করে, বা সরাসরি একটি JAR-এ, app:hasCode অবশ্যই "true" হতে হবে, বা এটি ডিফল্ট হিসাবে বাদ দেওয়া হবে।

উদাহরণস্বরূপ, আপনার অ্যাপ প্লে ফিচার ডেলিভারি সমর্থন করতে পারে এবং এতে ফিচার মডিউল অন্তর্ভুক্ত থাকতে পারে যা কোনো DEX ফাইল তৈরি করে না, যা অ্যান্ড্রয়েড প্ল্যাটফর্মের জন্য বাইটকোড অপ্টিমাইজ করা হয়েছে। যদি তাই হয়, তাহলে রানটাইম ত্রুটি এড়াতে আপনাকে মডিউলের ম্যানিফেস্ট ফাইলে এই প্রপার্টিটিকে "false" তে সেট করতে হবে।

android:hasFragileUserData
ব্যবহারকারী যখন অ্যাপটি আনইনস্টল করে তখন অ্যাপের ডেটা রাখার জন্য ব্যবহারকারীকে প্রম্পট দেখাতে হবে কিনা। ডিফল্ট মান হল "false"
android:hardwareAccelerated
হার্ডওয়্যার-এক্সিলারেটেড রেন্ডারিং এই অ্যাপ্লিকেশানে সমস্ত ক্রিয়াকলাপ এবং দর্শনের জন্য সক্ষম কিনা। এটি সক্ষম হলে এটি "true" এবং না থাকলে "false" । আপনি যদি minSdkVersion বা targetSdkVersion হয় "14" বা উচ্চতর সেট করেন তাহলে ডিফল্ট মান "true" । অন্যথায়, এটি "false"

Android 3.0 (API লেভেল 11) থেকে শুরু করে, অনেক সাধারণ 2D গ্রাফিক্স ক্রিয়াকলাপগুলির জন্য কর্মক্ষমতা উন্নত করতে একটি হার্ডওয়্যার-অ্যাক্সিলারেটেড OpenGL রেন্ডারার অ্যাপ্লিকেশনগুলিতে উপলব্ধ। যখন হার্ডওয়্যার-অ্যাক্সিলারেটেড রেন্ডারার সক্ষম করা হয়, তখন ক্যানভাস, পেইন্ট, এক্সফর্মোড, কালারফিল্টার, শেডার এবং ক্যামেরার বেশিরভাগ ক্রিয়াকলাপ ত্বরান্বিত হয়।

এর ফলে মসৃণ অ্যানিমেশন, মসৃণ স্ক্রোলিং, এবং সামগ্রিকভাবে উন্নত প্রতিক্রিয়াশীলতা দেখা যায়, এমনকি এমন অ্যাপ্লিকেশনের জন্যও যেগুলি স্পষ্টভাবে ফ্রেমওয়ার্কের OpenGL লাইব্রেরি ব্যবহার করে না।

সমস্ত OpenGL 2D অপারেশন ত্বরান্বিত হয় না। আপনি যদি হার্ডওয়্যার-এক্সিলারেটেড রেন্ডারার সক্ষম করেন, আপনার অ্যাপ্লিকেশনটি পরীক্ষা করুন যাতে এটি ত্রুটি ছাড়াই রেন্ডারার ব্যবহার করতে পারে৷

আরও তথ্যের জন্য, হার্ডওয়্যার ত্বরণ নির্দেশিকা পড়ুন।

android:icon
সম্পূর্ণরূপে অ্যাপ্লিকেশনের জন্য একটি আইকন এবং অ্যাপ্লিকেশনের প্রতিটি উপাদানের জন্য ডিফল্ট আইকন৷ <activity> , <activity-alias> , <service> , <receiver> , এবং <provider> উপাদানগুলির জন্য পৃথক icon বৈশিষ্ট্যগুলি দেখুন৷

এই বৈশিষ্ট্যটি একটি অঙ্কনযোগ্য সংস্থানের একটি রেফারেন্স হিসাবে সেট করা হয়েছে যার মধ্যে চিত্র রয়েছে, যেমন "@drawable/icon" । কোন ডিফল্ট আইকন নেই.

android:isGame
অ্যাপ্লিকেশনটি একটি খেলা কিনা। সিস্টেম গেম হিসাবে শ্রেণীবদ্ধ অ্যাপ্লিকেশনগুলিকে একত্রিত করতে পারে বা অন্যান্য অ্যাপ্লিকেশন থেকে আলাদাভাবে প্রদর্শন করতে পারে। ডিফল্ট হল "false"
android:isMonitoringTool

নির্দেশ করে যে এই অ্যাপ্লিকেশনটি অন্যান্য ব্যক্তিদের নিরীক্ষণ করার জন্য ডিজাইন করা হয়েছে।

দ্রষ্টব্য: যদি কোনো অ্যাপ তার ম্যানিফেস্টে এই বৈশিষ্ট্যটি ঘোষণা করে, তাহলে ডেভেলপারকে Google Play-তে অ্যাপটি প্রকাশ করতে Stalkerware নীতি অনুসরণ করতে হবে।

কোন ডিফল্ট মান নেই। বিকাশকারীকে অবশ্যই নিম্নলিখিত মানগুলির মধ্যে একটি নির্দিষ্ট করতে হবে:

মান বর্ণনা
"parental_control" অ্যাপটি অভিভাবকীয় নিয়ন্ত্রণ প্রদান করে এবং বিশেষভাবে অভিভাবকদের লক্ষ্য করে যারা তাদের বাচ্চাদের নিরাপদ রাখতে চান।
"enterprise_management" অ্যাপটি এমন উদ্যোগগুলিকে পূরণ করে যেগুলি কর্মীদের দেওয়া ডিভাইসগুলি পরিচালনা এবং ট্র্যাক করতে চায়৷
"other" অ্যাপটি এই সারণীতে অন্যথায় উল্লেখ করা নেই এমন একটি ব্যবহারের ক্ষেত্রে পূরণ করে।
android:killAfterRestore

একটি পূর্ণ-সিস্টেম পুনরুদ্ধার ক্রিয়াকলাপের সময় সেটিংস পুনরুদ্ধার করার পরে অ্যাপ্লিকেশনটি বন্ধ হয়ে যায় কিনা। একক-প্যাকেজ পুনরুদ্ধার ক্রিয়াকলাপ কখনই অ্যাপ্লিকেশন বন্ধ করে না। পূর্ণ-সিস্টেম পুনরুদ্ধার ক্রিয়াকলাপগুলি সাধারণত শুধুমাত্র একবার ঘটে, যখন ফোনটি প্রথম সেট আপ করা হয়৷ তৃতীয় পক্ষের অ্যাপ্লিকেশনগুলির সাধারণত এই বৈশিষ্ট্যটি ব্যবহার করার প্রয়োজন হয় না।

ডিফল্ট হল "true" , যার মানে হল একটি পূর্ণ-সিস্টেম পুনরুদ্ধারের সময় অ্যাপ্লিকেশনটি তার ডেটা প্রক্রিয়াকরণ শেষ করার পরে, এটি বন্ধ হয়ে যায়।

android:largeHeap

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

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

রানটাইমে উপলব্ধ মেমরির আকার জিজ্ঞাসা করতে, getMemoryClass() বা getLargeMemoryClass() পদ্ধতিগুলি ব্যবহার করুন।

android:label
সম্পূর্ণরূপে অ্যাপ্লিকেশনটির জন্য একটি ব্যবহারকারী-পাঠযোগ্য লেবেল এবং অ্যাপ্লিকেশনটির প্রতিটি উপাদানের জন্য একটি ডিফল্ট লেবেল৷ <activity> , <activity-alias> , <service> , <receiver> , এবং <provider> উপাদানগুলির জন্য পৃথক label বৈশিষ্ট্যগুলি দেখুন৷

লেবেলটি একটি স্ট্রিং রিসোর্সের রেফারেন্স হিসাবে সেট করা হয়েছে, যাতে এটি ব্যবহারকারী ইন্টারফেসের অন্যান্য স্ট্রিংগুলির মতো স্থানীয়করণ করা যায়। যাইহোক, আপনি অ্যাপ্লিকেশনটি বিকাশ করার সময় সুবিধা হিসাবে, এটি একটি কাঁচা স্ট্রিং হিসাবেও সেট করা যেতে পারে।

android:logo
সম্পূর্ণরূপে অ্যাপ্লিকেশনের জন্য একটি লোগো এবং কার্যকলাপের জন্য ডিফল্ট লোগো৷ এই বৈশিষ্ট্যটি একটি অঙ্কনযোগ্য সম্পদের একটি রেফারেন্স হিসাবে সেট করা হয়েছে যার মধ্যে ছবি রয়েছে, যেমন "@drawable/logo" । কোন ডিফল্ট লোগো নেই.
android:manageSpaceActivity
একটি Activity সাবক্লাসের সম্পূর্ণ যোগ্য নাম যা ব্যবহারকারীদের ডিভাইসে অ্যাপ্লিকেশন দ্বারা দখল করা মেমরি পরিচালনা করতে দেওয়ার জন্য সিস্টেম চালু করে। কার্যকলাপ একটি <activity> উপাদান দিয়ে ঘোষণা করা হয়.
android:name
অ্যাপ্লিকেশনের জন্য প্রয়োগ করা একটি Application সাবক্লাসের সম্পূর্ণ যোগ্য নাম। যখন আবেদন প্রক্রিয়া শুরু হয়, তখন এই ক্লাসটি আবেদনের যেকোন উপাদানের আগে তাৎক্ষণিকভাবে চালু করা হয়।

সাবক্লাসটি ঐচ্ছিক। বেশিরভাগ অ্যাপ্লিকেশনের একটির প্রয়োজন নেই। একটি সাবক্লাসের অনুপস্থিতিতে, অ্যান্ড্রয়েড বেস Application ক্লাসের একটি উদাহরণ ব্যবহার করে।

android:networkSecurityConfig

আপনার অ্যাপ্লিকেশনের নেটওয়ার্ক নিরাপত্তা কনফিগারেশন ধারণকারী XML ফাইলের নাম নির্দিষ্ট করে। মান হল কনফিগারেশন ধারণকারী XML রিসোর্স ফাইলের একটি রেফারেন্স।

এই বৈশিষ্ট্যটি API স্তর 24 এ যোগ করা হয়েছে।

android:permission
একটি অনুমতির নাম যা ক্লায়েন্টদের অ্যাপ্লিকেশনের সাথে ইন্টারঅ্যাক্ট করার জন্য প্রয়োজন। এই বৈশিষ্ট্যটি একটি অনুমতি সেট করার একটি সুবিধাজনক উপায় যা অ্যাপ্লিকেশনের সমস্ত উপাদানগুলিতে প্রযোজ্য। এটি পৃথক উপাদানের permission বৈশিষ্ট্য সেট করে ওভাররাইট করা হয়।

অনুমতি সম্পর্কে আরও তথ্যের জন্য, অ্যাপ ম্যানিফেস্ট ওভারভিউ এবং নিরাপত্তা টিপসের অনুমতি বিভাগটি দেখুন।

android:persistent
অ্যাপ্লিকেশনটি সর্বদা চলমান থাকে কিনা। এটা যদি হয় "true" এবং না হলে "false" । ডিফল্ট মান হল "false" । অ্যাপ্লিকেশনগুলি সাধারণত এই পতাকা সেট করে না৷ দৃঢ়তা মোড শুধুমাত্র নির্দিষ্ট সিস্টেম অ্যাপ্লিকেশনের জন্য উদ্দেশ্যে করা হয়.
android:process
একটি প্রক্রিয়ার নাম যেখানে অ্যাপ্লিকেশনের সমস্ত উপাদান চলে। প্রতিটি উপাদান তার নিজস্ব process বৈশিষ্ট্য সেট করে এই ডিফল্ট ওভাররাইড করতে পারে।

ডিফল্টরূপে, অ্যান্ড্রয়েড একটি অ্যাপ্লিকেশনের জন্য একটি প্রক্রিয়া তৈরি করে যখন এর উপাদানগুলির প্রথমটি চালানোর প্রয়োজন হয়। সমস্ত উপাদান তারপর সেই প্রক্রিয়ায় চলে। ডিফল্ট প্রক্রিয়ার নাম <manifest> উপাদান দ্বারা সেট করা প্যাকেজ নামের সাথে মিলে যায়।

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

যদি এই অ্যাট্রিবিউটের জন্য নির্ধারিত নামটি একটি কোলন ( : ) দিয়ে শুরু হয়, একটি নতুন প্রক্রিয়া, অ্যাপ্লিকেশনের জন্য ব্যক্তিগত, যখন এটি প্রয়োজন হয় তখন তৈরি করা হয়। যদি প্রক্রিয়ার নাম একটি ছোট হাতের অক্ষর দিয়ে শুরু হয়, সেই নামের একটি বিশ্বব্যাপী প্রক্রিয়া তৈরি করা হয়। একটি বিশ্বব্যাপী প্রক্রিয়া অন্যান্য অ্যাপ্লিকেশনের সাথে ভাগ করা যেতে পারে, সম্পদের ব্যবহার হ্রাস করে।

android:restoreAnyVersion
ইঙ্গিত করে যে অ্যাপ্লিকেশনটি যেকোনো ব্যাক-আপ ডেটা সেট পুনরুদ্ধার করার চেষ্টা করার জন্য প্রস্তুত, এমনকি যদি ব্যাকআপটি বর্তমানে ডিভাইসে ইনস্টল করা অ্যাপ্লিকেশনটির একটি নতুন সংস্করণ দ্বারা সঞ্চিত হয়। এই বৈশিষ্ট্যটিকে "true" তে সেট করা ব্যাকআপ ম্যানেজারকে পুনরুদ্ধারের চেষ্টা করতে দেয় এমনকি যখন একটি সংস্করণের অমিল পরামর্শ দেয় যে ডেটা বেমানান। সতর্কতার সাথে ব্যবহার করুন!

এই বৈশিষ্ট্যের ডিফল্ট মান হল "false"

android:requestLegacyExternalStorage

অ্যাপ্লিকেশনটি স্কোপড স্টোরেজ থেকে অপ্ট আউট করতে চায় কিনা৷

দ্রষ্টব্য: নীতি বা অ্যাপ সামঞ্জস্য সম্পর্কিত পরিবর্তনের উপর নির্ভর করে, সিস্টেম এই অপ্ট-আউট অনুরোধকে সম্মান নাও করতে পারে।

android:requiredAccountType
অ্যাপ্লিকেশন দ্বারা কাজ করার জন্য প্রয়োজনীয় অ্যাকাউন্টের ধরন নির্দিষ্ট করে। যদি আপনার অ্যাপের একটি Account প্রয়োজন হয়, তাহলে এই বৈশিষ্ট্যের মান অবশ্যই আপনার অ্যাপ দ্বারা ব্যবহৃত অ্যাকাউন্ট প্রমাণীকরণকারীর প্রকারের সাথে মিলিত হতে হবে, যেমন "com.google" এর মতো AuthenticatorDescription দ্বারা সংজ্ঞায়িত করা হয়েছে।

ডিফল্ট মানটি শূন্য এবং নির্দেশ করে যে অ্যাপ্লিকেশনটি কোনো অ্যাকাউন্ট ছাড়াই কাজ করতে পারে।

যেহেতু সীমাবদ্ধ প্রোফাইলগুলি অ্যাকাউন্ট যোগ করতে পারে না, এই বৈশিষ্ট্যটি নির্দিষ্ট করা আপনার অ্যাপটিকে একটি সীমাবদ্ধ প্রোফাইল থেকে অনুপলব্ধ করে তোলে যদি না আপনি একই মান সহ android:restrictedAccountType ঘোষণা না করেন৷

সতর্কতা: যদি অ্যাকাউন্টের ডেটা ব্যক্তিগতভাবে শনাক্তযোগ্য তথ্য প্রকাশ করতে পারে, তাহলে এটি গুরুত্বপূর্ণ যে আপনি এই বৈশিষ্ট্যটি ঘোষণা করুন এবং android:restrictedAccountType শূন্য রেখে দিন, যাতে সীমাবদ্ধ প্রোফাইলগুলি মালিক ব্যবহারকারীর ব্যক্তিগত তথ্য অ্যাক্সেস করতে আপনার অ্যাপ ব্যবহার করতে না পারে৷

এই বৈশিষ্ট্যটি API স্তর 18 এ যোগ করা হয়েছে।

android:resizeableActivity

অ্যাপটি মাল্টি-উইন্ডো মোড সমর্থন করে কিনা তা নির্দিষ্ট করে৷ আপনি এই বৈশিষ্ট্যটি <activity> বা <application> উপাদানে সেট করতে পারেন।

আপনি যদি এই বৈশিষ্ট্যটি "true" তে সেট করেন, ব্যবহারকারী স্প্লিট-স্ক্রিন এবং ফ্রি-ফর্ম মোডে কার্যকলাপ চালু করতে পারেন। আপনি যদি অ্যাট্রিবিউটটিকে "false" তে সেট করেন, তাহলে অ্যাপটি একাধিক-উইন্ডো পরিবেশের জন্য পরীক্ষা বা অপ্টিমাইজ করা যাবে না। সিস্টেম এখনও সামঞ্জস্য মোড প্রয়োগের সাথে একাধিক-উইন্ডো মোডে কার্যকলাপ রাখতে পারে।

এই বৈশিষ্ট্যটিকে "true" তে সেট করা গ্যারান্টি দেয় না যে মাল্টি-উইন্ডো মোডে পর্দায় দৃশ্যমান অন্য কোনও অ্যাপ নেই, যেমন পিকচার-ইন-পিকচার বা অন্যান্য ডিসপ্লেতে। অতএব, এই পতাকা সেট করার অর্থ এই নয় যে আপনার অ্যাপের একচেটিয়া সম্পদ অ্যাক্সেস আছে।

API স্তর 24 বা উচ্চতর টার্গেট করা অ্যাপগুলির জন্য, ডিফল্ট হল "true"

যদি আপনার অ্যাপ এপিআই লেভেল 31 বা তার বেশি টার্গেট করে, তাহলে এই অ্যাট্রিবিউটটি ছোট এবং বড় স্ক্রিনে ভিন্নভাবে কাজ করে:

  • বড় স্ক্রীন (sw >= 600dp): সমস্ত অ্যাপ মাল্টি-উইন্ডো মোড সমর্থন করে। অ্যাট্রিবিউটটি নির্দেশ করে যে একটি অ্যাপের আকার পরিবর্তন করা যাবে কিনা, অ্যাপটি মাল্টি-উইন্ডো মোড সমর্থন করে কিনা তা নয়। resizeableActivity="false" হলে, ডিসপ্লে ডাইমেনশনের সাথে সামঞ্জস্য করার জন্য অ্যাপটিকে সামঞ্জস্যপূর্ণ মোডে রাখা হয়।
  • ছোট স্ক্রীন (sw <600dp): যদি resizeableActivity="true" এবং প্রধান কার্যকলাপের ন্যূনতম প্রস্থ এবং ন্যূনতম উচ্চতা মাল্টি-উইন্ডো প্রয়োজনীয়তার মধ্যে থাকে, অ্যাপটি মাল্টি-উইন্ডো মোড সমর্থন করে। resizeableActivity="false" হলে, অ্যাপ্লিকেশানটি ন্যূনতম প্রস্থ এবং উচ্চতা নির্বিশেষে একাধিক-উইন্ডো মোড সমর্থন করে না৷

দ্রষ্টব্য: ডিভাইস নির্মাতারা API স্তর 31 আচরণকে ওভাররাইড করতে পারে।

এই বৈশিষ্ট্যটি API স্তর 24 এ যোগ করা হয়েছে।

দ্রষ্টব্য: একটি টাস্কের রুট অ্যাক্টিভিটি মান টাস্কে চালু করা সমস্ত অতিরিক্ত অ্যাক্টিভিটিগুলিতে প্রয়োগ করা হয়। অর্থাৎ, যদি কোনো টাস্কের রুট অ্যাক্টিভিটি রিসাইজ করা যায়, তাহলে সিস্টেম টাস্কের অন্য সব অ্যাক্টিভিটিকে রিসাইজযোগ্য হিসেবে বিবেচনা করে। রুট অ্যাক্টিভিটি রিসাইজ করা না গেলে, টাস্কের অন্যান্য অ্যাক্টিভিটি রিসাইজ করা যায় না।

android:restrictedAccountType
এই অ্যাপ্লিকেশনটির জন্য প্রয়োজনীয় অ্যাকাউন্টের ধরন নির্দিষ্ট করে এবং নির্দেশ করে যে সীমাবদ্ধ প্রোফাইলগুলি মালিক ব্যবহারকারীর অন্তর্গত অ্যাকাউন্টগুলিতে অ্যাক্সেস করতে পারে৷ যদি আপনার অ্যাপের জন্য একটি Account প্রয়োজন হয় এবং সীমাবদ্ধ প্রোফাইলগুলি প্রাথমিক ব্যবহারকারীর অ্যাকাউন্টগুলি অ্যাক্সেস করতে পারে , তাহলে এই বৈশিষ্ট্যের মান অবশ্যই আপনার অ্যাপের দ্বারা ব্যবহৃত অ্যাকাউন্ট প্রমাণীকরণকারীর প্রকারের সাথে মিলিত হতে হবে, যেমন "com.google" এর মতো AuthenticatorDescription দ্বারা সংজ্ঞায়িত করা হয়েছে।

ডিফল্ট মানটি শূন্য এবং নির্দেশ করে যে অ্যাপ্লিকেশনটি কোনো অ্যাকাউন্ট ছাড়াই কাজ করতে পারে।

সতর্কতা: এই বৈশিষ্ট্যটি নির্দিষ্ট করার ফলে সীমাবদ্ধ প্রোফাইলগুলি মালিক ব্যবহারকারীর অন্তর্গত অ্যাকাউন্টগুলির সাথে আপনার অ্যাপ ব্যবহার করতে দেয়, যা ব্যক্তিগতভাবে সনাক্তযোগ্য তথ্য প্রকাশ করতে পারে। যদি অ্যাকাউন্ট ব্যক্তিগত বিবরণ প্রকাশ করতে পারে, তাহলে এই বৈশিষ্ট্যটি ব্যবহার করবেন না । পরিবর্তে, আপনার অ্যাপটিকে সীমাবদ্ধ প্রোফাইলে অনুপলব্ধ করতে android:requiredAccountType বৈশিষ্ট্যটি ঘোষণা করুন।

এই বৈশিষ্ট্যটি API স্তর 18 এ যোগ করা হয়েছে।

android:supportsRtl

আপনার অ্যাপ্লিকেশন ডান-থেকে-বাম (RTL) লেআউট সমর্থন করতে ইচ্ছুক কিনা তা ঘোষণা করে।

যদি এটি "true" তে সেট করা থাকে এবং targetSdkVersion 17 বা তার বেশি সেট করা থাকে, তাহলে বিভিন্ন RTL API সক্রিয় করা হয় এবং সিস্টেম দ্বারা ব্যবহার করা হয় যাতে আপনার অ্যাপটি RTL লেআউটগুলি প্রদর্শন করতে পারে৷ যদি এটি "false" তে সেট করা থাকে বা targetSdkVersion 16 বা তার নিচে সেট করা থাকে, তাহলে RTL APIগুলিকে উপেক্ষা করা হয় বা কোনো প্রভাব না থাকে এবং ব্যবহারকারীর লোকেল পছন্দের সাথে যুক্ত লেআউট দিক নির্বিশেষে আপনার অ্যাপ একই আচরণ করে। অর্থাৎ, আপনার লেআউট সবসময় বাম থেকে ডানে থাকে।

এই বৈশিষ্ট্যের ডিফল্ট মান হল "false"

এই বৈশিষ্ট্যটি API স্তর 17 এ যোগ করা হয়েছে।

android:taskAffinity
একটি অ্যাফিনিটি নাম যা অ্যাপ্লিকেশনের মধ্যে থাকা সমস্ত ক্রিয়াকলাপের ক্ষেত্রে প্রযোজ্য, তাদের নিজস্ব taskAffinity বৈশিষ্ট্যগুলির সাথে একটি আলাদা সখ্যতা সেট করা ছাড়া৷ আরো তথ্যের জন্য যে বৈশিষ্ট্য দেখুন.

ডিফল্টরূপে, একটি অ্যাপ্লিকেশনের মধ্যে সমস্ত ক্রিয়াকলাপ একই সম্বন্ধ ভাগ করে নেয়। সেই অ্যাফিনিটির নামটি <manifest> উপাদান দ্বারা সেট করা প্যাকেজের নামের মতই।

android:testOnly
এই অ্যাপ্লিকেশনটি শুধুমাত্র পরীক্ষার উদ্দেশ্যে কিনা তা নির্দেশ করে৷ উদাহরণস্বরূপ, এটি কার্যকারিতা বা ডেটা নিজের বাইরে প্রকাশ করতে পারে যা একটি নিরাপত্তা গর্তের কারণ হতে পারে, কিন্তু পরীক্ষার জন্য দরকারী। এই ধরনের APK শুধুমাত্র adb এর মাধ্যমে ইনস্টল করা হয়। আপনি এটি Google Play এ প্রকাশ করতে পারবেন না।

আপনি রান ক্লিক করলে অ্যান্ড্রয়েড স্টুডিও স্বয়ংক্রিয়ভাবে এই বৈশিষ্ট্যটি যোগ করে .

android:theme
অ্যাপ্লিকেশনের সমস্ত ক্রিয়াকলাপের জন্য একটি ডিফল্ট থিম সংজ্ঞায়িত করে একটি শৈলী সংস্থানের একটি রেফারেন্স৷ স্বতন্ত্র ক্রিয়াকলাপগুলি তাদের নিজস্ব theme বৈশিষ্ট্যগুলি সেট করে ডিফল্টটিকে ওভাররাইড করতে পারে। আরও তথ্যের জন্য, শৈলী এবং থিম দেখুন।
android:uiOptions
একটি কার্যকলাপের UI এর জন্য অতিরিক্ত বিকল্প। নিম্নলিখিত মানগুলির মধ্যে একটি হতে হবে:
মান বর্ণনা
"none" কোনো অতিরিক্ত UI বিকল্প নেই। এটি ডিফল্ট।
"splitActionBarWhenNarrow" অ্যাপ বারে অ্যাকশন আইটেমগুলি প্রদর্শন করতে স্ক্রিনের নীচে একটি বার যুক্ত করে, যা অ্যাকশন বার নামেও পরিচিত, যখন অনুভূমিক স্থানের জন্য সীমাবদ্ধ থাকে, যেমন যখন হ্যান্ডসেটে প্রতিকৃতি মোডে থাকে৷ স্ক্রিনের শীর্ষে অ্যাপ বারে অল্প সংখ্যক অ্যাকশন আইটেম প্রদর্শিত হওয়ার পরিবর্তে, অ্যাপ বারটি উপরের নেভিগেশন বিভাগে এবং অ্যাকশন আইটেমগুলির জন্য নীচের বারে বিভক্ত হয়ে যায়। এর অর্থ হল অ্যাকশন আইটেমগুলির জন্য এবং শীর্ষে নেভিগেশন এবং শিরোনাম উপাদানগুলির জন্য একটি যুক্তিসঙ্গত পরিমাণ স্থান উপলব্ধ৷ মেনু আইটেম দুটি বার জুড়ে বিভক্ত করা হয় না. তারা সবসময় একসঙ্গে দেখা যায়।

অ্যাপ বার সম্পর্কে আরও তথ্যের জন্য, অ্যাপ বার যোগ করুন দেখুন।

এই বৈশিষ্ট্যটি API স্তর 14 এ যোগ করা হয়েছে।

android:usesCleartextTraffic
অ্যাপটি ক্লিয়ারটেক্সট এইচটিটিপির মতো ক্লিয়ারটেক্সট নেটওয়ার্ক ট্রাফিক ব্যবহার করতে চায় কিনা তা নির্দেশ করে। এপিআই লেভেল 27 বা তার নিচের অ্যাপ্লিকেশানগুলির জন্য ডিফল্ট মান হল "true" ৷ যে অ্যাপগুলি API স্তর 28 বা উচ্চতর ডিফল্টকে "false" তে লক্ষ্য করে।

যখন অ্যাট্রিবিউটটি "false" তে সেট করা হয়, প্ল্যাটফর্মের উপাদানগুলি, উদাহরণস্বরূপ, HTTP এবং FTP স্ট্যাক, DownloadManager এবং MediaPlayer , ক্লিয়ারটেক্সট ট্র্যাফিক ব্যবহার করার জন্য অ্যাপের অনুরোধগুলি প্রত্যাখ্যান করে৷

তৃতীয় পক্ষের লাইব্রেরিগুলিকেও এই সেটিংটিকে সম্মান করার জন্য দৃঢ়ভাবে উত্সাহিত করা হয়৷ ক্লিয়ারটেক্সট ট্র্যাফিক এড়ানোর মূল কারণ হল গোপনীয়তা, সত্যতা এবং টেম্পারিংয়ের বিরুদ্ধে সুরক্ষার অভাব। একটি নেটওয়ার্ক আক্রমণকারী ট্রান্সমিটেড ডেটা লুকিয়ে রাখতে পারে এবং সনাক্ত না করেই এটি পরিবর্তন করতে পারে।

এই পতাকাটিকে সর্বোত্তম প্রচেষ্টার ভিত্তিতে সম্মানিত করা হয়েছে কারণ Android অ্যাপ্লিকেশানগুলিকে প্রদত্ত অ্যাক্সেসের স্তরের ভিত্তিতে সমস্ত ক্লিয়ারটেক্সট ট্র্যাফিক প্রতিরোধ করা অসম্ভব৷ উদাহরণস্বরূপ, Socket এপিআই এই পতাকাটিকে সম্মান করবে এমন কোন প্রত্যাশা নেই, কারণ এটির ট্র্যাফিক স্পষ্ট পাঠ্যে আছে কিনা তা নির্ধারণ করতে পারে না।

যাইহোক, অ্যাপ্লিকেশনগুলি থেকে বেশিরভাগ নেটওয়ার্ক ট্র্যাফিক উচ্চ-স্তরের নেটওয়ার্ক স্ট্যাক এবং উপাদানগুলির দ্বারা পরিচালিত হয়, যা ApplicationInfo.flags বা NetworkSecurityPolicy.isCleartextTrafficPermitted() থেকে পড়ে এই পতাকাটিকে সম্মান করতে পারে।

দ্রষ্টব্য: WebView এপিআই স্তর 26 এবং উচ্চতর টার্গেট করা অ্যাপ্লিকেশনগুলির জন্য এই বৈশিষ্ট্যটিকে সম্মান করে৷

অ্যাপ ডেভেলপমেন্টের সময়, স্ট্রিক্টমোড অ্যাপ থেকে যেকোনো ক্লিয়ারটেক্সট ট্র্যাফিক সনাক্ত করতে ব্যবহার করা যেতে পারে। আরও তথ্যের জন্য, StrictMode.VmPolicy.Builder.detectCleartextNetwork() দেখুন।

এই বৈশিষ্ট্যটি API স্তর 23 এ যোগ করা হয়েছে।

এই পতাকাটি Android 7.0 (API স্তর 24) এবং তার উপরে উপেক্ষা করা হয় যদি একটি Android নেটওয়ার্ক নিরাপত্তা কনফিগ উপস্থিত থাকে।

android:vmSafeMode
অ্যাপটি ভার্চুয়াল মেশিন (VM) নিরাপদ মোডে কাজ করতে চায় কিনা তা নির্দেশ করে। ডিফল্ট মান হল "false"

এই অ্যাট্রিবিউটটি API লেভেল 8 এ যোগ করা হয়েছে, যেখানে "true" এর একটি মান ডালভিক জাস্ট-ইন-টাইম (JIT) কম্পাইলারকে নিষ্ক্রিয় করেছে।

এই বৈশিষ্ট্যটি API স্তর 22-এ অভিযোজিত হয়েছিল, যেখানে "true" -এর একটি মান ART-কে এগিয়ে-অফ-টাইম (AOT) কম্পাইলারকে নিষ্ক্রিয় করে।

প্রবর্তিত:
API স্তর 1
এছাড়াও দেখুন:
<activity>
<service>
<receiver>
<provider>
,
সিনট্যাক্স:
<application android:allowTaskReparenting=["true" | "false"]
             android:allowBackup=["true" | "false"]
             android:allowClearUserData=["true" | "false"]
             android:allowCrossUidActivitySwitchFromBelow=["true" | "false"]
             android:allowNativeHeapPointerTagging=["true" | "false"]
             android:appCategory=["accessibility" | "audio" | "game" |
             "image" | "maps" | "news" | "productivity" | "social" | "video"]
             android:backupAgent="string"
             android:backupInForeground=["true" | "false"]
             android:banner="drawable resource"
             android:dataExtractionRules="string resource"
             android:debuggable=["true" | "false"]
             android:description="string resource"
             android:enabled=["true" | "false"]
             android:extractNativeLibs=["true" | "false"]
             android:fullBackupContent="string"
             android:fullBackupOnly=["true" | "false"]
             android:gwpAsanMode=["always" | "never"]
             android:hasCode=["true" | "false"]
             android:hasFragileUserData=["true" | "false"]
             android:hardwareAccelerated=["true" | "false"]
             android:icon="drawable resource"
             android:isGame=["true" | "false"]
             android:isMonitoringTool=["parental_control" | "enterprise_management" |
             "other"]
             android:killAfterRestore=["true" | "false"]
             android:largeHeap=["true" | "false"]
             android:label="string resource"
             android:logo="drawable resource"
             android:manageSpaceActivity="string"
             android:name="string"
             android:networkSecurityConfig="xml resource"
             android:permission="string"
             android:persistent=["true" | "false"]
             android:process="string"
             android:restoreAnyVersion=["true" | "false"]
             android:requestLegacyExternalStorage=["true" | "false"]
             android:requiredAccountType="string"
             android:resizeableActivity=["true" | "false"]
             android:restrictedAccountType="string"
             android:supportsRtl=["true" | "false"]
             android:taskAffinity="string"
             android:testOnly=["true" | "false"]
             android:theme="resource or theme"
             android:uiOptions=["none" | "splitActionBarWhenNarrow"]
             android:usesCleartextTraffic=["true" | "false"]
             android:vmSafeMode=["true" | "false"] >
    . . .
</application>
এর মধ্যে রয়েছে:
<manifest>
থাকতে পারে:
<activity>
<activity-alias>
<meta-data>
<service>
<receiver>
<profileable>
<provider>
<uses-library>
<uses-native-library>
বর্ণনা:

আবেদনের ঘোষণা। এই উপাদানটিতে উপ-এলিমেন্ট রয়েছে যা অ্যাপ্লিকেশনের প্রতিটি উপাদান ঘোষণা করে এবং এমন বৈশিষ্ট্য রয়েছে যা সমস্ত উপাদানকে প্রভাবিত করতে পারে।

এই বৈশিষ্ট্যগুলির মধ্যে অনেকগুলি, যেমন icon , label , permission , process , taskAffinity , এবং allowTaskReparenting , উপাদান উপাদানগুলির সংশ্লিষ্ট বৈশিষ্ট্যগুলির জন্য ডিফল্ট মান সেট করে৷ অন্যান্য, যেমন debuggable , enabled , description , এবং allowClearUserData , সামগ্রিকভাবে অ্যাপ্লিকেশনের জন্য মান সেট করে এবং উপাদানগুলির দ্বারা ওভাররাইড করা হয় না৷

গুণাবলী
android:allowTaskReparenting
অ্যাপ্লিকেশানটি সংজ্ঞায়িত ক্রিয়াকলাপগুলি যে টাস্ক থেকে শুরু করে সেই টাস্কে যেতে পারে কিনা সেই টাস্কটি পরবর্তীতে সামনে আনা হলে তাদের সাথে সম্পর্ক রয়েছে কিনা। এটি "true" যদি তারা সরাতে পারে, এবং "false" যদি তারা যে কাজটি শুরু করেছিল তার সাথেই থাকে। ডিফল্ট মান হল "false"

<activity> উপাদানটির নিজস্ব allowTaskReparenting বৈশিষ্ট্য রয়েছে যা এখানে সেট করা মানকে ওভাররাইড করতে পারে।

android:allowBackup

অ্যাপ্লিকেশনটিকে ব্যাকআপে অংশ নিতে এবং পরিকাঠামো পুনরুদ্ধার করতে দেওয়া হবে কিনা। যদি এই অ্যাট্রিবিউটটি "false" এ সেট করা থাকে, তাহলে অ্যাপ্লিকেশনটির কোনো ব্যাকআপ বা পুনরুদ্ধার করা হয় না, এমনকি একটি পূর্ণ-সিস্টেম ব্যাকআপ দ্বারা যা অন্যথায় adb ব্যবহার করে সমস্ত অ্যাপ্লিকেশন ডেটা সংরক্ষণ করতে পারে। এই বৈশিষ্ট্যের ডিফল্ট মান হল "true"

দ্রষ্টব্য: Android 12 (API স্তর 31) বা উচ্চতরকে লক্ষ্য করা অ্যাপগুলির জন্য, এই আচরণটি পরিবর্তিত হয়। কিছু ডিভাইস নির্মাতার ডিভাইসে, আপনি আপনার অ্যাপের ফাইলের ডিভাইস থেকে ডিভাইস মাইগ্রেশন অক্ষম করতে পারবেন না।

যাইহোক, আপনি ক্লাউড-ভিত্তিক ব্যাকআপ অক্ষম করতে পারেন এবং এই অ্যাট্রিবিউটটিকে "false" তে সেট করে আপনার অ্যাপের ফাইলগুলি পুনরুদ্ধার করতে পারেন, এমনকি যদি আপনার অ্যাপটি Android 12 (API স্তর 31) বা উচ্চতরকে লক্ষ্য করে।

আরও তথ্যের জন্য, পৃষ্ঠাটির ব্যাকআপ এবং পুনরুদ্ধার বিভাগটি দেখুন যা Android 12 (API স্তর 31) বা উচ্চতর টার্গেট করা অ্যাপগুলির আচরণের পরিবর্তনগুলি বর্ণনা করে৷

android:allowClearUserData

অ্যাপ্লিকেশনটিকে ব্যবহারকারীর ডেটা পুনরায় সেট করতে দেওয়া হবে কিনা। এই ডেটাতে ফ্ল্যাগ রয়েছে, যেমন ব্যবহারকারী পরিচায়ক টুলটিপ দেখেছেন কিনা, সেইসাথে ব্যবহারকারী-কাস্টমাইজযোগ্য সেটিংস এবং পছন্দগুলি। এই বৈশিষ্ট্যের ডিফল্ট মান হল "true"

দ্রষ্টব্য: শুধুমাত্র যে অ্যাপগুলি সিস্টেম ইমেজের অংশ তারাই এই বৈশিষ্ট্যটি স্পষ্টভাবে ঘোষণা করতে পারে৷ তৃতীয় পক্ষের অ্যাপগুলি তাদের ম্যানিফেস্ট ফাইলগুলিতে এই বৈশিষ্ট্যটি অন্তর্ভুক্ত করতে পারে না৷

আরও তথ্যের জন্য, ডেটা ব্যাকআপ ওভারভিউ দেখুন।

android:allowCrossUidActivitySwitchFromBelow

টাস্কে এর নিচের ক্রিয়াকলাপগুলি অন্যান্য কার্যক্রম শুরু করতে বা কাজটি শেষ করতে পারে কিনা তা নির্দিষ্ট করে।

টার্গেট SDK লেভেল Build.VERSION_CODES.VANILLA_ICE_CREAM VERSION_CODES.VANILLA_ICE_CREAM থেকে শুরু করে, অ্যাপগুলিকে নতুন ক্রিয়াকলাপ শুরু করা বা তাদের কাজ শেষ করা থেকে ব্লক করা হতে পারে যদি না এই ধরনের টাস্কের শীর্ষ ক্রিয়াকলাপটি নিরাপত্তার কারণে একই UID-এর অন্তর্গত হয়৷

এই ফ্ল্যাগটিকে true সেট করা হলে এই কার্যকলাপটি শীর্ষে থাকলে লঞ্চিং অ্যাপটিকে সীমাবদ্ধতা উপেক্ষা করার অনুমতি দেবে৷ এই ক্রিয়াকলাপের UID-এর সাথে মিলে যাওয়া অ্যাপগুলিকে সর্বদা ছাড় দেওয়া হয়।

আরও তথ্যের জন্য, সুরক্ষিত পটভূমি কার্যকলাপ লঞ্চ দেখুন।

android:allowNativeHeapPointerTagging

অ্যাপটি হিপ পয়েন্টার ট্যাগিং বৈশিষ্ট্য সক্ষম করে কিনা। এই বৈশিষ্ট্যের ডিফল্ট মান হল "true"

দ্রষ্টব্য: এই বৈশিষ্ট্যটি অক্ষম করা অন্তর্নিহিত কোড স্বাস্থ্য সমস্যা সমাধান করে না । ভবিষ্যতের হার্ডওয়্যার ডিভাইসগুলি এই ম্যানিফেস্ট ট্যাগকে সমর্থন নাও করতে পারে৷

আরও তথ্যের জন্য, ট্যাগ করা পয়েন্টার দেখুন।

android:appCategory

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

নিম্নলিখিত ধ্রুবক মানগুলির মধ্যে একটি হতে হবে।

মান বর্ণনা
accessibility যে অ্যাপগুলি প্রাথমিকভাবে অ্যাক্সেসযোগ্যতা অ্যাপ, যেমন স্ক্রিন-রিডার।
audio যে অ্যাপগুলি প্রাথমিকভাবে অডিও বা মিউজিকের সাথে কাজ করে, যেমন মিউজিক প্লেয়ার।
game যে অ্যাপগুলো মূলত গেম।
image যে অ্যাপগুলি প্রাথমিকভাবে ছবি বা ফটোর সাথে কাজ করে, যেমন ক্যামেরা বা গ্যালারি অ্যাপ।
maps যে অ্যাপগুলি প্রাথমিকভাবে ম্যাপ অ্যাপ, যেমন নেভিগেশন অ্যাপ।
news যে অ্যাপগুলি প্রাথমিকভাবে খবরের অ্যাপ, যেমন সংবাদপত্র, ম্যাগাজিন বা স্পোর্টস অ্যাপ।
productivity যে অ্যাপগুলি প্রাথমিকভাবে উত্পাদনশীলতার অ্যাপ, যেমন ক্লাউড স্টোরেজ বা কর্মক্ষেত্রের অ্যাপ।
social যে অ্যাপগুলি প্রাথমিকভাবে সামাজিক অ্যাপ, যেমন মেসেজিং, যোগাযোগ, ইমেল বা সামাজিক নেটওয়ার্ক অ্যাপ।
video যে অ্যাপগুলি প্রাথমিকভাবে ভিডিও বা সিনেমার সাথে কাজ করে, যেমন স্ট্রিমিং ভিডিও অ্যাপ।

android:backupAgent
অ্যাপ্লিকেশনের ব্যাকআপ এজেন্ট প্রয়োগ করে এমন ক্লাসের নাম, BackupAgent এর একটি সাবক্লাস। অ্যাট্রিবিউট মান হল একটি সম্পূর্ণ যোগ্য শ্রেণীর নাম, যেমন "com.example.project.MyBackupAgent" । যাইহোক, শর্টহ্যান্ড হিসাবে, যদি নামের প্রথম অক্ষরটি একটি পিরিয়ড হয়, উদাহরণস্বরূপ, ".MyBackupAgent" , এটি <manifest> উপাদানে নির্দিষ্ট করা প্যাকেজের নামের সাথে যুক্ত করা হয়।

কোন ডিফল্ট নেই. নাম নির্দিষ্ট হতে হবে।

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

ডিফল্ট মান হল "false" , যার মানে হল যে OS অগ্রভাগে চলার সময় অ্যাপটির ব্যাক আপ নেওয়া এড়িয়ে যায়, যেমন একটি মিউজিক অ্যাপ যেটি startForeground() অবস্থায় একটি পরিষেবা ব্যবহার করে সক্রিয়ভাবে মিউজিক চালাচ্ছে।

android:banner
একটি অঙ্কনযোগ্য সংস্থান যা এর সাথে সম্পর্কিত আইটেমের জন্য একটি বর্ধিত গ্রাফিকাল ব্যানার প্রদান করে। সমস্ত অ্যাপ্লিকেশন ক্রিয়াকলাপের জন্য একটি ডিফল্ট ব্যানার সরবরাহ করতে <application> ট্যাগ ব্যবহার করুন বা একটি নির্দিষ্ট কার্যকলাপের জন্য একটি ব্যানার সরবরাহ করতে <activity> ট্যাগের সাথে ব্যবহার করুন।

অ্যান্ড্রয়েড টিভি হোম স্ক্রিনে একটি অ্যাপ উপস্থাপন করতে সিস্টেমটি ব্যানার ব্যবহার করে। অতএব, শুধুমাত্র CATEGORY_LEANBACK_LAUNCHER উদ্দেশ্য পরিচালনা করে এমন একটি কার্যকলাপ সহ অ্যাপ্লিকেশনগুলির জন্য এটি নির্দিষ্ট করুন৷

এই অ্যাট্রিবিউটটি ইমেজ ধারণকারী একটি অঙ্কনযোগ্য সম্পদের রেফারেন্স হিসাবে সেট করা হয়েছে, উদাহরণস্বরূপ "@drawable/banner" । কোন ডিফল্ট ব্যানার নেই.

আরও তথ্যের জন্য, একটি হোম স্ক্রীন ব্যানার প্রদান দেখুন।

android:dataExtractionRules

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

XML ফাইলের বিন্যাস সম্পর্কে তথ্যের জন্য, ব্যাকআপ এবং পুনরুদ্ধার দেখুন।

android:debuggable
অ্যাপ্লিকেশনটি ডিবাগ করা যাবে কি না, এমনকি ব্যবহারকারী মোডে একটি ডিভাইসে চললেও। এটা হতে পারে "true" এবং না হলে "false" । ডিফল্ট মান হল "false"
android:description
অ্যাপ্লিকেশন সম্পর্কে ব্যবহারকারী-পাঠযোগ্য পাঠ্য, যা অ্যাপ্লিকেশন লেবেলের চেয়ে দীর্ঘ এবং আরও বর্ণনামূলক৷ মান একটি স্ট্রিং সম্পদ একটি রেফারেন্স হিসাবে সেট করা হয়. লেবেল থেকে ভিন্ন, এটি একটি কাঁচা স্ট্রিং হতে পারে না। কোন ডিফল্ট মান নেই।
android:enabled
অ্যান্ড্রয়েড সিস্টেম অ্যাপ্লিকেশনটির উপাদানগুলিকে তাত্ক্ষণিক করতে পারে কিনা৷ এটা করতে পারলে "true" এবং না হলে "false" । মানটি "true" হলে, প্রতিটি উপাদানের enabled বৈশিষ্ট্য নির্ধারণ করে যে সেই উপাদানটি সক্ষম কিনা। মানটি "false" হলে, এটি উপাদান-নির্দিষ্ট মানগুলিকে ওভাররাইড করে এবং সমস্ত উপাদান অক্ষম করা হয়৷

ডিফল্ট মান হল "true"

android:extractNativeLibs

AGP 4.2.0 দিয়ে শুরু করে, DSL অপশন useLegacyPackaging এক্সট্রাক্ট extractNativeLibs ম্যানিফেস্ট অ্যাট্রিবিউটকে প্রতিস্থাপন করে। নেটিভ লাইব্রেরি কম্প্রেশন আচরণ কনফিগার করতে ম্যানিফেস্ট ফাইলে extractNativeLibs এর পরিবর্তে আপনার অ্যাপের build.gradle ফাইলে useLegacyPackaging ব্যবহার করুন। আরও তথ্যের জন্য, রিলিজ নোট দেখুন সংকুচিত নেটিভ লাইব্রেরি প্যাকেজ করতে DSL ব্যবহার করুন

এই বৈশিষ্ট্যটি নির্দেশ করে যে প্যাকেজ ইনস্টলার APK থেকে ফাইল সিস্টেমে নেটিভ লাইব্রেরিগুলি বের করে কিনা। যদি "false" তে সেট করা থাকে, তাহলে আপনার নেটিভ লাইব্রেরিগুলি APK-এ সংকুচিত না হয়ে সংরক্ষণ করা হয়৷ যদিও আপনার APK বড় হতে পারে, আপনার অ্যাপ্লিকেশন দ্রুত লোড হয় কারণ লাইব্রেরিগুলি রানটাইমে APK থেকে সরাসরি লোড হয়।

extractNativeLibs ডিফল্ট মানটি minSdkVersion এবং আপনি যে এজিপি ব্যবহার করছেন তার সংস্করণের উপর নির্ভর করে। বেশিরভাগ ক্ষেত্রে, ডিফল্ট আচরণ সম্ভবত আপনি যা চান তা হ'ল এবং আপনাকে এই বৈশিষ্ট্যটি স্পষ্টভাবে সেট করতে হবে না।

android:fullBackupContent
এই বৈশিষ্ট্যটি একটি এক্সএমএল ফাইলের দিকে নির্দেশ করে যাতে অটো ব্যাকআপের জন্য সম্পূর্ণ ব্যাকআপ বিধি থাকে। এই নিয়মগুলি নির্ধারণ করে যে কোন ফাইলগুলি ব্যাক আপ হয়। আরও তথ্যের জন্য, অটো ব্যাকআপের জন্য এক্সএমএল কনফিগার সিনট্যাক্স দেখুন।

এই বৈশিষ্ট্যটি al চ্ছিক। যদি এটি নির্দিষ্ট না করা হয় তবে ডিফল্টরূপে, অটো ব্যাকআপে আপনার অ্যাপের বেশিরভাগ ফাইল অন্তর্ভুক্ত রয়েছে। আরও তথ্যের জন্য, ব্যাক আপ করা ফাইলগুলি দেখুন।

android:fullBackupOnly
এই বৈশিষ্ট্যটি নির্দেশ করে যে এটি উপলব্ধ ডিভাইসগুলিতে অটো ব্যাকআপ ব্যবহার করবেন কিনা। যদি "true" এ সেট করা থাকে তবে অ্যান্ড্রয়েড 6.0 (এপিআই স্তর 23) বা উচ্চতর চালিত কোনও ডিভাইসে ইনস্টল করার সময় আপনার অ্যাপটি অটো ব্যাকআপ সম্পাদন করে। পুরানো ডিভাইসগুলিতে, আপনার অ্যাপ্লিকেশনটি এই বৈশিষ্ট্যটিকে উপেক্ষা করে এবং কী/মান ব্যাকআপগুলি সম্পাদন করে।

ডিফল্ট মান হল "false"

android:gwpAsanMode
এই বৈশিষ্ট্যটি নির্দেশ করে যে জিডব্লিউপি-আসান , একটি নেটিভ মেমরি বরাদ্দকারী বৈশিষ্ট্য যা ব্যবহার-পরে-মুক্ত এবং হিপ-বাফার-ওভারফ্লো বাগগুলি খুঁজে পেতে সহায়তা করে।

ডিফল্ট মান "never" হয় না।

android:hasCode
অ্যাপ্লিকেশনটিতে কোনও ডেক্স কোড রয়েছে কিনা - এটি হ'ল কোটলিন বা জাভা প্রোগ্রামিং ভাষা ব্যবহার করে কোড। এটি যদি "true" হয় এবং যদি তা না হয় তবে "false" । যখন মানটি "false" হয়, তখন উপাদানগুলি চালু করার সময় সিস্টেম কোনও অ্যাপ্লিকেশন কোড লোড করার চেষ্টা করে না। ডিফল্ট মান "true"

যদি অ্যাপ্লিকেশনটিতে নেটিভ (সি/সি ++) কোড অন্তর্ভুক্ত থাকে তবে কোনও ডেক্স কোড নেই, তবে এটি "false" এ সেট করা উচিত। যদি "true" এ সেট করা হয় যখন এপিকে কোনও ডেক্স কোড না থাকে, অ্যাপ্লিকেশনটি লোড করতে ব্যর্থ হতে পারে।

এই সম্পত্তি অবশ্যই নির্ভরতা দ্বারা আবেদনে অন্তর্ভুক্ত কোডের জন্য অ্যাকাউন্ট করতে হবে। যদি অ্যাপ্লিকেশনটি জাভা/কোটলিন কোড ব্যবহার করে বা সরাসরি কোনও জারে ব্যবহার করে এমন কোনও এএআর এর উপর নির্ভর করে তবে app:hasCode অবশ্যই "true" হতে হবে, বা এটি ডিফল্ট হিসাবে বাদ দেওয়া উচিত।

উদাহরণস্বরূপ, আপনার অ্যাপ্লিকেশনটি খেলতে বৈশিষ্ট্য বিতরণকে সমর্থন করতে পারে এবং এমন বৈশিষ্ট্য মডিউলগুলি অন্তর্ভুক্ত করতে পারে যা কোনও ডেক্স ফাইল তৈরি করে না, যা অ্যান্ড্রয়েড প্ল্যাটফর্মের জন্য বাইটকোড অনুকূলিত। যদি তা হয় তবে রানটাইম ত্রুটিগুলি এড়াতে আপনাকে এই সম্পত্তিটি মডিউলটির ম্যানিফেস্ট ফাইলে "false" এ সেট করতে হবে।

android:hasFragileUserData
ব্যবহারকারী যখন অ্যাপটি আনইনস্টল করে তখন অ্যাপের ডেটা রাখার জন্য ব্যবহারকারীকে প্রম্পট দেখাতে হবে কিনা। ডিফল্ট মান হল "false"
android:hardwareAccelerated
এই অ্যাপ্লিকেশনটিতে সমস্ত ক্রিয়াকলাপ এবং দৃষ্টিভঙ্গির জন্য হার্ডওয়্যার-ত্বরণযুক্ত রেন্ডারিং সক্ষম করা আছে কিনা। এটি সক্ষম করা থাকলে এটি "true" এবং যদি না হয় তবে "false" । আপনি যদি minSdkVersion বা targetSdkVersion "14" বা উচ্চতর করে সেট করেন তবে ডিফল্ট মানটি "true" অন্যথায়, এটি "false"

অ্যান্ড্রয়েড 3.0 (এপিআই স্তর 11) থেকে শুরু করে, অনেকগুলি সাধারণ 2 ডি গ্রাফিক্স অপারেশনের পারফরম্যান্স উন্নত করতে অ্যাপ্লিকেশনগুলিতে একটি হার্ডওয়্যার-এক্সিলারেটেড ওপেনজিএল রেন্ডারার উপলব্ধ। যখন হার্ডওয়্যার-এক্সিলারেটেড রেন্ডারার সক্ষম করা হয়, তখন ক্যানভাস, পেইন্ট, এক্সফেরমোড, কালারফিল্টার, শেডার এবং ক্যামেরায় বেশিরভাগ ক্রিয়াকলাপ ত্বরান্বিত হয়।

এর ফলে মসৃণ অ্যানিমেশনগুলি, মসৃণ স্ক্রোলিং এবং সামগ্রিকভাবে উন্নত প্রতিক্রিয়াশীলতার ফলস্বরূপ, এমনকি এমন অ্যাপ্লিকেশনগুলির জন্য যা স্পষ্টভাবে ফ্রেমওয়ার্কের ওপেনজিএল লাইব্রেরিগুলি ব্যবহার করে না।

ওপেনজিএল 2 ডি অপারেশনগুলির সমস্তই ত্বরান্বিত হয় না। আপনি যদি হার্ডওয়্যার-এক্সিলারেটেড রেন্ডারার সক্ষম করেন তবে আপনার অ্যাপ্লিকেশনটি পরীক্ষা করুন যাতে এটি ত্রুটি ছাড়াই রেন্ডারারের ব্যবহার করতে পারে।

আরও তথ্যের জন্য, হার্ডওয়্যার ত্বরণ গাইডটি পড়ুন।

android:icon
পুরো অ্যাপ্লিকেশনটির জন্য একটি আইকন এবং অ্যাপ্লিকেশনটির প্রতিটি উপাদানগুলির জন্য ডিফল্ট আইকন। icon <activity> <activity-alias> <service> <receiver> <provider>

এই বৈশিষ্ট্যটি "@drawable/icon" এর মতো চিত্রযুক্ত একটি অঙ্কনযোগ্য সংস্থার রেফারেন্স হিসাবে সেট করা হয়েছে। কোনও ডিফল্ট আইকন নেই।

android:isGame
অ্যাপ্লিকেশনটি একটি খেলা কিনা। সিস্টেমগুলি গেম হিসাবে শ্রেণিবদ্ধ অ্যাপ্লিকেশনগুলিকে একত্রিত করতে পারে বা অন্যান্য অ্যাপ্লিকেশন থেকে পৃথকভাবে প্রদর্শন করতে পারে। ডিফল্টটি "false"
android:isMonitoringTool

ইঙ্গিত দেয় যে এই অ্যাপ্লিকেশনটি অন্যান্য ব্যক্তিদের নিরীক্ষণের জন্য ডিজাইন করা হয়েছে।

দ্রষ্টব্য: যদি কোনও অ্যাপ্লিকেশন এই বৈশিষ্ট্যটিকে তার ম্যানিফেস্টে ঘোষণা করে তবে বিকাশকারীকে অবশ্যই গুগল প্লেতে অ্যাপ্লিকেশনটি প্রকাশ করতে স্টালকারওয়্যার নীতি অনুসরণ করতে হবে।

কোন ডিফল্ট মান নেই। বিকাশকারীকে অবশ্যই নিম্নলিখিত মানগুলির একটি নির্দিষ্ট করতে হবে:

মান বর্ণনা
"parental_control" অ্যাপ্লিকেশন পিতামাতার নিয়ন্ত্রণকে পরিবেশন করে এবং বিশেষত তাদের বাচ্চাদের সুরক্ষিত রাখতে চায় এমন পিতামাতাদের দিকে লক্ষ্য করা যায়।
"enterprise_management" অ্যাপ্লিকেশন কর্মীদের দেওয়া ডিভাইসগুলি পরিচালনা করতে এবং ট্র্যাক করতে চায় এমন উদ্যোগগুলিতে সরবরাহ করে।
"other" অ্যাপ্লিকেশনটি কোনও ব্যবহারের ক্ষেত্রে সরবরাহ করে অন্যথায় এই টেবিলটিতে নির্দিষ্ট করা হয়নি।
android:killAfterRestore

সম্পূর্ণ সিস্টেম পুনরুদ্ধার অপারেশন চলাকালীন অ্যাপ্লিকেশনটি তার সেটিংসের পরে পুনরুদ্ধার হওয়ার পরে শেষ হয় কিনা। একক-প্যাকেজ পুনরুদ্ধার অপারেশনগুলি কখনই অ্যাপ্লিকেশনটি বন্ধ করে দেয় না। পূর্ণ-সিস্টেম পুনরুদ্ধার অপারেশনগুলি সাধারণত একবারে ঘটে যখন ফোনটি প্রথম সেট আপ করা হয়। তৃতীয় পক্ষের অ্যাপ্লিকেশনগুলিকে সাধারণত এই বৈশিষ্ট্যটি ব্যবহার করার প্রয়োজন হয় না।

ডিফল্টটি "true" , যার অর্থ অ্যাপ্লিকেশনটি একটি পূর্ণ-সিস্টেম পুনরুদ্ধারের সময় তার ডেটা প্রক্রিয়াকরণ শেষ করার পরে এটি সমাপ্ত হয়।

android:largeHeap

অ্যাপ্লিকেশনটির প্রক্রিয়াগুলি একটি বৃহত ডালভিক হিপ দিয়ে তৈরি করা হয়েছে কিনা। এটি অ্যাপ্লিকেশনটির জন্য তৈরি সমস্ত প্রক্রিয়াগুলিতে প্রযোজ্য। এটি কেবল একটি প্রক্রিয়াতে লোড হওয়া প্রথম অ্যাপ্লিকেশনটিতে প্রযোজ্য। আপনি যদি একাধিক অ্যাপ্লিকেশনগুলিকে একটি প্রক্রিয়া ব্যবহার করতে কোনও ভাগ করা ব্যবহারকারী আইডি ব্যবহার করছেন তবে অনির্দেশ্য ফলাফল এড়াতে তাদের সকলকে অবশ্যই এই বিকল্পটি ধারাবাহিকভাবে ব্যবহার করতে হবে।

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

রানটাইমে উপলভ্য মেমরির আকারটি জিজ্ঞাসা করতে, getMemoryClass() বা getLargeMemoryClass() পদ্ধতিগুলি ব্যবহার করুন।

android:label
সামগ্রিকভাবে অ্যাপ্লিকেশনটির জন্য একটি ব্যবহারকারী-পঠনযোগ্য লেবেল এবং অ্যাপ্লিকেশনটির প্রতিটি উপাদানগুলির জন্য একটি ডিফল্ট লেবেল। label <activity> <activity-alias> <service> <receiver> <provider>

লেবেলটি স্ট্রিং রিসোর্সের রেফারেন্স হিসাবে সেট করা হয়েছে, যাতে এটি ব্যবহারকারী ইন্টারফেসের অন্যান্য স্ট্রিংয়ের মতো স্থানীয়করণ করা যায়। যাইহোক, আপনি অ্যাপ্লিকেশনটি বিকাশ করার সময় সুবিধা হিসাবে, এটি একটি কাঁচা স্ট্রিং হিসাবেও সেট করা যেতে পারে।

android:logo
পুরো অ্যাপ্লিকেশনটির জন্য একটি লোগো এবং ক্রিয়াকলাপগুলির জন্য ডিফল্ট লোগো। এই বৈশিষ্ট্যটি "@drawable/logo" এর মতো চিত্রযুক্ত একটি অঙ্কনযোগ্য সংস্থার রেফারেন্স হিসাবে সেট করা হয়েছে। কোনও ডিফল্ট লোগো নেই।
android:manageSpaceActivity
কোনও Activity সাবক্লাসের সম্পূর্ণ যোগ্য নাম যা সিস্টেমটি ব্যবহারকারীদের ডিভাইসে অ্যাপ্লিকেশন দ্বারা দখল করা মেমরিটি পরিচালনা করতে দেয়। ক্রিয়াকলাপটি একটি <activity> উপাদান দিয়েও ঘোষণা করা হয়।
android:name
অ্যাপ্লিকেশনটির জন্য প্রয়োগ করা একটি Application সাবক্লাসের সম্পূর্ণ যোগ্য নাম। যখন আবেদন প্রক্রিয়া শুরু হয়, এই শ্রেণিটি অ্যাপ্লিকেশনটির যে কোনও উপাদানগুলির আগে ইনস্ট্যান্ট করা হয়।

সাবক্লাসটি al চ্ছিক। বেশিরভাগ অ্যাপ্লিকেশনগুলির একটি প্রয়োজন হয় না। সাবক্লাসের অনুপস্থিতিতে, অ্যান্ড্রয়েড বেস Application শ্রেণীর একটি উদাহরণ ব্যবহার করে।

android:networkSecurityConfig

আপনার অ্যাপ্লিকেশনটির নেটওয়ার্ক সুরক্ষা কনফিগারেশন রয়েছে এমন এক্সএমএল ফাইলের নাম নির্দিষ্ট করে। মানটি কনফিগারেশনযুক্ত এক্সএমএল রিসোর্স ফাইলের একটি রেফারেন্স।

এই বৈশিষ্ট্যটি এপিআই স্তর 24 এ যুক্ত করা হয়েছিল।

android:permission
অ্যাপ্লিকেশনটির সাথে ইন্টারঅ্যাক্ট করার জন্য ক্লায়েন্টদের যে অনুমতিগুলির প্রয়োজন হয় তার নাম। এই বৈশিষ্ট্যটি একটি অনুমতি নির্ধারণের একটি সুবিধাজনক উপায় যা অ্যাপ্লিকেশনটির সমস্ত উপাদানগুলির জন্য প্রযোজ্য। এটি পৃথক উপাদানগুলির permission বৈশিষ্ট্যগুলি সেট করে ওভাররাইট করা হয়।

অনুমতি সম্পর্কে আরও তথ্যের জন্য, অ্যাপ্লিকেশনটি প্রকাশের ওভারভিউ এবং সুরক্ষা টিপসের অনুমতি বিভাগটি দেখুন।

android:persistent
অ্যাপ্লিকেশনটি সর্বদা চলমান থাকে কিনা। এটি যদি "true" হয় এবং যদি তা না হয় তবে "false" । ডিফল্ট মান হল "false" । অ্যাপ্লিকেশনগুলি সাধারণত এই পতাকাটি সেট করে না। অধ্যবসায় মোডটি কেবলমাত্র নির্দিষ্ট সিস্টেম অ্যাপ্লিকেশনগুলির জন্য।
android:process
এমন একটি প্রক্রিয়ার নাম যেখানে অ্যাপ্লিকেশনটির সমস্ত উপাদান চলে। প্রতিটি উপাদান নিজস্ব process বৈশিষ্ট্য সেট করে এই ডিফল্টটি ওভাররাইড করতে পারে।

ডিফল্টরূপে, অ্যান্ড্রয়েড যখন এর উপাদানগুলির প্রথমটি চালানো দরকার তখন কোনও অ্যাপ্লিকেশনটির জন্য একটি প্রক্রিয়া তৈরি করে। সমস্ত উপাদানগুলি তখন সেই প্রক্রিয়াতে চলে। ডিফল্ট প্রক্রিয়াটির নাম <manifest> উপাদান দ্বারা নির্ধারিত প্যাকেজ নামের সাথে মেলে।

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

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

android:restoreAnyVersion
ইঙ্গিত দেয় যে অ্যাপ্লিকেশনটি কোনও ব্যাক-আপ ডেটা সেট পুনরুদ্ধার করার জন্য প্রস্তুত রয়েছে, এমনকি যদি ব্যাকআপটি ডিভাইসে বর্তমানে ইনস্টল করা থাকে তার চেয়ে অ্যাপ্লিকেশনটির নতুন সংস্করণ দ্বারা সংরক্ষণ করা হয়। "true" এ এই বৈশিষ্ট্যটি সেট করা ব্যাকআপ ম্যানেজারকে পুনরুদ্ধার করার চেষ্টা করতে দেয় এমনকি যখন কোনও সংস্করণ অমিল পরামর্শ দেয় যে ডেটা বেমানান। সতর্কতার সাথে ব্যবহার করুন!

এই বৈশিষ্ট্যের ডিফল্ট মান "false"

android:requestLegacyExternalStorage

অ্যাপ্লিকেশনটি স্কোপড স্টোরেজ থেকে বেরিয়ে যেতে চায় কিনা।

দ্রষ্টব্য: নীতি বা অ্যাপ্লিকেশন সামঞ্জস্যতার সাথে সম্পর্কিত পরিবর্তনের উপর নির্ভর করে সিস্টেমটি এই অপ্ট-আউট অনুরোধটিকে সম্মান করতে পারে না।

android:requiredAccountType
ফাংশনটিতে অ্যাপ্লিকেশন দ্বারা প্রয়োজনীয় অ্যাকাউন্টের ধরণ নির্দিষ্ট করে। যদি আপনার অ্যাপ্লিকেশনটির জন্য কোনও Account প্রয়োজন হয় তবে এই বৈশিষ্ট্যের জন্য মানটি অবশ্যই আপনার অ্যাপ্লিকেশন দ্বারা ব্যবহৃত অ্যাকাউন্ট প্রমাণীকরণকারী ধরণের সাথে সামঞ্জস্য করতে হবে, যেমন "com.google" এর মতো AuthenticatorDescription দ্বারা সংজ্ঞায়িত করা হয়েছে।

ডিফল্ট মানটি নাল এবং ইঙ্গিত দেয় যে অ্যাপ্লিকেশনটি কোনও অ্যাকাউন্ট ছাড়াই কাজ করতে পারে।

কারণ সীমাবদ্ধ প্রোফাইলগুলি অ্যাকাউন্টগুলি যুক্ত করতে পারে না, এই বৈশিষ্ট্যটি নির্দিষ্ট করে আপনার অ্যাপ্লিকেশনটিকে একটি সীমাবদ্ধ প্রোফাইল থেকে অনুপলব্ধ করে তোলে যদি না আপনি android:restrictedAccountType

সাবধানতা: যদি অ্যাকাউন্টের ডেটা ব্যক্তিগতভাবে সনাক্তযোগ্য তথ্য প্রকাশ করতে পারে তবে আপনি এই বৈশিষ্ট্যটি ঘোষণা করা এবং android:restrictedAccountType নাল, যাতে সীমাবদ্ধ প্রোফাইলগুলি আপনার অ্যাপ্লিকেশনটি মালিক ব্যবহারকারীর সাথে সম্পর্কিত ব্যক্তিগত তথ্য অ্যাক্সেস করতে ব্যবহার করতে পারে না।

এই বৈশিষ্ট্যটি এপিআই স্তর 18 এ যুক্ত করা হয়েছিল।

android:resizeableActivity

অ্যাপটি মাল্টি-উইন্ডো মোড সমর্থন করে কিনা তা নির্দিষ্ট করে। আপনি এই বৈশিষ্ট্যটি <activity> বা <application> উপাদানটিতে সেট করতে পারেন।

আপনি যদি এই বৈশিষ্ট্যটিকে "true" এ সেট করেন তবে ব্যবহারকারী স্প্লিট-স্ক্রিন এবং ফ্রি-ফর্ম মোডে ক্রিয়াকলাপটি চালু করতে পারেন। আপনি যদি "false" এ বৈশিষ্ট্যটি সেট করেন তবে অ্যাপটি বহু-উইন্ডো পরিবেশের জন্য পরীক্ষা বা অনুকূলিত করা যায় না। সামঞ্জস্যতা মোড প্রয়োগ করে সিস্টেমটি এখনও মাল্টি-উইন্ডো মোডে ক্রিয়াকলাপটি রাখতে পারে।

"true" এ এই বৈশিষ্ট্যটি সেট করা গ্যারান্টি দেয় না যে স্ক্রিনে দৃশ্যমান মাল্টি-উইন্ডো মোডে অন্য কোনও অ্যাপ্লিকেশন নেই, যেমন চিত্র-ইন-চিত্র বা অন্যান্য প্রদর্শনগুলিতে। অতএব, এই পতাকাটি নির্ধারণের অর্থ এই নয় যে আপনার অ্যাপ্লিকেশনটিতে একচেটিয়া সংস্থান অ্যাক্সেস রয়েছে।

এপিআই স্তর 24 বা উচ্চতর লক্ষ্য করে অ্যাপ্লিকেশনগুলির জন্য, ডিফল্টটি "true"

যদি আপনার অ্যাপ এপিআই লেভেল 31 বা তার বেশি টার্গেট করে, তাহলে এই অ্যাট্রিবিউটটি ছোট এবং বড় স্ক্রিনে ভিন্নভাবে কাজ করে:

  • বড় পর্দা (এসডাব্লু> = 600 ডিপি): সমস্ত অ্যাপ্লিকেশন মাল্টি-উইন্ডো মোডকে সমর্থন করে। বৈশিষ্ট্যটি নির্দেশ করে যে কোনও অ্যাপ্লিকেশনকে পুনরায় আকার দেওয়া যেতে পারে কিনা, অ্যাপ্লিকেশনটি মাল্টি-উইন্ডো মোড সমর্থন করে কিনা তা নয়। resizeableActivity="false" হলে, ডিসপ্লে ডাইমেনশনের সাথে সামঞ্জস্য করার জন্য অ্যাপটিকে সামঞ্জস্যপূর্ণ মোডে রাখা হয়।
  • ছোট স্ক্রিনগুলি (এসডাব্লু <600 ডিপি): যদি resizeableActivity="true" এবং মূল ক্রিয়াকলাপের সর্বনিম্ন প্রস্থ এবং সর্বনিম্ন উচ্চতা মাল্টি-উইন্ডো প্রয়োজনীয়তার মধ্যে থাকে তবে অ্যাপ্লিকেশনটি মাল্টি-উইন্ডো মোডকে সমর্থন করে। যদি resizeableActivity="false" তবে অ্যাপ্লিকেশনটি ন্যূনতম প্রস্থ এবং উচ্চতা নির্বিশেষে মাল্টি-উইন্ডো মোডকে সমর্থন করে না।

দ্রষ্টব্য: ডিভাইস নির্মাতারা এপিআই স্তর 31 আচরণকে ওভাররাইড করতে পারে।

এই বৈশিষ্ট্যটি এপিআই স্তর 24 এ যুক্ত করা হয়েছিল।

দ্রষ্টব্য: কোনও টাস্কের মূল ক্রিয়াকলাপের মানটি টাস্কে চালু হওয়া সমস্ত অতিরিক্ত ক্রিয়াকলাপে প্রয়োগ করা হয়। এটি হ'ল, যদি কোনও টাস্কের মূল ক্রিয়াকলাপটি পুনরুদ্ধারযোগ্য হয়, তবে সিস্টেমটি কার্যের অন্যান্য সমস্ত ক্রিয়াকলাপকে পুনরায় আকারযোগ্য হিসাবে বিবেচনা করে। যদি মূলের ক্রিয়াকলাপটি পুনরায় আকার পরিবর্তন না করা হয় তবে টাস্কের অন্যান্য ক্রিয়াকলাপগুলি পুনরায় চিত্রগ্রহণযোগ্য নয়।

android:restrictedAccountType
এই অ্যাপ্লিকেশনটির দ্বারা প্রয়োজনীয় অ্যাকাউন্টের ধরণটি নির্দিষ্ট করে এবং নির্দেশ করে যে সীমাবদ্ধ প্রোফাইলগুলি মালিক ব্যবহারকারীর অন্তর্ভুক্ত এই জাতীয় অ্যাকাউন্টগুলিতে অ্যাক্সেস করতে পারে। যদি আপনার অ্যাপ্লিকেশনটির জন্য কোনও Account প্রয়োজন হয় এবং সীমাবদ্ধ প্রোফাইলগুলি প্রাথমিক ব্যবহারকারীর অ্যাকাউন্টগুলিতে অ্যাক্সেস করতে পারে , তবে এই বৈশিষ্ট্যের মানটি অবশ্যই আপনার অ্যাপ্লিকেশন দ্বারা ব্যবহৃত অ্যাকাউন্ট প্রমাণীকরণকারী ধরণের সাথে সামঞ্জস্য করতে হবে, যেমন "com.google" এর মতো AuthenticatorDescription দ্বারা সংজ্ঞায়িত।

ডিফল্ট মানটি নাল এবং ইঙ্গিত দেয় যে অ্যাপ্লিকেশনটি কোনও অ্যাকাউন্ট ছাড়াই কাজ করতে পারে।

সতর্কতা: এই বৈশিষ্ট্যটি নির্দিষ্ট করে সীমাবদ্ধ প্রোফাইলগুলি আপনার অ্যাপ্লিকেশনটিকে মালিক ব্যবহারকারীর অন্তর্ভুক্ত অ্যাকাউন্টগুলির সাথে ব্যবহার করতে দেয় যা ব্যক্তিগতভাবে সনাক্তযোগ্য তথ্য প্রকাশ করতে পারে। যদি অ্যাকাউন্টটি ব্যক্তিগত বিবরণ প্রকাশ করতে পারে তবে এই বৈশিষ্ট্যটি ব্যবহার করবেন না । পরিবর্তে, আপনার অ্যাপ্লিকেশনটিকে সীমাবদ্ধ প্রোফাইলগুলিতে অনুপলব্ধ করতে android:requiredAccountType বৈশিষ্ট্যটি ঘোষণা করুন।

এই বৈশিষ্ট্যটি এপিআই স্তর 18 এ যুক্ত করা হয়েছিল।

android:supportsRtl

আপনার অ্যাপ্লিকেশনটি ডান-টু-বাম (আরটিএল) লেআউটগুলিকে সমর্থন করতে ইচ্ছুক কিনা তা ঘোষণা করে।

যদি এটি "true" এ সেট করা থাকে এবং targetSdkVersion 17 বা ততোধিক সেট করা থাকে তবে বিভিন্ন আরটিএল এপিআইগুলি সিস্টেম দ্বারা সক্রিয় এবং ব্যবহার করা হয় যাতে আপনার অ্যাপ্লিকেশনটি আরটিএল লেআউটগুলি প্রদর্শন করতে পারে। যদি এটি "false" এ সেট করা থাকে বা যদি targetSdkVersion 16 বা তার চেয়ে কম সেট করা থাকে তবে আরটিএল এপিআইগুলি উপেক্ষা করা হয় বা কোনও প্রভাব নেই এবং আপনার অ্যাপ্লিকেশনটি ব্যবহারকারীর স্থানীয় পছন্দের সাথে সম্পর্কিত লেআউট দিকটি নির্বিশেষে একই আচরণ করে। এটি হ'ল, আপনার লেআউটগুলি সর্বদা বাম থেকে ডানদিকে থাকে।

এই বৈশিষ্ট্যের ডিফল্ট মান "false"

এই বৈশিষ্ট্যটি এপিআই স্তর 17 এ যুক্ত করা হয়েছিল।

android:taskAffinity
একটি স্নেহের নাম যা অ্যাপ্লিকেশনটির মধ্যে থাকা সমস্ত ক্রিয়াকলাপের ক্ষেত্রে প্রযোজ্য, তাদের নিজস্ব taskAffinity বৈশিষ্ট্যগুলির সাথে আলাদা সখ্যতা নির্ধারণ করে। আরও তথ্যের জন্য সেই বৈশিষ্ট্যটি দেখুন।

ডিফল্টরূপে, একটি অ্যাপ্লিকেশন মধ্যে সমস্ত ক্রিয়াকলাপ একই সখ্যতা ভাগ করে। সেই স্নেহের নাম <manifest> উপাদান দ্বারা সেট করা প্যাকেজ নামের সমান।

android:testOnly
এই অ্যাপ্লিকেশনটি কেবল পরীক্ষার উদ্দেশ্যে কিনা তা নির্দেশ করে। উদাহরণস্বরূপ, এটি নিজের বাইরে কার্যকারিতা বা ডেটা প্রকাশ করতে পারে যা সুরক্ষা গর্তের কারণ হতে পারে তবে পরীক্ষার জন্য দরকারী হতে পারে। এই ধরণের এপিকে কেবল adb মাধ্যমে ইনস্টল করে। আপনি এটি গুগল প্লেতে প্রকাশ করতে পারবেন না।

অ্যান্ড্রয়েড স্টুডিও আপনি যখন রান ক্লিক করেন তখন স্বয়ংক্রিয়ভাবে এই বৈশিষ্ট্যটি যুক্ত করে .

android:theme
অ্যাপ্লিকেশনটিতে সমস্ত ক্রিয়াকলাপের জন্য একটি ডিফল্ট থিম সংজ্ঞায়িত একটি স্টাইল রিসোর্সের একটি রেফারেন্স। স্বতন্ত্র ক্রিয়াকলাপগুলি তাদের নিজস্ব theme বৈশিষ্ট্যগুলি সেট করে ডিফল্টকে ওভাররাইড করতে পারে। আরও তথ্যের জন্য, স্টাইল এবং থিমগুলি দেখুন।
android:uiOptions
কোনও ক্রিয়াকলাপের ইউআই এর জন্য অতিরিক্ত বিকল্প। নিম্নলিখিত মানগুলির মধ্যে একটি হতে হবে:
মান বর্ণনা
"none" কোনও অতিরিক্ত ইউআই বিকল্প নেই। এটি ডিফল্ট।
"splitActionBarWhenNarrow" অ্যাপ্লিকেশন বারে অ্যাকশন আইটেমগুলি প্রদর্শন করতে স্ক্রিনের নীচে একটি বার যুক্ত করে, যখন অ্যাকশন বার হিসাবে পরিচিত, যখন অনুভূমিক স্থানের জন্য সীমাবদ্ধ থাকে, যেমন হ্যান্ডসেটের প্রতিকৃতি মোডে থাকে। স্ক্রিনের শীর্ষে অ্যাপ বারে উপস্থিত অল্প সংখ্যক অ্যাকশন আইটেমের পরিবর্তে অ্যাপ বারটি শীর্ষ নেভিগেশন বিভাগে এবং অ্যাকশন আইটেমগুলির জন্য নীচের বারে বিভক্ত হয়। এর অর্থ অ্যাকশন আইটেমগুলির জন্য এবং শীর্ষে নেভিগেশন এবং শিরোনাম উপাদানগুলির জন্য একটি যুক্তিসঙ্গত পরিমাণ স্থান উপলব্ধ। মেনু আইটেম দুটি বারের মধ্যে বিভক্ত হয় না। তারা সবসময় একসাথে উপস্থিত হয়।

অ্যাপ বার সম্পর্কে আরও তথ্যের জন্য, অ্যাপ বারটি যুক্ত করুন।

এই বৈশিষ্ট্যটি এপিআই স্তর 14 এ যুক্ত করা হয়েছিল।

android:usesCleartextTraffic
অ্যাপ্লিকেশনটি ক্লিয়ারটেক্সট নেটওয়ার্ক ট্র্যাফিক যেমন ক্লিয়ারটেক্সট এইচটিটিপি ব্যবহার করতে চায় তা নির্দেশ করে। অ্যাপ্লিকেশনগুলির জন্য ডিফল্ট মান যা এপিআই স্তর 27 বা তার চেয়ে কম লক্ষ্য করে "true" । অ্যাপ্লিকেশনগুলি যা এপিআই স্তর 28 বা উচ্চতর ডিফল্টকে "false" তে লক্ষ্য করে।

যখন বৈশিষ্ট্যটি "false" , প্ল্যাটফর্মের উপাদানগুলিতে সেট করা থাকে, উদাহরণস্বরূপ, এইচটিটিপি এবং এফটিপি স্ট্যাকস, DownloadManager এবং MediaPlayer , ক্লিয়ারটেক্সট ট্র্যাফিক ব্যবহারের জন্য অ্যাপ্লিকেশনটির অনুরোধগুলি প্রত্যাখ্যান করে।

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

এই পতাকাটি সর্বোত্তম প্রভাবের ভিত্তিতে সম্মানিত হয়েছে কারণ অ্যান্ড্রয়েড অ্যাপ্লিকেশনগুলি থেকে সমস্ত ক্লিয়ারটেক্সট ট্র্যাফিক তাদের সরবরাহিত অ্যাক্সেসের স্তরটি প্রদত্ত প্রতিরোধ করা অসম্ভব। উদাহরণস্বরূপ, Socket এপিআই এই পতাকাটিকে সম্মান করে এমন কোনও প্রত্যাশা নেই, কারণ এটি তার ট্র্যাফিক ক্লিয়ারটেক্সটে রয়েছে কিনা তা নির্ধারণ করতে পারে না।

যাইহোক, অ্যাপ্লিকেশনগুলি থেকে বেশিরভাগ নেটওয়ার্ক ট্র্যাফিক উচ্চ-স্তরের নেটওয়ার্ক স্ট্যাক এবং উপাদানগুলি দ্বারা পরিচালিত হয়, যা এই পতাকাটিকে ApplicationInfo.flags বা NetworkSecurityPolicy.isCleartextTrafficPermitted() থেকে এটি পড়ার মাধ্যমে সম্মান করতে পারে।

দ্রষ্টব্য: WebView এপিআই স্তর 26 এবং উচ্চতর লক্ষ্য করে অ্যাপ্লিকেশনগুলির জন্য এই বৈশিষ্ট্যটিকে সম্মান করে।

অ্যাপ্লিকেশন বিকাশের সময়, স্ট্রিটমোড অ্যাপ্লিকেশন থেকে কোনও ক্লিয়ারটেক্সট ট্র্যাফিক সনাক্ত করতে ব্যবহার করা যেতে পারে। আরও তথ্যের জন্য, StrictMode.VmPolicy.Builder.detectCleartextNetwork() দেখুন।

এই বৈশিষ্ট্যটি এপিআই স্তর 23 এ যুক্ত করা হয়েছিল।

অ্যান্ড্রয়েড নেটওয়ার্ক সুরক্ষা কনফিগারেশন উপস্থিত থাকলে এই পতাকাটি অ্যান্ড্রয়েড 7.0 (এপিআই স্তর 24) এ উপেক্ষা করা হবে (এপিআই স্তর 24)।

android:vmSafeMode
অ্যাপ্লিকেশনটি ভার্চুয়াল মেশিন (ভিএম) নিরাপদ মোডে পরিচালনা করতে চায় কিনা তা নির্দেশ করে। ডিফল্ট মান হল "false"

এই বৈশিষ্ট্যটি এপিআই স্তর 8 এ যুক্ত করা হয়েছিল, যেখানে "true" এর মান ডালভিক সবে-সময় (জেআইটি) সংকলককে অক্ষম করে।

এই বৈশিষ্ট্যটি এপিআই স্তর 22 এ অভিযোজিত হয়েছিল, যেখানে "true" এর একটি মান শিল্পকে এগিয়ে-সময়ের (এওটি) সংকলককে অক্ষম করে।

পরিচয়:
API স্তর 1
এছাড়াও দেখুন:
<activity>
<service>
<receiver>
<provider>