- সিনট্যাক্স:
<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
- এই বৈশিষ্ট্যটি নির্দেশ করে যে প্যাকেজ ইনস্টলার 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 এ যোগ করা হয়েছে।
দ্রষ্টব্য: একটি টাস্কের রুট অ্যাক্টিভিটি মান টাস্কে চালু করা সমস্ত অতিরিক্ত অ্যাক্টিভিটিগুলিতে প্রয়োগ করা হয়। অর্থাৎ, যদি কোনো টাস্কের রুট অ্যাক্টিভিটি রিসাইজ করা যায়, তাহলে সিস্টেম টাস্কের অন্য সব অ্যাক্টিভিটিকে রিসাইজযোগ্য হিসেবে বিবেচনা করে। রুট অ্যাক্টিভিটি রিসাইজ করা না গেলে, টাস্কের অন্যান্য অ্যাক্টিভিটি রিসাইজ করা যায় না।
- বড় স্ক্রীন (sw >= 600dp): সমস্ত অ্যাপ মাল্টি-উইন্ডো মোড সমর্থন করে। অ্যাট্রিবিউটটি নির্দেশ করে যে একটি অ্যাপের আকার পরিবর্তন করা যাবে কিনা, অ্যাপটি মাল্টি-উইন্ডো মোড সমর্থন করে কিনা তা নয়।
-
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) কম্পাইলারকে নিষ্ক্রিয় করে।
AGP 4.2.0 দিয়ে শুরু করে, DSL অপশন
useLegacyPackaging
এক্সট্রাক্টextractNativeLibs
ম্যানিফেস্ট অ্যাট্রিবিউটকে প্রতিস্থাপন করে। নেটিভ লাইব্রেরি কম্প্রেশন আচরণ কনফিগার করতে ম্যানিফেস্ট ফাইলেextractNativeLibs
এর পরিবর্তে আপনার অ্যাপেরbuild.gradle
ফাইলেuseLegacyPackaging
ব্যবহার করুন। আরও তথ্যের জন্য, রিলিজ নোট দেখুন সংকুচিত নেটিভ লাইব্রেরি প্যাকেজ করতে DSL ব্যবহার করুন ।-
- প্রবর্তিত:
- 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
- এই বৈশিষ্ট্যটি নির্দেশ করে যে প্যাকেজ ইনস্টলার 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 এ যুক্ত করা হয়েছিল।
দ্রষ্টব্য: কোনও টাস্কের মূল ক্রিয়াকলাপের মানটি টাস্কে চালু হওয়া সমস্ত অতিরিক্ত ক্রিয়াকলাপে প্রয়োগ করা হয়। এটি হ'ল, যদি কোনও টাস্কের মূল ক্রিয়াকলাপটি পুনরুদ্ধারযোগ্য হয়, তবে সিস্টেমটি কার্যের অন্যান্য সমস্ত ক্রিয়াকলাপকে পুনরায় আকারযোগ্য হিসাবে বিবেচনা করে। যদি মূলের ক্রিয়াকলাপটি পুনরায় আকার পরিবর্তন না করা হয় তবে টাস্কের অন্যান্য ক্রিয়াকলাপগুলি পুনরায় চিত্রগ্রহণযোগ্য নয়।
- বড় পর্দা (এসডাব্লু> = 600 ডিপি): সমস্ত অ্যাপ্লিকেশন মাল্টি-উইন্ডো মোডকে সমর্থন করে। বৈশিষ্ট্যটি নির্দেশ করে যে কোনও অ্যাপ্লিকেশনকে পুনরায় আকার দেওয়া যেতে পারে কিনা, অ্যাপ্লিকেশনটি মাল্টি-উইন্ডো মোড সমর্থন করে কিনা তা নয়।
-
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"
এর একটি মান শিল্পকে এগিয়ে-সময়ের (এওটি) সংকলককে অক্ষম করে।
AGP 4.2.0 দিয়ে শুরু করে, DSL অপশন
useLegacyPackaging
এক্সট্রাক্টextractNativeLibs
ম্যানিফেস্ট অ্যাট্রিবিউটকে প্রতিস্থাপন করে। নেটিভ লাইব্রেরি কম্প্রেশন আচরণ কনফিগার করতে ম্যানিফেস্ট ফাইলেextractNativeLibs
এর পরিবর্তে আপনার অ্যাপেরbuild.gradle
ফাইলেuseLegacyPackaging
ব্যবহার করুন। আরও তথ্যের জন্য, রিলিজ নোট দেখুন সংকুচিত নেটিভ লাইব্রেরি প্যাকেজ করতে DSL ব্যবহার করুন ।-
- পরিচয়:
- API স্তর 1
- এছাড়াও দেখুন:
-
<activity>
<service>
<receiver>
<provider>