<กิจกรรม>

ไวยากรณ์:
<activity android:allowEmbedded=["true" | "false"]
          android:allowTaskReparenting=["true" | "false"]
          android:alwaysRetainTaskState=["true" | "false"]
          android:autoRemoveFromRecents=["true" | "false"]
          android:banner="drawable resource"
          android:canDisplayOnRemoteDevices=["true" | "false"]
          android:clearTaskOnLaunch=["true" | "false"]
          android:colorMode=[ "hdr" | "wideColorGamut"]
          android:configChanges=["colorMode", "density",
                                 "fontScale", "fontWeightAdjustment",
                                 "grammaticalGender", "keyboard",
                                 "keyboardHidden", "layoutDirection", "locale",
                                 "mcc", "mnc", "navigation", "orientation",
                                 "screenLayout", "screenSize",
                                 "smallestScreenSize", "touchscreen", "uiMode"]
          android:directBootAware=["true" | "false"]
          android:documentLaunchMode=["intoExisting" | "always" |
                                  "none" | "never"]
          android:enabled=["true" | "false"]
          android:enabledOnBackInvokedCallback=["true" | "false"]
          android:excludeFromRecents=["true" | "false"]
          android:exported=["true" | "false"]
          android:finishOnTaskLaunch=["true" | "false"]
          android:hardwareAccelerated=["true" | "false"]
          android:icon="drawable resource"
          android:immersive=["true" | "false"]
          android:label="string resource"
          android:launchMode=["standard" | "singleTop" |
                              "singleTask" | "singleInstance" | "singleInstancePerTask"]
          android:lockTaskMode=["normal" | "never" |
                              "if_whitelisted" | "always"]
          android:maxRecents="integer"
          android:maxAspectRatio="float"
          android:multiprocess=["true" | "false"]
          android:name="string"
          android:noHistory=["true" | "false"]  
          android:parentActivityName="string" 
          android:persistableMode=["persistRootOnly" | 
                                   "persistAcrossReboots" | "persistNever"]
          android:permission="string"
          android:process="string"
          android:relinquishTaskIdentity=["true" | "false"]
          android:requireContentUriPermissionFromCaller=["none" | "read" | "readAndWrite" |
                                                         "readOrWrite" | "write"] 
          android:resizeableActivity=["true" | "false"]
          android:screenOrientation=["unspecified" | "behind" |
                                     "landscape" | "portrait" |
                                     "reverseLandscape" | "reversePortrait" |
                                     "sensorLandscape" | "sensorPortrait" |
                                     "userLandscape" | "userPortrait" |
                                     "sensor" | "fullSensor" | "nosensor" |
                                     "user" | "fullUser" | "locked"]
          android:showForAllUsers=["true" | "false"]
          android:stateNotNeeded=["true" | "false"]
          android:supportsPictureInPicture=["true" | "false"]
          android:taskAffinity="string"
          android:theme="resource or theme"
          android:uiOptions=["none" | "splitActionBarWhenNarrow"]
          android:windowSoftInputMode=["stateUnspecified",
                                       "stateUnchanged", "stateHidden",
                                       "stateAlwaysHidden", "stateVisible",
                                       "stateAlwaysVisible", "adjustUnspecified",
                                       "adjustResize", "adjustPan"] >   
    ...
</activity>
ที่อยู่ใน:
<application>
สามารถมีข้อมูลต่อไปนี้
<intent-filter>
<meta-data>
<layout>
description:
ประกาศกิจกรรม (คลาสย่อย Activity) ที่ มีการใช้งานส่วนหนึ่งของอินเทอร์เฟซผู้ใช้แบบภาพของแอปพลิเคชัน กิจกรรมทั้งหมด ต้องแสดงด้วย <activity> องค์ประกอบในไฟล์ Manifest รายการใดๆ ที่ไม่ได้ประกาศไว้ว่าไม่มี ด้วยระบบและไม่เคยเรียกใช้
ดังนี้
android:allowEmbedded

ระบุว่าสามารถเรียกใช้กิจกรรมเป็นกิจกรรมย่อยที่ฝังของอีกกิจกรรมหนึ่งได้ โดยเฉพาะในกรณีที่เด็กอาศัยอยู่ในตู้คอนเทนเนอร์ เช่น Display ที่เป็นของกิจกรรมอื่น เช่น กิจกรรม ที่ใช้สำหรับการแจ้งเตือนที่กำหนดเองของ Wear ให้ประกาศสิ่งนี้ Wear สามารถแสดงกิจกรรมในสตรีมบริบท ซึ่งอยู่ ในกระบวนการอื่น

ค่าเริ่มต้นของแอตทริบิวต์นี้คือ false

android:allowTaskReparenting
กิจกรรมสามารถย้ายจากงานที่เริ่มไปแล้วได้หรือไม่ งานซึ่งกลุ่มเป้าหมายสนใจเมื่องานนั้นได้รับเลือกให้ ด้านหน้า หากย้ายได้จะเป็น "true" และ "false" หากย้ายได้ ยังคงอยู่กับงานที่เริ่มต้นไว้

หากไม่ได้ตั้งค่าแอตทริบิวต์นี้ ระบบจะใช้ค่า allowTaskReparenting แอตทริบิวต์ขององค์ประกอบ <application> กับกิจกรรมดังกล่าว ค่าเริ่มต้นคือ "false"

โดยปกติแล้ว เมื่อกิจกรรมเริ่มต้นขึ้น กิจกรรมจะเชื่อมโยงกับงาน กิจกรรมที่เริ่มต้นและจะอยู่ ตลอดอายุการใช้งาน คุณใช้แอตทริบิวต์นี้เพื่อบังคับให้มีการกำหนดระดับบนสุดใหม่กับงานที่ต้องใช้ได้ มีผู้สนใจเมื่อไม่มีการแสดงงานปัจจุบันอีกต่อไป โดยปกติแล้ว โค้ดนี้ใช้เพื่อทําให้กิจกรรมของแอปพลิเคชันย้าย ไปยังงานหลักที่เชื่อมโยงกับแอปพลิเคชันนั้น

ตัวอย่างเช่น หากข้อความอีเมลมีลิงก์ไปยังหน้าเว็บ การคลิก ลิงก์จะแสดงกิจกรรมที่สามารถแสดงหน้าเว็บได้ กิจกรรมดังกล่าว กำหนดโดยแอปพลิเคชันเบราว์เซอร์ แต่เปิดใช้งานโดยเป็นส่วนหนึ่งของอีเมล งาน หากเปลี่ยนเป็นงานของเบราว์เซอร์ ก็จะแสดงเมื่อ เบราว์เซอร์ถัดไปจะอยู่ด้านหน้าและหายไปเมื่องานอีเมล อีกในอนาคต

กลุ่มความสนใจของกิจกรรมจะกำหนดโดย taskAffinity กลุ่มความสนใจ ของงานหนึ่งๆ จะกำหนดโดยการอ่านแอฟฟินิตี้ของกิจกรรมราก ดังนั้นตามคำจำกัดความแล้ว กิจกรรมรูทจะอยู่ในงานที่มี กลุ่มความสนใจเดียวกัน เนื่องจากกิจกรรมที่มี "singleTask" หรือ โหมดเปิดใช้งาน "singleInstance" โหมดจะอยู่ที่รูทของงานเท่านั้น การเลี้ยงดูบุตรใหม่จำกัดเฉพาะ"standard" และ"singleTop" โหมดต่างๆ (โปรดดู launchMode เพิ่มเติม )

android:alwaysRetainTaskState
สถานะของงานที่มีกิจกรรมนั้นอยู่เสมอหรือไม่ ดูแลรักษาโดยระบบ "true" หากใช่ และ "false" หากระบบรีเซ็ตงานเป็นค่าเริ่มต้นได้ ในบางสถานการณ์ ค่าเริ่มต้นคือ "false" ช่วงเวลานี้ จะมีความหมายเฉพาะกิจกรรมรูทของงานเท่านั้น ระบบไม่สนใจ สำหรับกิจกรรมอื่นๆ ทั้งหมด

โดยปกติแล้ว ระบบจะล้างงานและนำกิจกรรมทั้งหมดออกจากสแต็ก เหนือกิจกรรมราก ในบางกรณี เมื่อผู้ใช้เลือกอีกครั้ง งานจากหน้าจอหลัก โดยปกติจะทำแบบนี้หากผู้ใช้ไม่ได้เข้าชม งานเป็นระยะเวลาหนึ่ง เช่น 30 นาที

แต่เมื่อแอตทริบิวต์นี้คือ "true" ผู้ใช้จะกลับมาเสมอ เข้ากับงานในสถานะสุดท้ายไม่ว่าจะไปถึงขั้นตอนนั้นได้อย่างไร นี่คือ มีประโยชน์ในแอปพลิเคชัน เช่น เว็บเบราว์เซอร์ ที่ สถานะต่างๆ มากมาย เช่น แท็บที่เปิดอยู่หลายแท็บ ที่ผู้ใช้ไม่อยากเสียไป

android:autoRemoveFromRecents
งานที่เปิดโดยกิจกรรมที่มีแอตทริบิวต์นี้จะยังคงอยู่ใน หน้าจอล่าสุดจนถึงกิจกรรมล่าสุดใน งานเสร็จสมบูรณ์ หาก true งานคือ โดยอัตโนมัติจากหน้าจอ "ล่าสุด" ตัวเลือกนี้จะลบล้างการใช้ FLAG_ACTIVITY_RETAIN_IN_RECENTS ค่านี้ต้องเป็นค่าบูลีน "true" หรือ "false"
android:banner
แหล่งข้อมูลที่ถอนได้ แสดงแบนเนอร์กราฟิกแบบขยายสำหรับรายการที่เกี่ยวข้อง ใช้กับ <activity> เพื่อระบุแบนเนอร์เริ่มต้นสำหรับกิจกรรมหนึ่งๆ หรือด้วยแท็ก <application> เพื่อระบุแบนเนอร์ของกิจกรรมของแอปพลิเคชันทั้งหมด

ระบบจะใช้แบนเนอร์เพื่อแสดงถึงแอปใน หน้าจอหลักของ Android TV และเนื่องจากแบนเนอร์จะแสดงเฉพาะในหน้าจอหลัก จะระบุโดยแอปพลิเคชันที่มีกิจกรรมที่จัดการ Intent CATEGORY_LEANBACK_LAUNCHER

แอตทริบิวต์นี้ตั้งเป็นการอ้างอิงทรัพยากรที่ถอนออกได้ซึ่งมี รูปภาพ เช่น "@drawable/banner" ไม่มีแบนเนอร์เริ่มต้น

สำหรับข้อมูลเพิ่มเติม โปรดดู สร้างแบนเนอร์หน้าจอหลักในการเริ่มต้นใช้งานแอปทีวี

android:canDisplayOnRemoteDevices

ระบุว่าจะแสดงกิจกรรมในอุปกรณ์ระยะไกลได้หรือไม่ อาจใช้ Android หรือไม่ก็ได้ ค่านี้ต้องเป็นค่าบูลีน "true" หรือ "false"

ค่าเริ่มต้นของแอตทริบิวต์นี้คือ "true"

android:clearTaskOnLaunch
นำกิจกรรมทั้งหมดออกจากงานหรือไม่ ยกเว้น กิจกรรมหลัก เมื่อมีการเรียกใช้งานอีกครั้งจากหน้าจอหลัก "true" หากมีการนำงานออกเป็นกิจกรรมระดับรูทเสมอ และ "false" หากไม่ ค่าเริ่มต้นคือ "false" แอตทริบิวต์นี้ มีความหมายเฉพาะในกิจกรรมที่เริ่มงานใหม่ ซึ่งก็คือกิจกรรมราก ระบบจะละเว้นกิจกรรมอื่นๆ ทั้งหมดในงาน

เมื่อค่าเป็น "true" ทุกครั้งที่ผู้ใช้เริ่มงาน ระบบจะดำเนินการ นำมาสู่กิจกรรมที่เป็นราก ไม่ว่าจะทำอะไรล่าสุด งานนั้นโดยไม่คำนึงว่าผู้ใช้จะใช้ปุ่ม "ย้อนกลับ" หรือ "หน้าแรก" เพื่อ ออกจากแชทนั้น เมื่อค่าเป็น "false" จะล้างงานกิจกรรมใน ในบางสถานการณ์ แต่ไม่เสมอไป สำหรับข้อมูลเพิ่มเติม โปรดดู alwaysRetainTaskState

สมมติว่าผู้ใช้เปิดกิจกรรม P จากหน้าจอหลัก จากนั้นไปที่กิจกรรม Q ถัดไปให้ผู้ใช้แตะ "หน้าแรก" แล้วกลับมา สำหรับกิจกรรม P ตามปกติแล้ว ผู้ใช้จะเห็นกิจกรรม Q เพราะนี่คือสิ่งที่พวกเขา ทำงานล่าสุดในงานของ P อย่างไรก็ตาม หาก P ตั้งค่าแฟล็กนี้เป็น "true" ข้อผิดพลาดทั้งหมด ของกิจกรรมนอกเหนือจากนั้น ซึ่งในกรณีนี้คือ Q จะถูกนำออกเมื่อผู้ใช้เปิดใช้งาน กิจกรรม P จากหน้าจอหลัก ดังนั้นผู้ใช้จะเห็นเฉพาะ P เมื่อกลับไปที่งาน

หากแอตทริบิวต์นี้และ allowTaskReparenting เป็น "true" ทั้งคู่ กิจกรรมใดๆ ที่แสดงผู้ปกครองอีกครั้งได้จะถูกย้ายไปที่ งานที่สนใจในเรื่องเดียวกัน จากนั้นจึงยกเลิกกิจกรรมที่เหลือ

ระบบจะละเว้นแอตทริบิวต์นี้หากไม่ได้ตั้งค่า FLAG_ACTIVITY_RESET_TASK_IF_NEEDED

android:colorMode

ระบุโหมดสีของกิจกรรม หากระบุแล้ว อาจเป็น hdr หรือ wideColorGamut

หากเป็น hdr ขอให้แสดงกิจกรรมในช่วงไดนามิกสูงหาก อุปกรณ์ของคุณรองรับ

หากเป็น wideColorGamut ขอให้แสดงกิจกรรมในโหมดขอบเขตสีแบบกว้าง บนอุปกรณ์ที่เข้ากันได้ ในโหมดขอบเขตสีกว้าง หน้าต่างสามารถแสดงผลนอก SRGB ขอบเขตสำหรับ แสดงสีสันสดใสมากขึ้น หากอุปกรณ์ไม่รองรับการแสดงผลแบบ Wide Color Gamut จะไม่มีผล สำหรับข้อมูลเพิ่มเติมเกี่ยวกับการแสดงผลในโหมดสีแบบกว้าง โปรดดู ปรับปรุงกราฟิกด้วยเนื้อหา Wide Color

android:configChanges
แสดงรายการการเปลี่ยนแปลงการกำหนดค่าที่กิจกรรมจัดการด้วยตัวเอง เมื่อการกำหนดค่า การเปลี่ยนแปลงจะเกิดขึ้นที่รันไทม์ กิจกรรมจะปิดลงและรีสตาร์ทโดยค่าเริ่มต้น แต่การประกาศ การกำหนดค่าด้วยแอตทริบิวต์นี้จะป้องกันไม่ให้กิจกรรมรีสตาร์ท แต่ กิจกรรมยังคงทำงานอยู่และจะเรียกเมธอด onConfigurationChanged()

หมายเหตุ: ใช้แอตทริบิวต์นี้ในกรณีพิเศษเท่านั้นเพื่อปรับปรุงแอปพลิเคชัน ประสิทธิภาพและการตอบสนอง โปรดดูข้อมูลเพิ่มเติมที่หัวข้อจัดการการเปลี่ยนแปลงการกำหนดค่า

สตริงต่อไปนี้เป็นค่าที่ถูกต้องสำหรับแอตทริบิวต์นี้ ค่าหลายค่าคือ คั่นด้วย | เช่น "locale|navigation|orientation"

ค่า คำอธิบาย
"colorMode"

ความสามารถในการโหมดสีของหน้าจอ (ช่วงสีหรือช่วงไดนามิก) มีการเปลี่ยนแปลง

หมายเหตุ: โหมดสีที่คำขอกิจกรรมด้วยแอตทริบิวต์ colorMode หรือขณะรันไทม์จะแตกต่างจากความสามารถของโหมดสีแบบต่างๆ กิจกรรมการเปลี่ยนโหมดสีที่ใช้อยู่ไม่ทำให้การกำหนดค่าเปลี่ยนแปลง เนื่องจากความสามารถในการแสดงสีของหน้าจอไม่เปลี่ยนแปลง

"density"

การเปลี่ยนแปลงความหนาแน่นของการแสดงผล เช่น เมื่อผู้ใช้ระบุ ขนาดการแสดงผลที่แตกต่างกันหรือจอแสดงผลอื่นทำงานอยู่

เพิ่มใน API ระดับ 24

"fontScale" การเปลี่ยนแปลงปัจจัยการปรับขนาดแบบอักษร เช่น เมื่อผู้ใช้เลือก ขนาดอักษรส่วนกลางใหม่
"fontWeightAdjustment" จำนวนการเพิ่มน้ำหนักแบบอักษรมีการเปลี่ยนแปลง
"grammaticalGender" เพศทางไวยากรณ์ในภาษามีการเปลี่ยนแปลง โปรดดู GrammaticalInflectionManager

เพิ่มใน API ระดับ 34

"keyboard" การเปลี่ยนแปลงประเภทแป้นพิมพ์ เช่น เมื่อผู้ใช้ เสียบกับแป้นพิมพ์ภายนอก
"keyboardHidden" การเปลี่ยนแปลงการเข้าถึงแป้นพิมพ์ เช่น เมื่อ แสดงแป้นพิมพ์ของฮาร์ดแวร์
"layoutDirection"

การเปลี่ยนแปลงทิศทางของเลย์เอาต์ เช่น จาก จากซ้ายไปขวา (LTR) ไปขวาไปซ้าย (RTL)

เพิ่มใน API ระดับ 17

"locale" การเปลี่ยนแปลงของภาษา เช่น เมื่อผู้ใช้เลือกภาษาใหม่ ภาษาที่ข้อความแสดง
"mcc" การเปลี่ยนแปลงรหัสประเทศสำหรับมือถือ IMSI (MCC) เมื่อ ตรวจพบว่า SIM มีการอัปเดต MCC
"mnc" การเปลี่ยนแปลงรหัสเครือข่ายมือถือ IMSI (MNC) เมื่อ ตรวจพบซิมที่อัปเดต MNC
"navigation" TA จะเปลี่ยนเป็นประเภทการนำทาง (แทร็กบอลหรือ D-pad) โดยปกติแล้วปัญหานี้จะไม่เกิดขึ้น
"orientation"

การเปลี่ยนการวางแนวหน้าจอ เช่น เมื่อผู้ใช้หมุนอุปกรณ์

หมายเหตุ: หากแอปพลิเคชันกำหนดเป้าหมาย Android 3.2 (API ระดับ 13) ขึ้นไปยังประกาศ การกำหนดค่า "screenLayout" และ "screenSize" เนื่องจากการจัดวางหน้าจอ และขนาดหน้าจออาจเปลี่ยนไปเมื่อ อุปกรณ์จะสลับระหว่างแนวตั้งและแนวนอน

"screenLayout" การเปลี่ยนแปลงเลย์เอาต์หน้าจอ เช่น เมื่อมีการเปิดใช้งานจอแสดงผลอื่น
"screenSize"

การเปลี่ยนแปลงขนาดหน้าจอที่พร้อมใช้งานในปัจจุบัน

ค่านี้แสดงถึงการเปลี่ยนแปลงขนาดที่ใช้ได้ในปัจจุบัน เมื่อเทียบกับ สัดส่วนการแสดงผลปัจจุบัน ดังนั้นจึงเปลี่ยนเมื่อผู้ใช้สลับเปลี่ยนระหว่างแนวนอน และแนวตั้ง

เพิ่มใน API ระดับ 13

"smallestScreenSize"

การเปลี่ยนขนาดหน้าจอจริง

จะแสดงการเปลี่ยนแปลงขนาดโดยไม่คำนึงถึงการวางแนว ดังนั้น เปลี่ยนเมื่อขนาดหน้าจอจริงเปลี่ยนไป เช่น เปลี่ยนเป็น จอแสดงผลภายนอก การเปลี่ยนแปลงการกำหนดค่านี้สอดคล้องกับการเปลี่ยนแปลง ในช่วง smallestWidth การกำหนดค่า

เพิ่มใน API ระดับ 13

"touchscreen" เปลี่ยนเป็นหน้าจอสัมผัส โดยปกติแล้วปัญหานี้จะไม่เกิดขึ้น
"uiMode" การเปลี่ยนแปลงโหมดอินเทอร์เฟซผู้ใช้ เช่น เมื่อผู้ใช้วาง อุปกรณ์ไว้บนโต๊ะหรือแท่นชาร์จในรถ หรือโหมดกลางคืนจะเปลี่ยนไป สำหรับข้อมูลเพิ่มเติม ข้อมูลเกี่ยวกับโหมด UI ต่างๆ โปรดดู UiModeManager

เพิ่มใน API ระดับ 8

การเปลี่ยนแปลงการกำหนดค่าเหล่านี้ทั้งหมดอาจส่งผลต่อค่าทรัพยากรที่แสดงโดย แอปพลิเคชัน ดังนั้นเมื่อ onConfigurationChanged() ก็จะต้องเรียกตามปกติว่า ดึงข้อมูลทรัพยากรทั้งหมด รวมถึงดูเลย์เอาต์และเนื้อหาที่ถอนออกได้ เพื่อจัดการการเปลี่ยนแปลงอย่างถูกต้อง

หมายเหตุ: โปรดใช้ทั้ง "screenLayout" และ "smallestScreenSize" เพื่อจัดการการเปลี่ยนแปลงการกำหนดค่าที่เกี่ยวข้องกับหลายหน้าต่าง รองรับหลายหน้าต่างใน Android 7.0 (API ระดับ 24) ขึ้นไป

android:directBootAware

ระบุว่ากิจกรรมเป็นแบบรับรู้การเปิดเครื่องโดยตรงหรือไม่ กล่าวคือ ว่าจะทำงานก่อนที่ผู้ใช้จะปลดล็อกอุปกรณ์ได้หรือไม่

หมายเหตุ: ระหว่าง การเปิดเครื่องโดยตรง ซึ่งเป็นกิจกรรมใน แอปพลิเคชันของคุณจะสามารถเข้าถึงเฉพาะข้อมูลที่เก็บไว้ใน พื้นที่เก็บข้อมูลที่ปกป้องอุปกรณ์

ค่าเริ่มต้นคือ "false"

android:documentLaunchMode
ระบุวิธีการเพิ่มกิจกรรมใหม่ในงานทุกครั้งที่เริ่มต้น แอตทริบิวต์นี้อนุญาตให้ผู้ใช้มีเอกสารหลายรายการจากแอปพลิเคชันเดียวกัน ปรากฏในหน้าจอล่าสุด

แอตทริบิวต์นี้มี 4 ค่า ซึ่งจะมีผลต่อไปนี้เมื่อผู้ใช้เปิดเอกสาร ด้วยแอปพลิเคชัน:

ค่า คำอธิบาย
"intoExisting" ระบบจะค้นหางานที่มี ComponentName ของ Intent พื้นฐานและ URI ของข้อมูล ตรงกับจุดประสงค์ของการเปิดตัว หากระบบพบงานดังกล่าว ระบบจะล้างข้อมูล งานและเริ่มใหม่ โดยมีกิจกรรมรูทที่เรียก onNewIntent(android.content.Intent) หากระบบไม่พบงานดังกล่าว ระบบจะสร้างงานใหม่
"always" กิจกรรมนี้จะสร้างงานใหม่สำหรับเอกสารดังกล่าว แม้ว่าเอกสารจะเปิดอยู่แล้ว ซึ่งจะเหมือนกับการตั้งค่าทั้ง FLAG_ACTIVITY_NEW_DOCUMENT และ FLAG_ACTIVITY_MULTIPLE_TASK Flag
"none" กิจกรรมจะไม่สร้างงานใหม่สำหรับกิจกรรมดังกล่าว ค่านี้เป็นค่าเริ่มต้น สร้างงานใหม่เมื่อตั้งค่า FLAG_ACTIVITY_NEW_TASK ไว้เท่านั้น หน้าจอ "ล่าสุด" จะดำเนินการกับกิจกรรมตามปกติ โดยจะแสดงงานเดียวสำหรับ แอปซึ่งกลับมาทำงานอีกครั้งจากกิจกรรมใดก็ตามที่ผู้ใช้เรียกใช้ครั้งล่าสุด
"never" กิจกรรมไม่ได้เปิดตัวในเอกสารใหม่แม้ว่า Intent มี FLAG_ACTIVITY_NEW_DOCUMENT การตั้งค่านี้จะลบล้างลักษณะการทำงาน ของFLAG_ACTIVITY_NEW_DOCUMENTและ FLAG_ACTIVITY_MULTIPLE_TASK แฟล็ก หากตั้งค่าอย่างใดอย่างหนึ่งไว้ใน และหน้าจอ "ล่าสุด" จะแสดงงานเดียวสำหรับแอปนั้น ซึ่งกลับมาทำงานอีกครั้งจาก กิจกรรมใดก็ตามที่ผู้ใช้เรียกใช้ล่าสุด

หมายเหตุ: สำหรับค่าอื่นที่ไม่ใช่ "none" และ "never" ค่า กิจกรรมจะกำหนดด้วย launchMode="standard" หากไม่ได้ระบุแอตทริบิวต์นี้ไว้ ใช้งาน documentLaunchMode="none"

android:enabled
ระบบสร้างอินสแตนซ์กิจกรรมได้หรือไม่ ตอนนี้ "true" หากทำได้ และ "false" หากทำได้ ค่าเริ่มต้น มีค่า "true"

<application> องค์ประกอบมี enabled ของตัวเอง ที่ใช้กับคอมโพเนนต์ของแอปพลิเคชันทั้งหมด รวมถึงกิจกรรมด้วย <application> และแอตทริบิวต์ <activity> ต้องเป็น "true" เนื่องจากทั้งคู่ ตามค่าเริ่มต้น เพื่อให้ระบบสามารถสร้างอินสแตนซ์ของกิจกรรมได้ หากมี คือ "false" จะไม่สามารถสร้างอินสแตนซ์ได้

android:enableOnBackInvokedCallback
แฟล็กนี้ช่วยให้คุณเลือกใช้ภาพเคลื่อนไหวของระบบการคาดการณ์ในระดับกิจกรรมได้ ลักษณะการทำงานนี้ ทำให้ย้ายแอปกิจกรรมขนาดใหญ่แบบหลายกิจกรรมไปยังท่าทางสัมผัสการย้อนกลับแบบคาดเดาได้มากขึ้น

การตั้งค่า android:enableOnBackInvokedCallback=false จะปิดการย้อนกลับที่คาดการณ์ได้ ภาพเคลื่อนไหวที่ระดับกิจกรรมหรือที่ระดับแอป ทั้งนี้ขึ้นอยู่กับตำแหน่งที่คุณกำหนดแท็ก และบอกระบบให้ละเว้นการเรียกไปยัง API ของแพลตฟอร์ม OnBackInvokedCallback

android:excludeFromRecents

งานที่เริ่มต้นโดยกิจกรรมนี้ไม่รวมอยู่ใน หรือไม่ หน้าจอล่าสุด กล่าวคือ เมื่อกิจกรรมนี้เป็นกิจกรรมรากของ งาน แอตทริบิวต์นี้กำหนดว่างานจะปรากฏในรายการแอปล่าสุดหรือไม่ ตอนนี้ "true" หากงานยกเว้นจากรายการ "false" หากใช่ รวมแล้ว ค่าเริ่มต้นคือ "false"

android:exported

สามารถเรียกใช้กิจกรรมด้วยคอมโพเนนต์ของ แอปพลิเคชัน:

  • หากเป็น "true" ทุกแอปจะเข้าถึงกิจกรรมได้และเปิดได้ตามที่ต้องการ ชื่อชั้นเรียน
  • หากเป็น "false" กิจกรรมจะเปิดได้โดยคอมโพเนนต์ของ แอปพลิเคชันเดียวกัน แอปพลิเคชันที่มีรหัสผู้ใช้ หรือคอมโพเนนต์ของระบบที่ได้รับสิทธิ์เดียวกัน ค่านี้เป็นค่าเริ่มต้นเมื่อไม่มีตัวกรอง Intent

หากกิจกรรมในแอปมีตัวกรอง Intent ให้ตั้งค่าองค์ประกอบนี้เป็น "true"เพื่อให้แอปอื่นๆ เริ่มทำงานได้ ตัวอย่างเช่น หากกิจกรรมเป็นกิจกรรมหลัก ของแอปและมีcategory android.intent.category.LAUNCHER

หากตั้งค่าองค์ประกอบนี้เป็น "false" และแอปพยายามเริ่มกิจกรรม ระบบจะแสดงข้อผิดพลาด ActivityNotFoundException

แอตทริบิวต์นี้ไม่ใช่วิธีเดียวในการจำกัดการแสดงกิจกรรมต่อบุคคลอื่นๆ แอปพลิเคชัน สิทธิ์ยังใช้เพื่อจำกัดเอนทิตีภายนอกที่ สามารถเรียกใช้กิจกรรม โปรดดู permission

android:finishOnTaskLaunch
กิจกรรมที่มีอยู่จะปิดลงหรือไม่ ยกเว้นกิจกรรมรูท เมื่อผู้ใช้เปิดงานอีกครั้งโดยเลือกงานใน หน้าจอหลัก เวลา "true" หากปิดตัวลง และ"false" หากไม่ ค่าเริ่มต้นคือ "false"

หากแอตทริบิวต์นี้และ allowTaskReparenting เป็น "true" ทั้งคู่ โดยแอตทริบิวต์นี้มีความสำคัญมากกว่าแอตทริบิวต์อื่น กลุ่มความสนใจของ กิจกรรมจะถูกละเว้น กิจกรรมไม่ได้ถูกกำหนดขึ้นอีกครั้ง แต่ทำลายแล้ว

ระบบจะละเว้นแอตทริบิวต์นี้หากไม่ได้ตั้งค่า FLAG_ACTIVITY_RESET_TASK_IF_NEEDED

android:hardwareAccelerated
เปิดใช้การแสดงผลแบบเร่งฮาร์ดแวร์อยู่หรือไม่ กิจกรรม "true" หากเปิดใช้อยู่ และ "false" หากเปิดใช้ ไม่ได้ ค่าเริ่มต้นคือ "false"

ใน Android 3.0 ขึ้นไป ตัวแสดงผล OpenGL ที่ใช้ฮาร์ดแวร์เร่งการแสดงผล พร้อมใช้งานสำหรับแอปพลิเคชันเพื่อปรับปรุงประสิทธิภาพสำหรับกราฟิก 2 มิติทั่วไปจำนวนมาก การดำเนินงาน เมื่อเปิดใช้การแสดงภาพที่เร่งการแสดงผลด้วยฮาร์ดแวร์ การดำเนินการส่วนใหญ่ ใน Canvas, Paint, Xfermode, ColorFilter, Shader และกล้องถ่ายรูปจะได้รับการเร่ง

ทำให้ภาพเคลื่อนไหวลื่นไหลขึ้น การเลื่อนลื่นไหลขึ้น และปรับปรุงขึ้น การตอบสนองโดยรวม แม้แต่สำหรับแอปพลิเคชันที่ไม่ได้ใช้ ไลบรารี OpenGL ของเฟรมเวิร์ก เนื่องจากมีทรัพยากรมากขึ้นที่จำเป็นต้องใช้ เปิดใช้การเร่งฮาร์ดแวร์ แอปของคุณจะใช้ RAM มากขึ้น

ไม่ใช่การเร่งการดำเนินการ OpenGL 2D ทั้งหมด หากเปิดใช้ เพื่อเร่งการแสดงผลด้วยฮาร์ดแวร์ ให้ทดสอบว่าแอปพลิเคชันของคุณสามารถ ใช้ตัวแสดงผลโดยไม่มีข้อผิดพลาด

android:icon

ไอคอนที่แสดงถึงกิจกรรม ไอคอนจะแสดงต่อผู้ใช้เมื่อ ต้องแสดงกิจกรรมบนหน้าจอ เช่น ไอคอน สำหรับกิจกรรมที่เริ่มงานจะแสดงในหน้าต่าง Launcher ไอคอนมักมีป้ายกำกับติดมาด้วย สำหรับข้อมูลเกี่ยวกับป้ายกำกับ โปรดดูที่แอตทริบิวต์ android:label

แอตทริบิวต์นี้ตั้งเป็นการอ้างอิงทรัพยากรที่ถอนออกได้ซึ่งมี คำจำกัดความของรูปภาพ หากไม่ได้ตั้งค่าไว้ ไอคอนที่ระบุไว้สำหรับแอปพลิเคชัน จะใช้จำนวนเต็มแทน สำหรับข้อมูลเพิ่มเติม โปรดดู <application> แอตทริบิวต์ icon ขององค์ประกอบ

ไอคอนของกิจกรรม ไม่ว่าจะตั้งค่าไว้ที่นี่หรือตาม <application> เป็นไอคอนเริ่มต้นสำหรับตัวกรอง Intent ของกิจกรรมทั้งหมดด้วย สำหรับข้อมูลเพิ่มเติม โปรดดู ขององค์ประกอบ <intent-filter> icon

android:immersive
กำหนดการตั้งค่าโหมดใหญ่พิเศษสำหรับกิจกรรมปัจจุบัน หากเป็น "true" สมาชิก ActivityInfo.flags จะมีค่าเสมอ FLAG_IMMERSIVE บิต แม้ว่า โหมดใหญ่พิเศษจะเปลี่ยนโหมดขณะรันไทม์โดยใช้เมธอด setImmersive()
android:label

ป้ายกำกับที่ผู้ใช้อ่านได้สำหรับกิจกรรม ป้ายกำกับแสดงบนหน้าจอ เมื่อกิจกรรมแสดงต่อผู้ใช้ มักจะแสดงร่วมกับ ที่มีไอคอนกิจกรรม หากไม่ได้ตั้งค่าแอตทริบิวต์นี้ ป้ายกำกับที่ตั้งไว้สำหรับแอปพลิเคชันโดยรวมจะเป็น ใช้แทน ดูองค์ประกอบ <application> label

ป้ายกำกับของกิจกรรม ไม่ว่าจะตั้งค่าไว้ที่นี่หรือตามแท็ก <application> ยังเป็นองค์ประกอบ ป้ายกำกับเริ่มต้นสำหรับตัวกรอง Intent ของกิจกรรมทั้งหมด สำหรับข้อมูลเพิ่มเติม โปรดดู ขององค์ประกอบ <intent-filter> label

ป้ายกำกับได้รับการตั้งค่าเป็นการอ้างอิงไปยังทรัพยากรสตริงเพื่อให้ สามารถแปลได้เหมือนกับสตริงอื่นๆ ในอินเทอร์เฟซผู้ใช้ แต่เพื่อความสะดวก ในระหว่างที่คุณพัฒนาแอปพลิเคชัน ยังสามารถตั้งค่าเป็นสตริงดิบได้

android:launchMode

คำแนะนำการเปิดตัวกิจกรรม มีทั้งหมด 5 โหมด ซึ่งทำงานร่วมกับ Flag กิจกรรม (ค่าคงที่ FLAG_ACTIVITY_*) ใน Intent ออบเจ็กต์เพื่อกำหนดสิ่งที่เกิดขึ้นเมื่อ กิจกรรมจะถูกเรียกใช้เพื่อจัดการกับ Intent:

"standard"
"singleTop"
"singleTask"
"singleInstance"
"singleInstancePerTask"

โหมดเริ่มต้นคือ "standard"

ตามที่แสดงในตารางต่อไปนี้ โหมดต่างๆ จะแบ่งออกเป็น 2 กลุ่มหลัก ได้แก่ "standard" และ "singleTop" กิจกรรมทางฝั่งเดียว และ "singleTask", "singleInstance" และ "singleInstancePerTask" กิจกรรมในอีกหลายๆ กิจกรรม กิจกรรมที่มี โหมดเปิดใช้งาน "standard" หรือ "singleTop" สามารถสร้างอินสแตนซ์ได้หลายครั้ง

อินสแตนซ์อาจเป็นของงานใดก็ได้ และอาจอยู่ที่ใดก็ได้ในงานกิจกรรม โดยทั่วไปแล้ว เปิดตัวไปเป็นงานที่มีชื่อว่า startActivity() เว้นแต่ออบเจ็กต์ Intent จะมีแอตทริบิวต์ FLAG_ACTIVITY_NEW_TASK ซึ่งในกรณีนี้จะมีการเลือกงานอื่น สำหรับข้อมูลเพิ่มเติม โปรดดู taskAffinity

ในทางตรงกันข้าม "singleTask", "singleInstance" และ กิจกรรม "singleInstancePerTask" มีลักษณะการทำงานที่ต่างกัน "singleInstancePerTask" จะอยู่ที่รูทของงานกิจกรรมเสมอ นอกจากนี้ อุปกรณ์สามารถเก็บอินสแตนซ์ของ กิจกรรมครั้งละ "singleInstance" รายการ ขณะที่ สร้างกิจกรรม "singleInstancePerTask ได้หลายครั้ง ในงานที่แตกต่างกันเมื่อ FLAG_ACTIVITY_MULTIPLE_TASK หรือ FLAG_ACTIVITY_NEW_DOCUMENT ได้รับการตั้งค่าแล้ว

กิจกรรมที่มีโหมดเปิดใช้งาน "singleTask" จะรวม พฤติกรรมของ "singleInstance" และ "singleInstancePerTask": สร้างอินสแตนซ์กิจกรรมได้หลายรายการ และระบุตำแหน่งที่ใดก็ได้ในงานของ taskAffinity เดียวกัน แต่อุปกรณ์จะเก็บงานไว้ได้เพียง 1 งานเท่านั้นในการค้นหา กิจกรรม "singleTask" ที่รูทของงานกิจกรรม

โหมด "standard" และ "singleTop" แตกต่างกัน ในแง่หนึ่ง ทุกครั้งที่มีการแสดงความตั้งใจใหม่สำหรับ "standard" กิจกรรม อินสแตนซ์ใหม่ของชั้นเรียนจะถูกสร้างขึ้นเพื่อตอบสนองต่อความตั้งใจนั้น แต่ละอินสแตนซ์จะรองรับ Intent เดียว ในทํานองเดียวกัน อินสแตนซ์ใหม่ของกิจกรรม "singleTop" อาจ ที่สร้างขึ้นเพื่อจัดการกับ Intent ใหม่

แต่หากงานเป้าหมายมี กิจกรรมที่มีอยู่ที่ด้านบนสุดของสแต็ก อินสแตนซ์นั้น จะได้รับ Intent ใหม่ใน onNewIntent() สาย ระบบจะไม่สร้างอินสแตนซ์ใหม่ มิฉะนั้น หากเป็นอินสแตนซ์ที่มีอยู่ของ กิจกรรม "singleTop" อยู่ในงานเป้าหมาย แต่ไม่ใช่ที่ด้านบนสุดของ หรือหากสแต็กอยู่ที่ด้านบนของสแต็ก แต่ไม่อยู่ในงานเป้าหมาย อินสแตนซ์ใหม่จะ และพุชไปยังกองซ้อน

ในทำนองเดียวกัน หากผู้ใช้ นำทาง สูงสุดของกิจกรรมในสแต็กปัจจุบัน ลักษณะการทำงานจะพิจารณาตาม โหมดการเรียกใช้งานกิจกรรมของผู้ปกครอง หากกิจกรรมระดับบนสุดมีโหมดเปิดใช้งาน singleTop (หรือ Intent up มี FLAG_ACTIVITY_CLEAR_TOP) ระบบจะนำผู้ปกครองไปที่ ที่ด้านบนของสแต็ก และสถานะของสแต็กจะยังคงอยู่เหมือนเดิม

ได้รับความตั้งใจในการนำทางแล้ว โดยonNewIntent()ของกิจกรรมของผู้ปกครอง หากกิจกรรมของผู้ปกครองมีโหมดเปิดใช้งาน standard และ up Intent ไม่มี FLAG_ACTIVITY_CLEAR_TOP กิจกรรมปัจจุบัน และ ระดับบนสุดทั้งแยกออกจากกองและอินสแตนซ์ใหม่ของกิจกรรมระดับบนสุดเพื่อรับ Intent ในการไปยังส่วนต่างๆ

โหมด "singleInstance" ยังแตกต่างจาก "singleTask" และ "singleInstancePerTask" เพียงแง่มุมเดียว นั่นคือกิจกรรมที่มี โหมดเปิดใช้งาน "singleTask" หรือ "singleInstancePerTask" จะทำให้กิจกรรมอื่นๆ เป็น "standard" และ กิจกรรม "singleTop" เป็นส่วนหนึ่งของงาน

ต ในทางกลับกัน กิจกรรม "singleInstance" ไม่อนุญาต ให้เป็นส่วนหนึ่งของงาน ต้องเป็นกิจกรรมเดียวในงาน หาก เริ่มกิจกรรมอื่น กิจกรรมนั้นจะได้รับมอบหมายให้กับงานอื่น หาก FLAG_ACTIVITY_NEW_TASK เป็นความตั้งใจ

กรณีการใช้งาน โหมดเปิดใช้งาน หากมีอินสแตนซ์หลายรายการ ความคิดเห็น
การเปิดตัวตามปกติสำหรับกิจกรรมส่วนใหญ่ "standard" ใช่ ค่าเริ่มต้น ระบบจะสร้างอินสแตนซ์กิจกรรมใหม่ทุกครั้งใน กำหนดเป้าหมายของงาน และกำหนดเส้นทางความตั้งใจไปยังงานนั้น
"singleTop" มีเงื่อนไข หากมีอินสแตนซ์ของกิจกรรมที่ด้านบนของงานเป้าหมายอยู่แล้ว ระบบจะกำหนดเส้นทางความตั้งใจไปยังอินสแตนซ์นั้นผ่านการเรียกไปยังเมธอด onNewIntent() ของอินสแตนซ์แทนที่จะสร้าง กิจกรรมครั้งใหม่
การเปิดตัวเฉพาะทาง
(ไม่แนะนำสำหรับการใช้งานทั่วไป)
"singleTask" มีเงื่อนไข ระบบจะสร้างกิจกรรมที่รูทของงานใหม่หรือค้นหากิจกรรมในงานที่มีอยู่ที่มีผู้สนใจเดียวกัน หากมีอินสแตนซ์ของกิจกรรมอยู่แล้วและอยู่ที่รูทของงาน กำหนดเส้นทางความตั้งใจไปยังอินสแตนซ์ที่มีอยู่ผ่านการเรียกไปยังเมธอด onNewIntent() ของอินสแตนซ์แทนที่จะสร้าง อันใหม่นะ
"singleInstance" ไม่ เหมือนกับ "singleTask" ยกเว้นว่าระบบไม่ได้เปิด กิจกรรมอื่นๆ ลงในงานที่มีอินสแตนซ์ดังกล่าว กิจกรรมจะเป็น และเป็นสมาชิกคนเดียวที่ทำงานได้
"singleInstancePerTask" มีเงื่อนไข กิจกรรมสามารถเรียกใช้เป็นกิจกรรมรากของงานเท่านั้น ซึ่งเป็นกิจกรรมแรก ที่สร้างงาน ดังนั้นจึงมีเพียงอินสแตนซ์เดียว กิจกรรมนี้ในงาน อย่างไรก็ตาม กิจกรรมดังกล่าวสามารถสร้างขึ้นได้หลายครั้งในงานต่างๆ

ตามที่แสดงในตารางก่อนหน้านี้ "standard" คือโหมดเริ่มต้น เหมาะสำหรับกิจกรรมส่วนใหญ่ "singleTop" ยังเป็น โหมดเปิดใช้งานทั่วไปและมีประโยชน์สำหรับกิจกรรมหลายประเภท โหมดอื่นๆ "singleTask" , "singleInstance" และ "singleInstancePerTask" ไม่เหมาะสมกับแอปพลิเคชันส่วนใหญ่ ทำให้เกิดรูปแบบการโต้ตอบที่อาจไม่คุ้นเคย และแตกต่างจากแอปพลิเคชันอื่นๆ ส่วนใหญ่อย่างมาก

ไม่ว่าคุณจะเลือกโหมดเปิดใช้งานใด อย่าลืมทดสอบความสามารถในการใช้งาน ระหว่างการเปิดตัวและเมื่อกลับไปยังกิจกรรมจาก กิจกรรมและงานอื่นๆ โดยใช้ปุ่มย้อนกลับ

ดูข้อมูลเพิ่มเติมเกี่ยวกับโหมดเปิดใช้งานและการโต้ตอบกับ Intent ธง โปรดดู Tasks และ Back Stack

android:lockTaskMode
กำหนดวิธีที่ระบบจะแสดงกิจกรรมนี้เมื่ออุปกรณ์ทำงาน ล็อกโหมดงาน

Android เรียกใช้งานต่างๆ ได้สมจริงเหมือนคีออสก์ที่เรียกว่าโหมดล็อกงาน เมื่อระบบ ทำงานในโหมดล็อกงาน ผู้ใช้อุปกรณ์มักจะไม่เห็นการแจ้งเตือน เข้าถึงแอปที่ไม่ได้อยู่ในรายการที่อนุญาต หรือกลับไปที่หน้าจอหลัก เว้นแต่แอป Home จะอยู่ในรายการที่อนุญาต

เฉพาะแอปที่ รายการที่อนุญาตโดยเครื่องมือควบคุมนโยบายด้านอุปกรณ์ (DPC) จะเรียกใช้ได้เมื่อระบบอยู่ในโหมดงานล็อก ระบบ และแอปที่ได้รับสิทธิ์ สามารถทำงานในโหมดล็อกงานได้โดยไม่ต้องอยู่ในรายการที่อนุญาต

ค่าอาจเป็นอย่างใดอย่างหนึ่งต่อไปนี้ ค่าสตริง R.attr.lockTaskMode:

ค่า คำอธิบาย
"normal" ค่าเริ่มต้น ค่านี้เป็นค่าเริ่มต้น Tasks จะไม่เปิดขึ้นในโหมดล็อกงานแต่ทําได้ ถึงที่นั่นโดยการโทร startLockTask()
"never"

Tasks จะไม่เปิดขึ้นในโหมด lockTask และผู้ใช้อุปกรณ์จะไม่สามารถปักหมุดงานเหล่านี้จาก หน้าจอล่าสุด

หมายเหตุ: โหมดนี้ใช้ได้กับระบบและแอปพลิเคชันที่ได้รับสิทธิ์เท่านั้น แอปที่ไม่ได้รับสิทธิ์ตามค่านี้จะถือว่าเป็น normal

"if_whitelisted" หาก DPC อนุญาตแพ็กเกจนี้โดยใช้ DevicePolicyManager.setLockTaskPackages() โหมดนี้จะเหมือนกับ always ยกเว้นว่ากิจกรรมจะต้องเรียกใช้ stopLockTask() ก่อนที่จะ ทำงานให้เสร็จสิ้นได้หากเป็นงานที่ล็อกไว้ล่าสุด หาก DPC ไม่อนุญาตแพ็กเกจนี้ โหมดเหมือนกับ normal
"always"

งานที่มีรูทจากกิจกรรมนี้จะเปิดในโหมดล็อกงานเสมอ หากระบบอยู่ใน โหมดล็อกงานเมื่อมีการเปิดตัวงานนี้ จากนั้นระบบจะเปิดตัวงานใหม่นอกเหนือจากงานปัจจุบัน งานที่เปิดในโหมดนี้สามารถออกจากโหมดล็อกงานได้ด้วยการโทร finish()

หมายเหตุ: โหมดนี้ใช้ได้กับระบบและแอปพลิเคชันที่ได้รับสิทธิ์เท่านั้น แอปที่ไม่ได้รับสิทธิ์ตามค่านี้จะถือว่าเป็น normal

แอตทริบิวต์นี้เปิดตัวใน API ระดับ 23

android:maxRecents
จำนวนงานสูงสุดที่เกิดจากกิจกรรมนี้ใน หน้าจอล่าสุด เมื่อมีรายการครบจำนวนดังกล่าว ระบบจะนำรายการ ใช้อินสแตนซ์จากหน้าจอล่าสุด ค่าที่ใช้ได้คือจำนวนเต็มตั้งแต่ 1 ถึง 50 หรือ 1 ถึง 25 ในอุปกรณ์ที่มีหน่วยความจำต่ำ 0 ไม่ถูกต้อง ค่าเริ่มต้นคือ 16
android:maxAspectRatio

สัดส่วนภาพสูงสุดที่กิจกรรมรองรับ หากแอปทำงาน บนอุปกรณ์ที่มีสัดส่วนภาพกว้างกว่า ระบบจะปรับแอปเป็นแถบดำด้านบน-ล่างของภาพโดยอัตโนมัติ ปล่อยพื้นที่หน้าจอบางส่วนไว้โดยไม่ใช้เพื่อให้แอปสามารถทำงานได้ตามสัดส่วนภาพสูงสุดที่ระบุไว้

สัดส่วนการแสดงผลสูงสุดแสดงในรูปแบบเลขฐานสิบของผลหารของอุปกรณ์ที่ยาวกว่า หารด้วยมิติข้อมูลที่สั้นกว่า เช่น หากสัดส่วนภาพสูงสุดคือ 7:3 ให้กำหนดค่าของแอตทริบิวต์นี้เป็น 2.33

ในอุปกรณ์ที่สวมใส่ไม่ได้ ค่าของแอตทริบิวต์นี้ต้องเป็น 1.33 ขึ้นไป สำหรับอุปกรณ์ที่สวมใส่ได้ ค่าจะต้องเป็น 1.0 ขึ้นไป มิฉะนั้น ระบบจะไม่สนใจ กำหนดค่า

หมายเหตุ: ระบบจะละเว้นแอตทริบิวต์นี้หากกิจกรรม ตั้งค่า resizeableActivity เป็น "จริง" เนื่องจากหมายความว่ากิจกรรมของคุณ รองรับทุกขนาด

ดูข้อมูลเพิ่มเติมเกี่ยวกับแอตทริบิวต์นี้ได้ที่ ประกาศสัดส่วนภาพสูงสุด

android:multiprocess
สามารถเรียกใช้อินสแตนซ์ของกิจกรรมในกระบวนการของคอมโพเนนต์ได้หรือไม่ ที่เป็นจุดเริ่มต้น Conversion จะเป็น "true" หากทำได้ และ "false" หากไม่ใช่ ค่าเริ่มต้นคือ "false"

โดยปกติแล้วจะมีการเปิดตัวกิจกรรมครั้งใหม่ในกระบวนการของ ดังนั้น อินสแตนซ์ทั้งหมดของกิจกรรมจึงทำงาน ขั้นตอนได้ อย่างไรก็ตาม หากตั้งค่าแฟล็กนี้เป็น "true" อินสแตนซ์ของ สามารถเรียกใช้กิจกรรมได้ในหลายกระบวนการ เพื่อให้ระบบสร้างอินสแตนซ์ ไม่ว่าจะใช้งานที่ไหนก็ตาม ให้สิทธิ์อนุญาต ซึ่งเป็นสิ่งที่เกือบ ไม่จำเป็นหรือไม่เป็นที่ต้องการ

android:name
ชื่อคลาสที่ทำกิจกรรม คลาสย่อยของ Activity ค่าแอตทริบิวต์คือ โดยทั่วไปแล้ว การทดสอบที่สมบูรณ์ ชื่อชั้นเรียน เช่น "com.example.project.ExtracurricularActivity" แต่ถ้าอักขระตัวแรกของชื่อเป็นเครื่องหมายจุด เช่น ".ExtracurricularActivity" จะต่อท้าย namespace ที่ระบุใน build.gradle ไฟล์

เมื่อคุณเผยแพร่แอปพลิเคชันของคุณแล้ว อย่า เปลี่ยนชื่อนี้ เว้นแต่คุณจะตั้งค่า android:exported="false" ไม่มีค่าเริ่มต้น ต้องระบุชื่อ

android:noHistory
นำกิจกรรมออกจากสแต็กกิจกรรมและ เสร็จสิ้นแล้ว โดยการเรียกใช้ finish() เมื่อผู้ใช้ออกจากหน้าไป และไม่ได้ แสดงบนหน้าจอ ค่าใช้จ่าย"true" หากสิ้นสุด และ "false" หากไม่ ค่าเริ่มต้นคือ "false"

ค่า "true" หมายความว่ากิจกรรมจะไม่ทิ้ง การติดตามประวัติศาสตร์ และจะไม่อยู่ในสแต็กกิจกรรมของงาน เพื่อไม่ให้ผู้ใช้กลับไปใช้ได้อีก ในกรณีนี้ จะไม่มีการโทรหา onActivityResult() หากคุณ เริ่มกิจกรรมอื่นเพื่อรับผลลัพธ์จากกิจกรรมนี้

แอตทริบิวต์นี้เปิดตัวใน API ระดับ 3

android:parentActivityName
ชื่อคลาสของระดับบนสุดเชิงตรรกะของกิจกรรม ชื่อในส่วนนี้ต้องตรงกับชั้นเรียน ชื่อที่กำหนดให้กับองค์ประกอบ <activity> ที่เกี่ยวข้อง android:name

ระบบจะอ่านแอตทริบิวต์นี้เพื่อกำหนดกิจกรรมที่จะเริ่มต้นเมื่อ ผู้ใช้แตะปุ่มขึ้นในแถบการทำงาน นอกจากนี้ระบบยังสามารถใช้ข้อมูลนี้เพื่อ สังเคราะห์กิจกรรมกลุ่มแบ็กสแต็กด้วย TaskStackBuilder

หากต้องการรองรับ API ระดับ 4 - 16 คุณยังประกาศกิจกรรมระดับบนสุดที่มีเอลิเมนต์ <meta-data> ที่ระบุค่าสำหรับ "android.support.PARENT_ACTIVITY" ได้ด้วย โดยทำดังนี้

<activity
    android:name="com.example.app.ChildActivity"
    android:label="@string/title_child_activity"
    android:parentActivityName="com.example.app.MainActivity" >
    <!-- Parent activity meta-data to support API level 4+ -->
    <meta-data
        android:name="android.support.PARENT_ACTIVITY"
        android:value="com.example.app.MainActivity" />
</activity>

ดูข้อมูลเพิ่มเติมเกี่ยวกับการประกาศกิจกรรมของผู้ปกครองเพื่อรองรับการนําทาง "ขึ้น" ได้ อ่านการให้กำลัง การนำทาง

แอตทริบิวต์นี้เปิดตัวใน API ระดับ 16

android:persistableMode

กำหนดวิธีเก็บรักษาอินสแตนซ์ของกิจกรรมภายใน งานในอุปกรณ์ต่างๆ จะรีสตาร์ท

หากกิจกรรมรูทของงานตั้งค่าของแอตทริบิวต์นี้เป็น persistRootOnly ระบบจะเก็บรักษาเฉพาะกิจกรรมรูทเท่านั้น มิฉะนั้น กิจกรรมที่อยู่ในลำดับที่สูงกว่า Back Stack จะได้รับการตรวจสอบ กิจกรรมใดๆ ก็ตามเหล่านี้ที่กำหนดค่าของแอตทริบิวต์นี้เป็น persistAcrossReboots จะยังคงอยู่

หากใช้แอตทริบิวต์นี้ คุณต้องกำหนดค่าของแอตทริบิวต์นี้เป็นหนึ่งในแอตทริบิวต์ ดังต่อไปนี้:

ค่า คำอธิบาย
persistRootOnly

ค่าเริ่มต้น เมื่อระบบรีสตาร์ท งานกิจกรรมจะ แต่จะใช้ Intent การเปิดตัวกิจกรรมรูทเท่านั้น

เมื่อ Intent เปิดใช้งานแอปโหลดกิจกรรมรูทของแอป กิจกรรมไม่ได้รับออบเจ็กต์ PersistableBundle ดังนั้นโปรดอย่าใช้ onSaveInstanceState() เพื่อรักษาสถานะกิจกรรมรูทของแอปในอุปกรณ์ต่างๆ รีสตาร์ท

หมายเหตุ: ค่าแอตทริบิวต์นี้ส่งผลต่อแอปของคุณ พฤติกรรมเฉพาะเมื่อมีการตั้งค่าไว้ในกิจกรรมรูทของแอป

persistAcrossReboots

สถานะของกิจกรรมนี้จะยังคงอยู่ รวมถึงสถานะของ ทำกิจกรรมให้สูงขึ้น กลับ สแต็กที่มีการตั้งค่าแอตทริบิวต์ persistableMode ของตนเองเป็น persistAcrossReboots ถ้ากิจกรรมไม่มี แอตทริบิวต์ persistableMode ที่ตั้งค่าเป็น persistAcrossReboots หรือหากเปิดตัวแล้วโดยใช้ Intent.FLAG_ACTIVITY_NEW_DOCUMENT รายงาน กิจกรรมนั้นพร้อมกับกิจกรรมอื่นๆ ทางด้านบน กลุ่ม จะไม่สงวนไว้

เมื่อ Intent โหลดกิจกรรมที่persistableMode ได้รับการตั้งค่าเป็น persistAcrossReboots ในแอปของคุณ กิจกรรมได้รับออบเจ็กต์ PersistableBundle ใน onCreate() ดังนั้น คุณสามารถใช้ onSaveInstanceState() เพื่อรักษาสถานะของกิจกรรมขณะรีสตาร์ทอุปกรณ์ ตั้งค่าแอตทริบิวต์ persistableMode เป็น persistAcrossReboots

หมายเหตุ: ค่าแอตทริบิวต์นี้ส่งผลต่อแอปของคุณ ทำงานแม้ว่าจะตั้งค่าไว้ในกิจกรรมอื่นที่ไม่ใช่รากของแอปก็ตาม กิจกรรม

persistNever

โดยสถานะของกิจกรรมจะหายไป

หมายเหตุ: ค่าแอตทริบิวต์นี้ส่งผลต่อแอปของคุณ พฤติกรรมเฉพาะเมื่อมีการตั้งค่าไว้ในกิจกรรมรูทของแอป

แอตทริบิวต์นี้เปิดตัวใน API ระดับ 21

android:permission
ชื่อสิทธิ์ที่ลูกค้าต้องใช้ในการเปิดกิจกรรม หรือทำให้โมเดลตอบสนองความตั้งใจ หากผู้โทร startActivity() หรือ วันที่ startActivityForResult() ไม่ได้รับสิทธิ์ที่ระบุ ระบบจะไม่นำส่ง Intent ไปยังกิจกรรม

หากไม่ได้ตั้งค่าแอตทริบิวต์นี้ไว้ สิทธิ์ที่กำหนดโดย <application> ขององค์ประกอบ วันที่ permission ที่นำไปใช้กับกิจกรรม หากไม่ได้ตั้งค่าแอตทริบิวต์ไว้ กิจกรรมจะไม่ได้รับการปกป้องโดย สิทธิ์

ดูข้อมูลเพิ่มเติมเกี่ยวกับสิทธิ์ได้ที่ สิทธิ์ ในภาพรวมไฟล์ Manifest ของแอปและ เคล็ดลับความปลอดภัย

android:process

ชื่อของกระบวนการที่กิจกรรมทำงาน โดยปกติแล้ว องค์ประกอบทั้งหมดของ แอปพลิเคชันจะทำงานในชื่อกระบวนการเริ่มต้นที่สร้างขึ้นสำหรับแอปพลิเคชัน และคุณไม่ต้อง คุณต้องใช้แอตทริบิวต์นี้ แต่หากจำเป็น คุณสามารถลบล้างกระบวนการเริ่มต้นได้ ด้วยแอตทริบิวต์นี้เพื่อให้คุณกระจายคอมโพเนนต์แอปไปทั่ว ที่หลากหลาย

หากชื่อที่กำหนดให้กับแอตทริบิวต์นี้เริ่มต้นด้วยโคลอน (:) ซึ่งเป็นแบบส่วนตัวสำหรับแอปพลิเคชัน จะสร้างขึ้นเมื่อจำเป็น และ กิจกรรมจะทำงานในกระบวนการนั้น

หากชื่อกระบวนการเริ่มต้นด้วยอักขระตัวพิมพ์เล็ก กิจกรรมจะทำงาน ในกระบวนการส่วนกลางของชื่อนั้น หากชื่อนั้นได้รับอนุญาตให้ดำเนินการดังกล่าว ทำให้คอมโพเนนต์ต่างๆ ในแอปพลิเคชันต่างๆ สามารถแบ่งปันกระบวนการได้โดย การใช้ทรัพยากร

ขององค์ประกอบ <application> วันที่ process สามารถตั้งชื่อกระบวนการเริ่มต้นเป็นชื่ออื่นสำหรับคอมโพเนนต์ทั้งหมดได้

android:relinquishTaskIdentity

กิจกรรมเลิกใช้ตัวระบุงานในกิจกรรมที่อยู่ด้านบนหรือไม่ใน สแต็กงาน งานที่กิจกรรมรูทมีการตั้งค่าแอตทริบิวต์นี้เป็น "true" จะแทนที่ฐาน Intent พร้อมกับกิจกรรมถัดไปในงาน

หากกิจกรรมถัดไปมีการตั้งค่าแอตทริบิวต์นี้ด้วย เป็น "true" ตัวแปรจะให้ Intent ฐานเป็นกิจกรรมใดก็ตามที่เปิดตัวไป งาน การดําเนินการนี้จะดำเนินต่อไปสำหรับแต่ละกิจกรรมจนกว่าจะพบกิจกรรมที่มีการตั้งค่าแอตทริบิวต์นี้ ไปยัง "false" ค่าเริ่มต้นคือ "false"

แอตทริบิวต์นี้ที่ตั้งค่าเป็น "true" จะอนุญาตให้กิจกรรมใช้ ActivityManager.TaskDescription เพื่อเปลี่ยนป้ายกำกับ สี และไอคอนต่างๆ ในหน้าจอล่าสุด

android:requireContentUriPermissionFromCaller

ระบุสิทธิ์ที่จำเป็นต่อการเปิดกิจกรรมนี้เมื่อผ่าน URI เนื้อหา ค่าเริ่มต้นคือ none ซึ่งหมายความว่าไม่มีความเฉพาะเจาะจง สิทธิ์ที่จำเป็น การตั้งค่าแอตทริบิวต์นี้จะจำกัดกิจกรรม ตามสิทธิ์ของผู้เรียกใช้ หากผู้เรียกใช้ไม่มี สิทธิ์ที่จำเป็น การเริ่มต้นกิจกรรมจะถูกปฏิเสธผ่าน SecurityException

โปรดทราบว่าการบังคับใช้จะใช้ได้กับ URI เนื้อหาภายใน Intent.getData() Intent.EXTRA_STREAM, และ Intent.getClipData()

อาจเป็นค่าสตริง โดยใช้ "\\;" เพื่อหลีกอักขระ เช่น '\\n' หรือ "\\uxxxx" สำหรับอักขระ Unicode

ต้องเป็นค่าคงที่ค่าใดค่าหนึ่งต่อไปนี้

ค่าคงที่ ค่า คำอธิบาย
ไม่มี 0 ค่าเริ่มต้น ไม่จำเป็นต้องมีสิทธิ์ที่เฉพาะเจาะจง
อ่าน 1 บังคับให้ผู้เรียกใช้มีสิทธิ์เข้าถึงการอ่าน URI เนื้อหาที่ผ่าน
ReadAndWrite 4 บังคับให้ผู้เรียกใช้มีทั้งสิทธิ์อ่านและเขียน URI เนื้อหาที่ส่งผ่าน
อ่านหรือเขียน 3 บังคับให้ผู้เรียกใช้มีสิทธิ์อ่านหรือเขียนใน URI เนื้อหาที่ผ่าน
เขียน 2 บังคับให้ผู้เรียกใช้มีสิทธิ์ในการเขียน URI เนื้อหาที่ผ่าน
android:resizeableActivity

ระบุว่าแอปรองรับโหมดหลายหน้าต่างหรือไม่ คุณ ตั้งค่าแอตทริบิวต์นี้ใน <activity> หรือ <application>

หากคุณตั้งค่าแอตทริบิวต์นี้เป็น "true" ผู้ใช้จะเปิดกิจกรรมได้ใน โหมดแยกหน้าจอและโหมดรูปแบบอิสระ หากคุณตั้งค่าแอตทริบิวต์เป็น "false" แอปจะ ไม่สามารถทดสอบหรือเพิ่มประสิทธิภาพสำหรับสภาพแวดล้อมที่มีหลายหน้าต่างได้ ระบบจะดำเนินการต่อไปนี้ ยังคงทำให้กิจกรรมอยู่ในโหมดหลายหน้าต่างที่ใช้โหมดความเข้ากันได้

การตั้งค่าแอตทริบิวต์นี้เป็น "false" ไม่ได้รับประกันว่าไม่มีแอตทริบิวต์ดังกล่าว แอปอื่นๆ ในโหมดหลายหน้าต่างที่ปรากฏบนหน้าจอ เช่น การแสดงภาพซ้อนภาพ หรือ บนจอแสดงผลอื่นๆ ดังนั้น การตั้งค่าแฟล็กนี้ไม่ได้หมายความว่าแอปของคุณ มีสิทธิ์เข้าถึงทรัพยากรเฉพาะตัว

หากแอปกำหนดเป้าหมายเป็น API ระดับ 24 ขึ้นไปและคุณไม่ได้ระบุค่า สำหรับแอตทริบิวต์นี้ ค่าแอตทริบิวต์เริ่มต้นเป็น "true"

หากแอปกำหนดเป้าหมายเป็น API ระดับ 31 ขึ้นไป แอตทริบิวต์นี้จะทำงานต่างกันไปสำหรับขนาดเล็กและขนาดใหญ่ ได้แก่

  • หน้าจอขนาดใหญ่ (sw >= 600dp): แอปทั้งหมดรองรับโหมดหลายหน้าต่าง แอตทริบิวต์จะระบุ สามารถปรับขนาดแอปได้หรือไม่ ไม่ใช่ว่าแอปรองรับโหมดหลายหน้าต่างหรือไม่ ถ้า resizeableActivity="false" แอปจะเข้าสู่โหมดความเข้ากันได้เมื่อจำเป็น เพื่อให้สอดคล้องกับขนาดที่แสดง
  • หน้าจอขนาดเล็ก (sw < 600dp): หาก resizeableActivity="true" และต่ำสุด ความกว้างและความสูงขั้นต่ำของกิจกรรมอยู่ภายในข้อกำหนดของหลายหน้าต่าง แอป สนับสนุนโหมดหลายหน้าต่าง หากเป็น resizeableActivity="false" แอปจะไม่ทำ สนับสนุนโหมดหลายหน้าต่างโดยไม่คำนึงถึงความกว้างและความสูงขั้นต่ำของกิจกรรม

หมายเหตุ: ผู้ผลิตอุปกรณ์ลบล้าง API ระดับ 31 ได้ พฤติกรรมของคุณ

แอตทริบิวต์นี้มีการเพิ่มใน API ระดับ 24

หมายเหตุ: ระบบจะใช้ค่ากิจกรรมรูทของงานกับ กิจกรรมเพิ่มเติมที่เปิดในงาน กล่าวคือ หากกิจกรรมรากของ งานสามารถปรับขนาดได้ จากนั้น ระบบจะจัดการกับกิจกรรมอื่นๆ ทั้งหมดใน ที่ปรับขนาดได้ หากกิจกรรมรากไม่สามารถปรับขนาดได้ กิจกรรมในงานนั้นปรับขนาดไม่ได้

android:screenOrientation

การวางแนวที่ขอของกิจกรรม

เมื่อกิจกรรมแสดงเต็มหน้าจอ การวางแนวที่ขอจะทำหน้าที่เป็นคำแนะนำ เปลี่ยนการวางแนวบนหน้าจอนั้นให้ตรงกับค่าที่ขอ ซึ่งอาจส่งผลให้ การวางแนวที่แตกต่างจากการวางแนวหน้าจอในอวกาศ หมุนอุปกรณ์เพื่อใช้แอปต่อ ใน Android 12 (ระดับ API 31) ขึ้นไป ผู้ผลิตอุปกรณ์สามารถกำหนดค่าอุปกรณ์แต่ละเครื่องได้ (เช่น หน้าจอขนาดแท็บเล็ตของอุปกรณ์แบบพับได้) เพื่อละเว้นคำแนะนำนี้ และ บังคับให้กิจกรรมมีแถบดำด้านบน-ล่างของภาพตามการวางแนวอุปกรณ์ที่ผู้ใช้ต้องการ ช่วงเวลานี้ ทำให้การวางแนวของกิจกรรมตรงกับรายการที่ขอโดยผู้ใช้ไม่จำเป็นต้อง หมุนอุปกรณ์ของตน

ในโหมดหลายหน้าต่าง การวางแนวที่ร้องขอไม่ได้เป็นแนวทางสำหรับ การวางแนว หากกิจกรรมคือ Letterboxed คำขอ การวางแนวส่งผลต่อแถบดำด้านบน-ล่างของภาพที่ใช้กับกิจกรรม

ค่าอาจเป็นสตริงใดสตริงหนึ่งต่อไปนี้

"unspecified" ค่าเริ่มต้น ระบบจะเลือกการวางแนว นโยบาย การใช้งาน ดังนั้นตัวเลือกที่เลือกในบริบทที่เฉพาะเจาะจงจึงอาจแตกต่างกัน จากอุปกรณ์หนึ่งไปยังอีกอุปกรณ์หนึ่ง
"behind" การวางแนวเดียวกับกิจกรรมที่อยู่ด้านล่างของกิจกรรมนี้ ชุดกิจกรรม
"landscape" แนวนอน (จอแสดงผลมีความกว้างมากกว่าความสูง)
"portrait" การวางแนวตั้ง (จอแสดงผลสูงกว่าความกว้าง)
"reverseLandscape" การวางแนวแนวนอนในทิศทางตรงกันข้ามกับแนวนอนปกติ เพิ่มใน API ระดับ 9 แล้ว
"reversePortrait" การวางแนวตั้งในทิศทางตรงกันข้ามกับแนวตั้งปกติ เพิ่มใน API ระดับ 9 แล้ว
"sensorLandscape" วางแนวนอน แต่อาจเป็นแนวนอนหรือกลับด้านก็ได้โดยขึ้นอยู่กับอุปกรณ์ เซ็นเซอร์ ระบบจะใช้เซ็นเซอร์แม้ว่าผู้ใช้จะล็อกการหมุนตามเซ็นเซอร์ไว้ก็ตาม เพิ่มใน API ระดับ 9 แล้ว
"sensorPortrait" การวางแนวตั้ง แต่อาจเป็นแนวตั้งแบบกลับด้านหรือปกติก็ได้โดยขึ้นอยู่กับอุปกรณ์ เซ็นเซอร์ ระบบจะใช้เซ็นเซอร์แม้ว่าผู้ใช้จะล็อกการหมุนตามเซ็นเซอร์ไว้ก็ตาม อย่างไรก็ตาม ขึ้นอยู่กับ คุณอาจไม่อนุญาตให้ใช้การหมุนกลับหัว เพิ่มใน API ระดับ 9 แล้ว
"userLandscape" วางแนวนอน แต่อาจเป็นแนวนอนหรือกลับด้านก็ได้โดยขึ้นอยู่กับอุปกรณ์ และค่ากำหนดของผู้ใช้ เพิ่มใน API ระดับ 18 แล้ว
"userPortrait" การวางแนวตั้ง แต่อาจเป็นแนวตั้งแบบกลับด้านหรือปกติก็ได้โดยขึ้นอยู่กับอุปกรณ์ และค่ากำหนดของผู้ใช้ แต่ทั้งนี้ขึ้นอยู่กับการกำหนดค่าอุปกรณ์ การกลับหัวกลับหาง การหมุนอาจไม่ได้รับอนุญาต เพิ่มใน API ระดับ 18 แล้ว
"sensor" เซ็นเซอร์การวางแนวของอุปกรณ์เป็นตัวกำหนดการวางแนว การวางแนวของ ขึ้นอยู่กับวิธีที่ผู้ใช้ถืออุปกรณ์ จะเปลี่ยนแปลงเมื่อผู้ใช้หมุน อุปกรณ์ แต่อุปกรณ์บางรุ่นจะไม่หมุนไปเป็นการวางแนวทั้ง 4 แบบโดยค่าเริ่มต้น ถึง ใช้การวางแนวทั้ง 4 แบบ ใช้ "fullSensor" ระบบจะใช้เซ็นเซอร์แม้ว่าผู้ใช้ ล็อกการหมุนตามเซ็นเซอร์ไว้
"fullSensor" เซ็นเซอร์การวางแนวของอุปกรณ์เป็นตัวกำหนดการวางแนวสำหรับการวางแนว 4 แบบ โหมดนี้คล้ายกับ "sensor" แต่จะอนุญาตการวางแนวหน้าจอที่เป็นไปได้ 4 แบบ ไม่ว่าปกติแล้วอุปกรณ์จะรองรับรุ่นใด เช่น อุปกรณ์บางอย่างมักไม่ได้ใช้การกลับด้าน แนวตั้งหรือกลับด้าน แต่ก็จะช่วยให้วางแนวภาพเหล่านั้นได้ เพิ่มใน API ระดับ 9 แล้ว
"nosensor" การวางแนวจะกำหนดโดยไม่อ้างอิงเซ็นเซอร์การวางแนวทางกายภาพ เซ็นเซอร์ ไม่สนใจ ดังนั้นจอแสดงผลจะไม่หมุนตามวิธีที่ผู้ใช้ย้ายอุปกรณ์
"user" การวางแนวที่ผู้ใช้ต้องการในปัจจุบัน
"fullUser" หากผู้ใช้ล็อกการหมุนตามเซ็นเซอร์ไว้ ลักษณะการทำงานนี้ก็จะเหมือนกับ user ไม่เช่นนั้น ไฟล์ดังกล่าวจะทำงานเหมือนกับ fullSensor และอนุญาต 1 ใน 4 ข้อที่สามารถทำได้ การวางแนวหน้าจอ เพิ่มใน API ระดับ 18 แล้ว
"locked" ล็อกการวางแนวตามการหมุนปัจจุบัน ไม่ว่าจะอยู่ที่ใดก็ตาม เพิ่มใน API ระดับ 18 แล้ว

หมายเหตุ: เมื่อคุณประกาศค่าแนวนอนหรือแนวตั้งค่าใดค่าหนึ่ง ถือว่าเป็นข้อกำหนดที่บังคับสำหรับการวางแนวของกิจกรรม ค่าที่คุณประกาศจะช่วยให้สามารถกรองตามบริการ เช่น Google Play ดังนั้นแอปพลิเคชันของคุณจึง ใช้ได้เฉพาะกับอุปกรณ์ที่รองรับการวางแนวตามที่กิจกรรมของคุณกำหนดไว้ สำหรับ เช่น หากคุณประกาศ "landscape", "reverseLandscape" หรือ "sensorLandscape" แอปพลิเคชันของคุณจะพร้อมใช้งานในอุปกรณ์ที่รองรับเท่านั้น แนวนอน

ประกาศให้ชัดเจนด้วยว่า แอปพลิเคชันของคุณกำหนดให้มีการวางแนวตั้งหรือแนวนอนโดยใช้ <uses-feature> องค์ประกอบ เช่น <uses-feature android:name="android.hardware.screen.portrait"/> นี่เป็นลักษณะการทำงานของการกรอง จาก Google Play และบริการอื่นๆ ที่รองรับ Google Play และตัวแพลตฟอร์มเองก็ไม่ได้ ควบคุมว่าแอปจะติดตั้งได้หรือไม่เมื่ออุปกรณ์รองรับการวางแนวบางรูปแบบเท่านั้น

android:showForAllUsers

แสดงกิจกรรมเมื่อผู้ใช้ปัจจุบันของอุปกรณ์แสดงหรือไม่ ต่างจากผู้ใช้ที่เริ่มกิจกรรม คุณตั้งค่าแอตทริบิวต์นี้ได้ เป็นค่าลิเทอรัล เช่น "true" หรือ "false" หรือ คุณจะตั้งค่าแอตทริบิวต์เป็นแอตทริบิวต์ทรัพยากรหรือธีมที่มี ค่าบูลีน

แอตทริบิวต์นี้มีการเพิ่มใน API ระดับ 23

android:stateNotNeeded
สามารถสิ้นสุดกิจกรรมและเริ่มต้นใหม่สำเร็จหรือไม่ โดยไม่ต้องบันทึกสถานะไว้ เปลี่ยนเป็น "true" หากเริ่มต้นใหม่ได้ โดยไม่อ้างอิงสถานะก่อนหน้า และ "false" หากสถานะก่อนหน้า ต้องระบุสถานะ ค่าเริ่มต้นคือ "false"

โดยปกติก่อนที่กิจกรรมใดๆ จะปิดตัวลงชั่วคราวเพื่อประหยัดทรัพยากร onSaveInstanceState() เมธอด วิธีนี้จะจัดเก็บสถานะปัจจุบันของกิจกรรมใน Bundle ซึ่งจะส่งผ่านไปยัง onCreate() เมื่อกิจกรรม เริ่มต้นใหม่ หากตั้งค่าแอตทริบิวต์นี้เป็น "true" อาจไม่มีการเรียก onSaveInstanceState() และมีการส่งผ่าน onCreate() null แทนที่จะเป็น Bundle เช่นเดียวกับเมื่อ กิจกรรมเริ่มต้นเป็นครั้งแรก

การตั้งค่า "true" หมายความว่าคุณสามารถเริ่มกิจกรรมใหม่ได้โดยไม่ต้อง สถานะที่คงไว้ เช่น กิจกรรมที่แสดง หน้าจอหลักใช้การตั้งค่านี้เพื่อให้แน่ใจว่าจะไม่ถูกนำออกหาก ขัดข้องเพราะบางอย่าง

android:supportsPictureInPicture

ระบุว่ากิจกรรมรองรับ หรือไม่ การแสดงภาพซ้อนภาพ

android:taskAffinity

งานที่กิจกรรมดังกล่าวมีความสนใจ กิจกรรมกับ แนวคิดกลุ่มความสนใจเดียวกันเป็นของงานเดียวกัน โดยเป็น "แอปพลิเคชัน" จากมุมมองของผู้ใช้ ความสนใจของงาน กำหนดโดยแอฟฟินิตี้ของกิจกรรมราก

ผู้สนใจกำหนด 2 สิ่งคือ งานที่กิจกรรมนั้นได้รับการกำหนดระดับบนสุดใหม่ เพื่อ (โปรดดู allowTaskReparenting ) และงานที่เก็บกิจกรรมเมื่อเริ่มทำงาน ด้วย FLAG_ACTIVITY_NEW_TASK แจ้ง

โดยค่าเริ่มต้น กิจกรรมทั้งหมดในแอปพลิเคชันจะมีกลุ่มความสนใจเดียวกัน คุณ สามารถตั้งค่าแอตทริบิวต์นี้ให้จัดกลุ่มแอตทริบิวต์แตกต่างกันได้ กิจกรรมที่กำหนดไว้ในแอปพลิเคชันต่างๆ ภายในงานเดียวกัน ถึง ระบุว่ากิจกรรมไม่มีผู้สนใจสำหรับงานใดๆ ให้ตั้งค่า ลงในสตริงว่าง

หากไม่ได้ตั้งค่าแอตทริบิวต์นี้ กิจกรรมจะรับค่าชุดแอฟฟินิตี้ สำหรับแอปพลิเคชัน โปรดดู <application> ขององค์ประกอบ วันที่ taskAffinity ชื่อของกลุ่มความสนใจเริ่มต้นสำหรับแอปพลิเคชันคือ เนมสเปซที่ตั้งค่าไว้ใน build.gradle ไฟล์

android:theme
การอ้างอิงทรัพยากรรูปแบบซึ่งกำหนดธีมโดยรวมของกิจกรรม การดําเนินการนี้จะตั้งค่าบริบทของกิจกรรมโดยอัตโนมัติเพื่อใช้ theme และอาจ ทำให้ "เริ่มทำงาน" ภาพเคลื่อนไหวก่อนเริ่มกิจกรรม ตรงกับลักษณะของกิจกรรมจริง

หากไม่ได้ตั้งค่าแอตทริบิวต์นี้ไว้ กิจกรรมจะรับค่าชุดธีมสำหรับ แอปพลิเคชันโดยรวม จาก <application> ขององค์ประกอบ วันที่ theme หากไม่ได้ตั้งค่าแอตทริบิวต์ดังกล่าวไว้ ระบบจะใช้ธีมเริ่มต้นของระบบ สำหรับข้อมูลเพิ่มเติม โปรดดูข้อมูลที่หัวข้อรูปแบบและธีม

android:uiOptions

ตัวเลือกเพิ่มเติมสำหรับ UI ของกิจกรรม ต้องเป็นค่าใดค่าหนึ่งต่อไปนี้

ค่าคำอธิบาย
"none"ไม่มีตัวเลือก UI เพิ่มเติม โดยตัวเลือกนี้คือค่าเริ่มต้น
"splitActionBarWhenNarrow"เพิ่มแถบที่ ที่ด้านล่างของหน้าจอเพื่อแสดงรายการการทำงานในแถบแอป หรือที่เรียกว่า แถบการดำเนินการเมื่อ พื้นที่แนวนอน เช่น เมื่ออยู่ในโหมดแนวตั้งบนโทรศัพท์มือถือ แทนที่จะเป็นช่องเล็กๆ จำนวนรายการการทำงานที่ปรากฏในแถบแอปที่ด้านบนของหน้าจอ แถบแอป แบ่งออกเป็นส่วนการนำทางด้านบนและแถบด้านล่างสำหรับรายการการทำงาน ซึ่งหมายความว่า จำนวนพื้นที่ที่สามารถใช้งานได้ไม่เพียงแค่สำหรับรายการการทำงาน แต่รวมถึงการนำทางและชื่อ ที่ด้านบน รายการในเมนูไม่ได้แบ่งออกเป็น 2 แถบ โดยจะปรากฏเสมอ

ดูข้อมูลเพิ่มเติมเกี่ยวกับแถบแอปได้ที่เพิ่มแถบแอป

แอตทริบิวต์นี้มีการเพิ่มใน API ระดับ 14

android:windowSoftInputMode
วิธีที่หน้าต่างหลักของกิจกรรมโต้ตอบกับหน้าต่างที่มี แป้นพิมพ์บนหน้าจอ การตั้งค่าสำหรับแอตทริบิวต์นี้ สิ่งต่างๆ:
  • ซอฟต์แป้นพิมพ์จะซ่อนหรือมองเห็นได้เมื่อกิจกรรมกลายเป็น ความสนใจของผู้ใช้
  • หน้าต่างหลักของกิจกรรม ปรับขนาดให้เล็กลงเพื่อให้มีพื้นที่สำหรับซอฟต์คีย์บอร์ดหรือเนื้อหา เลื่อนเพื่อแสดงโฟกัสปัจจุบันเมื่อบางส่วนของหน้าต่างถูกบัง แป้นพิมพ์เสมือน

การตั้งค่าต้องเป็นค่าใดค่าหนึ่งที่แสดงในตารางต่อไปนี้ หรือ ชุดค่าผสมของค่า "state..." หนึ่งค่า บวกหนึ่ง "adjust..." การตั้งค่าหลายค่าในกลุ่มใดกลุ่มหนึ่ง เช่น หลายค่า ค่า "state..." มีผลลัพธ์ที่ไม่ได้กำหนด ค่าแต่ละค่าจะคั่นด้วยแถบแนวตั้ง (|) ดังที่แสดงในตัวอย่างต่อไปนี้

<activity android:windowSoftInputMode="stateVisible|adjustResize" ... >

ค่าที่ตั้งไว้ที่นี่ (นอกเหนือจาก "stateUnspecified" และ "adjustUnspecified") ลบล้างค่าที่ตั้งไว้ในธีม

ค่า คำอธิบาย
"stateUnspecified" แป้นพิมพ์เสมือนซ่อนอยู่หรือมองเห็นได้ ไม่ได้ระบุ เลือกรัฐที่เหมาะสม หรือ ขึ้นอยู่กับการตั้งค่าในธีม

นี่เป็นการตั้งค่าเริ่มต้นสำหรับลักษณะการทำงานของแป้นพิมพ์เสมือน

"stateUnchanged" แป้นพิมพ์เสมือนจะเก็บอยู่ในสถานะล่าสุด มองเห็นได้หรือซ่อนไว้ เมื่อมีกิจกรรมเกิดขึ้น
"stateHidden" แป้นพิมพ์เสมือนจะซ่อนอยู่เมื่อผู้ใช้เลือกกิจกรรมที่ เมื่อผู้ใช้ตอบรับที่จะนำทางไปยัง กิจกรรมอื่น แทนการสำรองข้อมูลขณะออกจากกิจกรรมอื่น
"stateAlwaysHidden" แป้นพิมพ์เสมือนจะซ่อนไว้เสมอเมื่อหน้าต่างหลักของกิจกรรม มีโฟกัสอินพุต
"stateVisible" แป้นพิมพ์เสมือนจะแสดงขึ้นเมื่อผู้ใช้เลือก ซึ่งก็คือเมื่อผู้ใช้ยืนยันว่าจะไปข้างหน้า ไปยังกิจกรรม แทนการย้อนกลับไปใช้เมื่อออกจากกิจกรรมอื่น กิจกรรม
"stateAlwaysVisible" แป้นพิมพ์เสมือนจะปรากฏขึ้นเมื่อหน้าต่างมีการโฟกัสการป้อนข้อมูล
"adjustUnspecified" ปรับขนาดหน้าต่างหลักของกิจกรรมหรือไม่ เพื่อให้มีพื้นที่สำหรับซอฟต์คีย์บอร์ดหรือเนื้อหา ของการเลื่อนหน้าต่างเพื่อทำให้โฟกัสปัจจุบันมองเห็นได้บนหน้าจอไม่ได้ระบุไว้ ระบบจะเลือกโหมดใดโหมดหนึ่งต่อไปนี้ให้โดยอัตโนมัติ ว่าเนื้อหาของหน้าต่างมีมุมมองเลย์เอาต์ ก็สามารถเลื่อนดูเนื้อหา หากมีมุมมองเช่นนี้ หน้าต่าง ปรับขนาดได้ โดยเข้าใจว่าการเลื่อนทำให้ ของเนื้อหาของหน้าต่างที่มองเห็นได้ภายในพื้นที่ที่เล็กกว่า

ตัวเลือกนี้เป็นการตั้งค่าเริ่มต้นสำหรับลักษณะการทำงานของหน้าต่างหลัก

"adjustResize" หน้าต่างหลักของกิจกรรมจะปรับขนาดอยู่เสมอเพื่อให้มีพื้นที่สำหรับ แป้นพิมพ์บนหน้าจอ
"adjustPan" หน้าต่างหลักของกิจกรรมไม่ได้ปรับขนาดเพื่อให้มีพื้นที่สำหรับการเคลื่อนไหว แป้นพิมพ์ แต่จะแสดงเนื้อหาในหน้าต่างโดยอัตโนมัติ เลื่อนเพื่อไม่ให้โฟกัสปัจจุบันบดบังด้วยแป้นพิมพ์ และผู้ใช้ก็สามารถเห็นได้ตลอดเวลาว่ากำลังพิมพ์อะไร โดยทั่วไปจะใช้เวลาน้อยกว่า ควรปรับปรุงมากกว่าการปรับขนาด เนื่องจากผู้ใช้อาจต้องปิดโฆษณา แป้นพิมพ์เพื่อตรวจจับและโต้ตอบกับส่วนที่ถูกบดบังของหน้าต่าง

แอตทริบิวต์นี้เปิดตัวใน API ระดับ 3

เปิดตัวใน
API ระดับ 1 สำหรับแอตทริบิวต์ทั้งหมดยกเว้น noHistory และ windowSoftInputMode ที่เพิ่มใน API ระดับ 3
ดูเพิ่มเติม
<application>
<activity-alias>