در اندروید 9 (و پایینتر)، برنامهها در حالت PAUSED
قرار میگرفتند که:
- یک فعالیت جدید و شفاف در بالای برنامه راه اندازی شد، در حالی که برنامه هنوز قابل مشاهده بود (و بنابراین، متوقف نشد).
- فعالیت تمرکز خود را از دست داد، اما نامشخص بود و کاربر میتوانست با آن تعامل داشته باشد. به عنوان مثال، در حالت چند پنجره ای، تعدادی از فعالیت ها می توانند قابل مشاهده باشند و ورودی لمسی را به طور همزمان دریافت کنند.
این موقعیتها در میزان توقفی که یک برنامه باید انجام دهد متفاوت است، اما در سطح برنامه قابل تشخیص نیستند.
در Android 10، تمام فعالیتهای با قابلیت فوکوس بالا در پشتههای قابل مشاهده در حالت RESUMED
قرار دارند. این کار سازگاری با حالتهای Multi-Window و MD را برای برنامههایی که از onPause()
به جای onStop()
برای توقف بازخوانی رابط کاربری و تعامل با کاربر، بهبود میبخشد. این یعنی:
- هر دو فعالیت در صفحه نمایش تقسیم شده از سر گرفته می شوند.
- همه فعالیتهای قابل مشاهده از بالا در حالت پنجرهسازی آزاد از سر گرفته میشوند.
- میتوان همزمان فعالیتها را در چندین صفحه از سر گرفت.
شکل 1. چند رزومه روی یک دستگاه تاشو
شکل 2. چند رزومه در حالت دسکتاپ
فعالیتها زمانی میتوانند در حالت PAUSED
قرار گیرند که نمیتوان روی آنها متمرکز شد یا تا حدی مسدود شدهاند، مانند:
- در یک صفحه تقسیم کوچک شده (با پرتاب کننده در کنار)، فعالیت برتر از سر گرفته نمی شود زیرا قابل تمرکز نیست.
- در حالت تصویر در تصویر، فعالیت از سر گرفته نمی شود زیرا قابل فوکوس نیست.
- زمانی که فعالیتها توسط سایر فعالیتهای شفاف در همان پشته پوشش داده میشوند.
این رویکرد به برنامهها نشان میدهد که یک فعالیت فقط در حالت RESUMED
میتواند ورودی را از کاربر دریافت کند. قبل از Android 10، فعالیتها همچنین میتوانستند ورودی را در حالت PAUSED
دریافت کنند (برای مثال، سعی کنید هر دو فعالیت را در صفحه تقسیم شده به طور همزمان در دستگاهی که Android 9 دارد لمس کنید).
برای حفظ سیگنال از سرگیری شده از نسخههای قبلی Android (و برقراری ارتباط زمانی که برنامهها باید به منابع دسترسی انحصاری یا تکتنه دسترسی داشته باشند)، Android 10 شامل یک تماس جدید است:
Activity#onTopResumedActivityChanged(boolean onTop)
هنگامی که فراخوانی می شود، این فراخوانی بین Activity#onResume()
و Activity#onPause()
فراخوانی می شود. این پاسخ به تماس اختیاری است و میتوان آن را نادیده گرفت، بنابراین یک فعالیت میتواند از حالت RESUMED
به حالت PAUSED
تبدیل شود بدون اینکه به بالاترین حالت در سیستم تبدیل شود. مثلا در حالت چند پنجره ای. از آنجایی که این فراخوان اختیاری است، بخشی از چرخه حیات فعالیت نیست و به ندرت باید از آن استفاده شود.
قبل از اینکه فعالیت قبلی از سر گرفته شده قبلی، onTopResumedActivity(false)
را دریافت کند، اجرای onTopResumedActivity(true)
را دریافت کرده و به پایان میرساند، مگر اینکه فعالیت قبلی زمان زیادی برای رسیدگی به فراخوانی متد داشته باشد و به وقفه 500 میلیثانیه برسد.
سازگاری
برای حفظ سازگاری هنگام اجرای چند رزومه، این راه حل ها را در نظر بگیرید.
چندین فعالیت از سر گرفته شده در یک فرآیند برنامه
- موضوع. در اندروید 9 و پایین تر، هر بار فقط یک فعالیت در سیستم از سر گرفته می شود. تمام انتقالها بین فعالیتها شامل توقف یک فعالیت قبل از از سرگیری فعالیت دیگر است. برخی از برنامهها و فریمورکها (مانند Flutter یا LocalActivityManager اندروید) از این واقعیت استفاده میکنند و وضعیت از سرگیری فعالیت را در تکتون ذخیره میکنند.
- راه حل. در اندروید 9 و پایینتر، اگر دو فعالیت از یک فرآیند هر دو از سر گرفته شوند، سیستم فقط فعالیتهایی را که در مرتبه Z بالاتر است از سر میگیرد. برنامههایی که اندروید 10 را هدف قرار میدهند، میتوانند همزمان از سرگیری چندین فعالیت پشتیبانی کنند.
دسترسی همزمان به دوربین
- مسائل . این مشکلات در اندروید 9 به بالا نیز وجود دارد. به عنوان مثال، یک فعالیت تمام صفحه و از سرگیری میتواند فوکوس دوربین را به دلیل یک فعالیت متوقف شده در بالا در حالت تصویر در تصویر از دست بدهد، اما با پذیرش گستردهتر حالتهای چند پنجرهای و چند صفحهنمایش بیشتر در معرض دید قرار میگیرد.
- با توجه به تغییرات ایجاد شده در وضعیت
RESUME
، برنامهها ممکن است حتی در زمان ازسرگیری از دوربین جدا شوند. برای رفع این مشکل، برنامهها باید با قطع ارتباط دوربین بدون خرابی برخورد کنند. وقتی اتصال برنامهها قطع میشود، یک پاسخ تماس قطع شده دریافت میکنند و همه تماسهای API شروع به پرتابCameraAccessException
میکنند. -
resizeableActivity=false
تضمینی برای دسترسی انحصاری به دوربین نیست، زیرا برنامههای دیگری که از دوربین استفاده میکنند میتوانند روی نمایشگرهای دیگر باز شوند.
- با توجه به تغییرات ایجاد شده در وضعیت
- راه حل ها برنامهنویسان باید منطقی را برای زمانی که یک برنامه از دوربین جدا میشود، لحاظ کنند. اگر ارتباط برنامهای با دوربین قطع شده باشد، باید تماسهای در دسترس بودن دوربین را تماشا کند تا دوباره متصل شود و به استفاده از دوربین ادامه دهد. علاوه بر پاسخ تماس
CameraManager#AvailabilityCallback#onCameraAvailable()
، Android 10CameraManager#AvailabilityCallback#onCameraAccessPrioritiesChanged()
را اضافه کرد که مواردی را پوشش می دهد که فوکوس (و اولویت دوربین) بین چندین فعالیت از سر گرفته شده جابجا شوند. توسعه دهندگان برنامه باید از هر دوی این تماس ها برای تعیین زمان مناسب برای دسترسی به دوربین استفاده کنند.
چند رزومه
در اندروید 10، وضعیت چرخه حیات فعالیت با قابلیت دید و ترتیب Z تعیین می شود. برای اطمینان از اینکه وضعیت صحیح پس از قابلیت مشاهده در یک فعالیت بهروزرسانی میشود و ارزیابی میکنید که کدام حالت چرخه حیات قابل اجرا است، متد ActivityRecord#makeActiveIfNeeded()
را از مکانهای مختلف فراخوانی کنید. در اندروید 10، فعال به معنای RESUMED
یا PAUSED
است و فقط در این دو مورد کار می کند.
در Android 10، از سرگیری یک فعالیت بهجای اینکه در یک مکان در سیستم باشد، بهطور جداگانه در هر پشته ردیابی میشود. این به این دلیل است که چندین انتقال فعالیت را می توان به طور همزمان در حالت های چند پنجره ای انجام داد. برای جزئیات، به ActivityStack#mInResumeTopActivity
مراجعه کنید.
پاسخ به تماس با فعالیت برتر از سر گرفته شده
پس از اقداماتی که میتواند منجر به تغییر فعالیت برتر شود (مانند راهاندازی فعالیت، از سرگیری یا تغییر مرتبه Z)، ActivityStackSupervisor#updateTopResumedActivityIfNeeded()
فراخوانی میشود. این روش بررسی می کند که آیا بالاترین فعالیت از سر گرفته شده تغییر کرده است یا خیر و در صورت نیاز به روز رسانی را انجام می دهد. اگر فعالیت قبلی که از سر گرفته شده است، وضعیت از سرگیری بالا را منتشر نکرده باشد، پیامی برای آن ارسال می شود و یک مهلت زمانی در سمت سرور برنامه ریزی می شود ( ActivityStackSupervisor#scheduleTopResumedStateLossTimeout()
). گزارش وضعیت بالاتر از سر گرفته شده پس از اینکه فعالیت قبلی وضعیت را آزاد کرد، یا زمانی که یک بازه زمانی قطع شد، به فعالیت بعدی ارسال میشود (به موارد زیر مراجعه کنید:
ActivityStackSupervisor#scheduleTopResumedActivityStateIfNeeded()
یک مورد جدید تراکنش TopResumedActivityChangeItem
اضافه شد تا تغییرات حالت از سر گرفته شده بالا را به مشتریان گزارش کند و از معماری ActivityLifecycler
از اندروید 9 استفاده کند.
حالت از سرگیری بالا در سمت کلاینت ذخیره میشود و هر بار که فعالیت به RESUMED
یا PAUSED
تغییر میکند، همچنین بررسی میکند که آیا باید فراخوانی onTopResumedActivityChanged()
فراخوانی شود یا خیر. این امر جداسازی خاصی را در ارتباط حالتهای چرخه حیات و حالت از سرگیری بالا بین طرف سرور و مشتری امکانپذیر میسازد.