Android 6.0 ( M ) ویژگی های جدیدی را برای کاربران و توسعه دهندگان برنامه ارائه می دهد. این سند مقدمه ای بر قابل توجه ترین API ها ارائه می دهد.
شروع به توسعه کنید
برای شروع ساختن برنامه برای Android 6.0، ابتدا باید Android SDK را دریافت کنید . سپس از SDK Manager برای دانلود پلتفرم Android 6.0 SDK و تصاویر سیستم استفاده کنید.
سطح API هدف خود را به روز کنید
برای بهینه سازی بهتر برنامه خود برای دستگاه های دارای Android، targetSdkVersion
خود را روی "23"
تنظیم کنید، برنامه خود را روی یک تصویر سیستم اندروید نصب کنید، آن را آزمایش کنید، سپس برنامه به روز شده را با این تغییر منتشر کنید.
میتوانید با افزودن شرایطی به کدتان که سطح API سیستم را قبل از اجرای APIهایی که توسط minSdkVersion
شما پشتیبانی نمیشوند، بررسی میکنند، در حالی که از نسخههای قدیمیتر نیز پشتیبانی میکنند، از APIهای Android استفاده کنید. برای اطلاعات بیشتر در مورد حفظ سازگاری به عقب، پشتیبانی از نسخههای مختلف پلتفرم را بخوانید.
برای اطلاعات بیشتر در مورد نحوه عملکرد سطوح API، سطح API چیست؟
احراز هویت اثر انگشت
این نسخه API های جدیدی را ارائه می دهد تا به شما امکان می دهد با استفاده از اسکن اثر انگشت کاربران در دستگاه های پشتیبانی شده، احراز هویت کاربران را تأیید کنید، از این API ها در ارتباط با سیستم Android Keystore استفاده کنید.
برای احراز هویت کاربران از طریق اسکن اثر انگشت، نمونه ای از کلاس FingerprintManager
جدید را دریافت کرده و متد authenticate()
را فراخوانی کنید. برنامه شما باید روی دستگاهی سازگار با حسگر اثر انگشت اجرا شود. باید رابط کاربری را برای جریان احراز هویت اثر انگشت در برنامه خود پیاده سازی کنید و از نماد استاندارد اثر انگشت اندروید در رابط کاربری خود استفاده کنید. نماد اثر انگشت اندروید ( c_fp_40px.png
) در نمونه احراز هویت بیومتریک گنجانده شده است. اگر در حال توسعه چندین برنامه هستید که از احراز هویت اثر انگشت استفاده می کنند، توجه داشته باشید که هر برنامه باید به طور مستقل اثر انگشت کاربر را تأیید کند.
برای استفاده از این ویژگی در برنامه خود، ابتدا مجوز USE_FINGERPRINT
را در مانیفست خود اضافه کنید.
<uses-permission android:name="android.permission.USE_FINGERPRINT" />
برای مشاهده اجرای برنامه احراز هویت اثر انگشت، به نمونه احراز هویت بیومتریک مراجعه کنید. برای نمایش نحوه استفاده از این APIهای احراز هویت در ارتباط با سایر APIهای Android، به ویدیوی APIهای اثر انگشت و پرداخت مراجعه کنید.
اگر در حال آزمایش این ویژگی هستید، مراحل زیر را دنبال کنید:
- اگر این کار را انجام نداده اید، نسخه 24.3 ابزار اندروید SDK را نصب کنید.
- با رفتن به Settings > Security > Fingerprint، یک اثر انگشت جدید را در شبیه ساز ثبت کنید، سپس دستورالعمل های ثبت نام را دنبال کنید.
- از یک شبیه ساز برای شبیه سازی رویدادهای لمس اثر انگشت با دستور زیر استفاده کنید. از همین فرمان برای شبیه سازی رویدادهای لمس اثر انگشت در صفحه قفل یا در برنامه خود استفاده کنید.
adb -e emu finger touch <finger_id>
در ویندوز، ممکن است مجبور شوید
telnet 127.0.0.1 <emulator-id>
و سپسfinger touch <finger_id>
اجرا کنید.
تایید اعتبار
برنامه شما میتواند کاربران را بر اساس آخرین باری که قفل دستگاه خود را باز کردهاند، احراز هویت کند. این ویژگی کاربران را از به خاطر سپردن گذرواژههای خاص برنامه رها میکند و از نیاز شما به پیادهسازی رابط کاربری احراز هویت خود جلوگیری میکند. برنامه شما باید از این ویژگی همراه با اجرای کلید عمومی یا مخفی برای احراز هویت کاربر استفاده کند.
برای تنظیم مدت زمانی که همان کلید میتواند پس از احراز هویت با موفقیت مجدداً استفاده شود، هنگام تنظیم KeyGenerator
یا KeyPairGenerator
، روش جدید setUserAuthenticationValidityDurationSeconds()
را فراخوانی کنید.
از نشان دادن بیش از حد گفتگوی احراز هویت مجدد خودداری کنید -- برنامه های شما باید ابتدا از شی رمزنگاری استفاده کنند و اگر مهلت زمانی منقضی شد، از روش createConfirmDeviceCredentialIntent()
برای احراز هویت مجدد کاربر در برنامه خود استفاده کنید.
پیوند دادن برنامه
این نسخه سیستم هدف اندروید را با ارائه پیوندهای قدرتمندتر برنامه بهبود می بخشد. این ویژگی به شما امکان می دهد یک برنامه را با دامنه وب خود مرتبط کنید. بر اساس این ارتباط، پلتفرم میتواند برنامه پیشفرض مورد استفاده برای مدیریت یک پیوند وب خاص را تعیین کند و از درخواست کاربران برای انتخاب یک برنامه صرفنظر کند. برای یادگیری نحوه اجرای این ویژگی، به مدیریت پیوندهای برنامه مراجعه کنید.
پشتیبان گیری خودکار برای برنامه ها
اکنون سیستم پشتیبانگیری و بازیابی کامل اطلاعات را برای برنامهها انجام میدهد. برای فعال کردن این رفتار، برنامه شما باید Android 6.0 (سطح API 23) را هدف قرار دهد. شما نیازی به اضافه کردن کد اضافی ندارید. اگر کاربران حساب های گوگل خود را حذف کنند، اطلاعات پشتیبان آنها نیز حذف می شود. برای آشنایی با نحوه عملکرد این ویژگی و نحوه پیکربندی مواردی که در سیستم فایل پشتیبانگیری شود، به پیکربندی پشتیبانگیری خودکار برای برنامهها مراجعه کنید.
اشتراک گذاری مستقیم
این نسخه APIهایی را در اختیار شما قرار می دهد تا اشتراک گذاری را برای کاربران بصری و سریع کند. اکنون می توانید اهداف اشتراک گذاری مستقیمی را تعریف کنید که فعالیت خاصی را در برنامه شما راه اندازی می کند. این اهداف اشتراک مستقیم از طریق منوی اشتراک گذاری در معرض دید کاربران قرار می گیرند. این ویژگی به کاربران اجازه می دهد تا محتوا را با اهدافی مانند مخاطبین در سایر برنامه ها به اشتراک بگذارند. به عنوان مثال، هدف اشتراک گذاری مستقیم ممکن است فعالیتی را در برنامه شبکه اجتماعی دیگری راه اندازی کند، که به کاربر امکان می دهد محتوا را مستقیماً با یک دوست یا انجمن خاص در آن برنامه به اشتراک بگذارد.
برای فعال کردن اهداف اشتراک مستقیم، باید کلاسی را تعریف کنید که کلاس ChooserTargetService
را گسترش دهد. خدمات خود را در مانیفست اعلام کنید. در آن اعلامیه، مجوز BIND_CHOOSER_TARGET_SERVICE
و فیلتر هدف را با استفاده از عملکرد SERVICE_INTERFACE
مشخص کنید.
مثال زیر نشان می دهد که چگونه می توانید ChooserTargetService
در مانیفست خود اعلام کنید.
<service android:name=".ChooserTargetService" android:label="@string/service_name" android:permission="android.permission.BIND_CHOOSER_TARGET_SERVICE"> <intent-filter> <action android:name="android.service.chooser.ChooserTargetService" /> </intent-filter> </service>
برای هر فعالیتی که میخواهید در معرض ChooserTargetService
قرار دهید، یک عنصر <meta-data>
با نام "android.service.chooser.chooser_target_service"
را در مانیفست برنامه خود اضافه کنید.
<activity android:name=".MyShareActivity” android:label="@string/share_activity_label"> <intent-filter> <action android:name="android.intent.action.SEND" /> </intent-filter> <meta-data android:name="android.service.chooser.chooser_target_service" android:value=".ChooserTargetService" /> </activity>
تعاملات صوتی
این نسخه یک API تعامل صوتی جدید ارائه میکند که همراه با Voice Actions به شما امکان میدهد تجربههای صوتی مکالمه را در برنامههای خود ایجاد کنید. متد isVoiceInteraction()
را فراخوانی کنید تا مشخص شود آیا یک عمل صوتی باعث فعال شدن فعالیت شما شده است یا خیر. در این صورت، برنامه شما میتواند از کلاس VoiceInteractor
برای درخواست تأیید صوتی از کاربر، انتخاب از لیست گزینهها و موارد دیگر استفاده کند.
بیشتر تعاملات صوتی از یک کنش صوتی کاربر سرچشمه می گیرد. با این حال، یک فعالیت تعامل صوتی نیز می تواند بدون ورودی کاربر شروع شود. به عنوان مثال، برنامه دیگری که از طریق تعامل صوتی راه اندازی شده است نیز می تواند قصد راه اندازی یک تعامل صوتی را ارسال کند. برای تعیین اینکه آیا فعالیت شما از یک درخواست صوتی کاربر یا از یک برنامه تعامل صوتی دیگر راه اندازی شده است، روش isVoiceInteractionRoot()
را فراخوانی کنید. اگر برنامه دیگری فعالیت شما را راه اندازی کرد، روش false
را برمی گرداند. سپس ممکن است برنامه شما از کاربر بخواهد تا تأیید کند که قصد انجام این کار را داشته است.
برای کسب اطلاعات بیشتر درباره اجرای کنشهای صوتی، به سایت برنامهنویس «کنشهای صوتی» مراجعه کنید.
Assist API
این نسخه راهی جدید برای تعامل کاربران با برنامه های شما از طریق دستیار ارائه می دهد. برای استفاده از این ویژگی، کاربر باید دستیار را فعال کند تا از زمینه فعلی استفاده کند. پس از فعالسازی، کاربر میتواند با فشار طولانی روی دکمه Home ، دستیار را در هر برنامهای احضار کند.
برنامه شما می تواند با تنظیم پرچم FLAG_SECURE
زمینه فعلی را با دستیار به اشتراک نگذارد. علاوه بر مجموعه استاندارد اطلاعاتی که پلتفرم به دستیار ارسال می کند، برنامه شما می تواند با استفاده از کلاس AssistContent
جدید، اطلاعات بیشتری را به اشتراک بگذارد.
برای ارائه زمینه اضافی از برنامه خود به دستیار، این مراحل را دنبال کنید:
- رابط
Application.OnProvideAssistDataListener
پیاده سازی کنید. - این شنونده را با استفاده از
registerOnProvideAssistDataListener()
ثبت کنید. - به منظور ارائه اطلاعات زمینهای خاص فعالیت، فراخوانی
onProvideAssistData()
و به صورت اختیاری، پاسخ تماس جدیدonProvideAssistContent()
را لغو کنید.
دستگاه های ذخیره سازی قابل پذیرش
با استفاده از این نسخه، کاربران می توانند از دستگاه های ذخیره سازی خارجی مانند کارت های SD استفاده کنند . استفاده از یک دستگاه ذخیرهسازی خارجی، دستگاه را رمزگذاری و قالببندی میکند تا مانند حافظه داخلی عمل کند. این ویژگی به کاربران امکان می دهد هم برنامه ها و هم داده های خصوصی آن برنامه ها را بین دستگاه های ذخیره سازی جابجا کنند. هنگام جابجایی برنامه ها، سیستم به اولویت android:installLocation
در مانیفست احترام می گذارد.
اگر برنامه شما به APIها یا فیلدهای زیر دسترسی دارد، توجه داشته باشید که مسیرهای فایلی که آنها برمیگردانند به صورت پویا با جابجایی برنامه بین دستگاههای ذخیرهسازی داخلی و خارجی تغییر میکنند. هنگام ساخت مسیرهای فایل، اکیداً توصیه می شود که همیشه این API ها را به صورت پویا فراخوانی کنید. از مسیرهای فایل هاردکد شده استفاده نکنید یا مسیرهای فایل کاملاً واجد شرایطی را که قبلا ساخته شده اند، ادامه ندهید.
- روش های
Context
: - فیلدهای
ApplicationInfo
:
برای اشکال زدایی این ویژگی، می توانید با اجرای این دستور، پذیرش یک درایو USB را که از طریق کابل USB On-The-Go (OTG) به دستگاه Android متصل است، فعال کنید:
$ adb shell sm set-force-adoptable true
اطلاعیه ها
این نسخه تغییرات API زیر را برای اعلان ها اضافه می کند:
- سطح فیلتر جدید
INTERRUPTION_FILTER_ALARMS
که مربوط به حالت هشدارهای جدید فقط مزاحم نیست. - مقدار جدید دسته
CATEGORY_REMINDER
که برای تشخیص یادآورهای زمانبندی شده توسط کاربر از سایر رویدادها (CATEGORY_EVENT
) و هشدارها (CATEGORY_ALARM
) استفاده میشود. - کلاس
Icon
جدیدی که می توانید از طریق متدهایsetSmallIcon()
وsetLargeIcon()
به اعلان های خود متصل کنید. به طور مشابه، متدaddAction()
اکنون یک شیIcon
را به جای شناسه منبع قابل ترسیم می پذیرد. - متد جدید
getActiveNotifications()
که به برنامههای شما امکان میدهد بفهمند کدام یک از اعلانهایشان در حال حاضر فعال هستند.
پشتیبانی از قلم بلوتوث
این نسخه پشتیبانی بهبود یافته ای را برای ورودی کاربر با استفاده از قلم بلوتوث فراهم می کند. کاربران می توانند یک قلم بلوتوث سازگار را با تلفن یا تبلت خود جفت و وصل کنند. در حین اتصال، اطلاعات موقعیت از صفحه لمسی با اطلاعات فشار و دکمه از قلم ترکیب می شود تا دامنه بیان بیشتری نسبت به صفحه لمسی به تنهایی ارائه دهد. برنامه شما می تواند با ثبت اشیاء View.OnContextClickListener
و GestureDetector.OnContextClickListener
در فعالیت شما، به فشارهای دکمه قلم گوش دهد و اقدامات ثانویه را انجام دهد.
از روشها و ثابتهای MotionEvent
برای تشخیص تعامل دکمههای قلم استفاده کنید:
- اگر کاربر قلمی را با دکمه ای روی صفحه برنامه شما لمس کند، متد
getTooltype()
TOOL_TYPE_STYLUS
را برمی گرداند. - برای برنامههایی که Android 6.0 (سطح API 23) را هدف قرار میدهند، وقتی کاربر دکمه قلم اصلی را فشار میدهد، روش
getButtonState()
BUTTON_STYLUS_PRIMARY
را برمیگرداند. اگر قلم دکمه دومی داشته باشد، وقتی کاربر آن را فشار میدهد، همان روشBUTTON_STYLUS_SECONDARY
را برمیگرداند. اگر کاربر هر دو دکمه را به طور همزمان فشار دهد، روش هر دو مقدار یا با هم (BUTTON_STYLUS_PRIMARY
|BUTTON_STYLUS_SECONDARY
) را برمی گرداند. - برای برنامههایی که نسخه پلتفرم پایینتری را هدف قرار میدهند، روش
getButtonState()
BUTTON_SECONDARY
(برای فشار دادن دکمه قلم اصلی)،BUTTON_TERTIARY
(برای فشار دادن دکمه قلم ثانویه)، یا هر دو را برمیگرداند.
اسکن کم انرژی بلوتوث بهبود یافته است
اگر برنامه شما اسکنهای کم مصرف بلوتوث را انجام میدهد، از روش جدید setCallbackType()
استفاده کنید تا مشخص کنید که میخواهید سیستم در اولین باری که بسته تبلیغاتی منطبق با مجموعه ScanFilter
را پیدا کرد یا بعد از مدتها مشاهده کرد، به تماسها اطلاع دهد. این رویکرد برای اسکن نسبت به آنچه در نسخه پلتفرم قبلی ارائه شده است، کارآمدتر است.
پشتیبانی Hotspot 2.0 Release 1
این نسخه پشتیبانی از مشخصات Hotspot 2.0 Release 1 را در دستگاههای Nexus 6 و Nexus 9 اضافه میکند. برای ارائه اعتبارنامه Hotspot 2.0 در برنامه خود، از روش های جدید کلاس WifiEnterpriseConfig
، مانند setPlmn()
و setRealm()
استفاده کنید. در شیء WifiConfiguration
، می توانید فیلدهای FQDN
و providerFriendlyName
را تنظیم کنید. روش جدید isPasspointNetwork()
نشان می دهد که آیا یک شبکه شناسایی شده یک نقطه دسترسی Hotspot 2.0 را نشان می دهد یا خیر.
حالت نمایش 4K
این پلتفرم اکنون به برنامهها اجازه میدهد تا درخواست کنند که وضوح نمایشگر به رندر 4K بر روی سختافزار سازگار ارتقا یابد. برای جستجو در وضوح فیزیکی فعلی، از APIهای Display.Mode
جدید استفاده کنید. اگر UI با وضوح منطقی پایینتری ترسیم شده و به وضوح فیزیکی بزرگتر ارتقا یافته است، توجه داشته باشید که وضوح فیزیکی که متد getPhysicalWidth()
برمیگرداند ممکن است با وضوح منطقی گزارش شده توسط getSize()
متفاوت باشد.
می توانید با تنظیم ویژگی preferredDisplayModeId
در پنجره برنامه خود، از سیستم درخواست کنید تا وضوح فیزیکی برنامه شما را در حین اجرا تغییر دهد. اگر می خواهید به وضوح صفحه نمایش 4K تغییر دهید، این ویژگی مفید است. در حالی که در حالت نمایش 4K است، رابط کاربری همچنان با وضوح اصلی (مانند 1080p) رندر می شود و به 4K ارتقا می یابد، اما اشیاء SurfaceView
ممکن است محتوا را با وضوح اصلی نشان دهند.
ColorStateLists قابل تم
ویژگیهای تم اکنون در ColorStateList
برای دستگاههای دارای Android نسخه ۶.۰ (سطح API ۲۳) پشتیبانی میشوند. متدهای Resources.getColorStateList()
و Resources.getColor()
منسوخ شده اند. اگر در حال فراخوانی این APIها هستید، به جای آن متدهای جدید Context.getColorStateList()
یا Context.getColor()
را فراخوانی کنید. این روش ها همچنین در کتابخانه appcompat v4 از طریق ContextCompat
در دسترس هستند.
ویژگی های صوتی
این نسخه پیشرفت هایی را به پردازش صدا در اندروید اضافه می کند، از جمله:
- پشتیبانی از پروتکل MIDI ، با API های جدید
android.media.midi
. از این APIها برای ارسال و دریافت رویدادهای MIDI استفاده کنید. - کلاسهای
AudioRecord.Builder
وAudioTrack.Builder
جدید به ترتیب برای ایجاد اشیاء ضبط و پخش صوتی دیجیتال، و پیکربندی ویژگیهای منبع صوتی و سینک برای لغو پیشفرضهای سیستم. - قلاب های API برای ارتباط دستگاه های صوتی و ورودی. این به ویژه در صورتی مفید است که برنامه شما به کاربران اجازه دهد جستجوی صوتی را از کنترلر بازی یا کنترل از راه دور متصل به Android TV شروع کنند. هنگامی که کاربر جستجو را شروع میکند، سیستم، فراخوانی جدید
onSearchRequested()
را فراخوانی میکند. برای تعیین اینکه آیا دستگاه ورودی کاربر دارای یک میکروفون داخلی است، شیInputDevice
را از آن callback بازیابی کنید، سپس متدhasMicrophone()
جدید را فراخوانی کنید. - متد جدید
getDevices()
که به شما امکان می دهد لیستی از تمام دستگاه های صوتی که در حال حاضر به سیستم متصل هستند را بازیابی کنید. همچنین میتوانید یک شیAudioDeviceCallback
را ثبت کنید اگر میخواهید سیستم هنگام اتصال یا قطع شدن یک دستگاه صوتی به برنامه شما اطلاع دهد.
ویژگی های ویدئو
این نسخه قابلیتهای جدیدی را به APIهای پردازش ویدیو اضافه میکند، از جمله:
- کلاس
MediaSync
جدید که به برنامه ها کمک می کند تا به طور همزمان جریان های صوتی و تصویری را ارائه دهند. بافرهای صوتی به صورت غیر مسدود ارسال می شوند و از طریق یک تماس برگشتی بازگردانده می شوند. همچنین از نرخ پخش پویا پشتیبانی می کند. - رویداد جدید
EVENT_SESSION_RECLAIMED
، که نشان میدهد جلسه باز شده توسط برنامه توسط مدیر منبع بازپس گرفته شده است. اگر برنامه شما از جلسات DRM استفاده میکند، باید این رویداد را مدیریت کنید و مطمئن شوید که از جلسه بازیابی شده استفاده نمیکنید. - کد خطای جدید
ERROR_RECLAIMED
، که نشان میدهد مدیر منبع، منبع رسانه مورد استفاده کدک را بازیابی کرده است. با این استثنا، کدک باید آزاد شود، زیرا به حالت ترمینال منتقل شده است. - رابط جدید
getMaxSupportedInstances()
برای دریافت راهنمایی برای حداکثر تعداد نمونه های کدک همزمان پشتیبانی شده. - روش جدید
setPlaybackParams()
برای تنظیم نرخ پخش رسانه برای پخش سریع یا حرکت آهسته. همچنین پخش صدا را به صورت خودکار همراه با ویدیو افزایش می دهد یا سرعت می بخشد.
ویژگی های دوربین
این نسخه شامل APIهای جدید زیر برای دسترسی به چراغ قوه دوربین و برای پردازش مجدد تصاویر دوربین است:
Flashlight API
اگر یک دستگاه دوربین دارای واحد فلاش است، می توانید روش setTorchMode()
را فراخوانی کنید تا بدون باز کردن دستگاه دوربین، حالت مشعل واحد فلاش را روشن یا خاموش کنید. این برنامه مالکیت انحصاری واحد فلاش یا دستگاه دوربین را ندارد. هر زمان که دستگاه دوربین در دسترس نباشد، یا زمانی که سایر منابع دوربین که مشعل را روشن نگه میدارند، حالت مشعل خاموش میشود و از دسترس خارج میشود. سایر برنامه ها همچنین می توانند setTorchMode()
برای خاموش کردن حالت مشعل فراخوانی کنند. وقتی آخرین برنامه ای که حالت مشعل را روشن کرده است بسته شود، حالت مشعل خاموش می شود.
می توانید با فراخوانی متد registerTorchCallback()
یک تماس برگشتی ثبت کنید تا از وضعیت حالت مشعل مطلع شوید. اولین باری که تماس برگشتی ثبت می شود، بلافاصله با وضعیت مشعل تمام دستگاه های دوربین شناخته شده فعلی با یک واحد فلاش فراخوانی می شود. اگر حالت مشعل با موفقیت روشن یا خاموش شود، متد onTorchModeChanged()
فراخوانی می شود.
API پردازش مجدد
Camera2
API برای پشتیبانی از YUV و پردازش مجدد تصویر با فرمت غیر شفاف خصوصی گسترش یافته است. برای تعیین اینکه آیا این قابلیتهای پردازش مجدد در دسترس هستند یا خیر، با getCameraCharacteristics()
تماس بگیرید و کلید REPROCESS_MAX_CAPTURE_STALL
را بررسی کنید. اگر دستگاهی از پردازش مجدد پشتیبانی میکند، میتوانید با فراخوانی createReprocessableCaptureSession()
یک جلسه ضبط مجدد دوربین ایجاد کنید و درخواستهایی برای پردازش مجدد بافر ورودی ایجاد کنید.
از کلاس ImageWriter
برای اتصال جریان بافر ورودی به ورودی پردازش مجدد دوربین استفاده کنید. برای دریافت بافر خالی، از این مدل برنامه نویسی پیروی کنید:
- متد
dequeueInputImage()
فراخوانی کنید. - داده ها را در بافر ورودی پر کنید.
- با فراخوانی متد
queueInputImage()
بافر را به دوربین ارسال کنید.
اگر از یک شی ImageWriter
همراه با یک تصویر PRIVATE
استفاده می کنید، برنامه شما نمی تواند مستقیماً به داده های تصویر دسترسی داشته باشد. در عوض، با فراخوانی متد queueInputImage()
بدون هیچ کپی بافر، تصویر PRIVATE
را مستقیماً به ImageWriter
ارسال کنید.
کلاس ImageReader
اکنون از جریان تصویر با فرمت PRIVATE
پشتیبانی می کند. این پشتیبانی به برنامه شما اجازه می دهد تا یک صف تصویر دایره ای از تصاویر خروجی ImageReader
را حفظ کند، یک یا چند تصویر را انتخاب کند و آنها را برای پردازش مجدد دوربین به ImageWriter
ارسال کند.
ویژگی های Android for Work
این نسخه شامل APIهای جدید زیر برای Android for Work است:
- کنترلهای پیشرفته برای دستگاههای یکبار مصرف متعلق به شرکت: مالک دستگاه اکنون میتواند تنظیمات زیر را برای بهبود مدیریت دستگاههای یکبار مصرف (COSU) کنترل کند:
- صفحه کلید را با متد
setKeyguardDisabled()
غیرفعال یا دوباره فعال کنید. - با روش
setStatusBarDisabled()
نوار وضعیت (از جمله تنظیمات سریع، اعلانها، و حرکت حرکت به سمت بالا که Google Now را راهاندازی میکند) غیرفعال یا دوباره فعال کنید. - بوت ایمن را با ثابت
UserManager
DISALLOW_SAFE_BOOT
غیرفعال یا دوباره فعال کنید. - با ثابت
STAY_ON_WHILE_PLUGGED_IN
از خاموش شدن صفحه هنگام وصل شدن به برق جلوگیری کنید.
- صفحه کلید را با متد
- نصب و حذف بیصدا برنامهها توسط Device Owner: مالک دستگاه اکنون میتواند بدون صدا برنامهها را با استفاده از
PackageInstaller
، مستقل از Google Play for Work نصب و حذف نصب کند. اکنون میتوانید دستگاههایی را از طریق مالک دستگاه تهیه کنید که برنامهها را بدون تعامل کاربر واکشی و نصب میکند. این ویژگی برای فعال کردن ارائه با یک لمس کیوسک ها یا سایر دستگاه های مشابه بدون فعال کردن حساب Google مفید است. - دسترسی به گواهی سازمانی بیصدا: وقتی برنامهای
choosePrivateKeyAlias()
را فراخوانی میکند، قبل از اینکه از کاربر خواسته شود گواهی را انتخاب کند، مالک نمایه یا دستگاه اکنون میتواند متدonChoosePrivateKeyAlias()
را فراخوانی کند تا نام مستعار را بیصدا به برنامه درخواستکننده ارائه دهد. این ویژگی به شما امکان میدهد بدون تعامل کاربر، به برنامههای مدیریتشده اجازه دسترسی به گواهیها را بدهید. - پذیرش خودکار به روز رسانی سیستم. با تنظیم یک خط مشی به روز رسانی سیستم با
setSystemUpdatePolicy()
، صاحب دستگاه می تواند به طور خودکار یک به روز رسانی سیستم را بپذیرد، به عنوان مثال در مورد دستگاه کیوسک، یا به روز رسانی را به تعویق بیاندازد و از گرفتن آن توسط کاربر تا 30 روز جلوگیری کند. . علاوه بر این، یک مدیر میتواند یک پنجره زمانی روزانه را تنظیم کند که در آن بهروزرسانی باید انجام شود، برای مثال در ساعاتی که دستگاه کیوسک استفاده نمیشود. وقتی یک بهروزرسانی سیستم در دسترس است، سیستم بررسی میکند که آیا برنامه کنترلکننده خطمشی دستگاه، خطمشی بهروزرسانی سیستم تنظیم کرده است یا خیر، و مطابق با آن رفتار میکند. - نصب گواهی تفویض شده: یک نمایه یا مالک دستگاه اکنون میتواند به برنامه شخص ثالث توانایی فراخوانی این APIهای مدیریت گواهی
DevicePolicyManager
را بدهد: - ردیابی مصرف داده یک نمایه یا مالک دستگاه اکنون میتواند با استفاده از روشهای جدید
NetworkStatsManager
، آمار مصرف داده قابل مشاهده در تنظیمات > مصرف داده را جستجو کند. به مالکان نمایه به طور خودکار اجازه پرس و جو از داده ها در نمایه ای که مدیریت می کنند داده می شود، در حالی که صاحبان دستگاه به داده های استفاده کاربر اصلی مدیریت شده دسترسی دارند. - مدیریت مجوز زمان اجرا:
یک نمایه یا مالک دستگاه میتواند با استفاده از
setPermissionPolicy()
یک خطمشی مجوز برای تمام درخواستهای زمان اجرا برای همه برنامهها تنظیم کند تا از کاربر بخواهد مجوز را صادر کند یا به طور خودکار مجوز را بیصدا اعطا یا رد کند. اگر خطمشی دوم تنظیم شده باشد، کاربر نمیتواند انتخابی را که نمایه یا مالک دستگاه در صفحه مجوزهای برنامه در تنظیمات انجام داده است، تغییر دهد. - VPN در تنظیمات: برنامههای VPN اکنون در تنظیمات > بیشتر > VPN قابل مشاهده هستند. علاوه بر این، اعلانهایی که با استفاده از VPN همراه هستند، اکنون به نحوه پیکربندی آن VPN اختصاص دارند. برای مالک نمایه، اعلانها مختص این است که آیا VPN برای یک نمایه مدیریت شده، یک نمایه شخصی یا هر دو پیکربندی شده است. برای یک صاحب دستگاه، اعلانها به این موضوع اختصاص دارد که آیا VPN برای کل دستگاه پیکربندی شده است یا خیر.
- اعلان وضعیت کار: اکنون هر زمان که برنامه ای از نمایه مدیریت شده فعالیتی در پیش زمینه داشته باشد، نماد کیف نوار وضعیت ظاهر می شود. علاوه بر این، اگر قفل دستگاه مستقیماً به فعالیت یک برنامه در نمایه مدیریت شده باز شود، یک نان تست نمایش داده می شود که به کاربر اطلاع می دهد که در نمایه کاری است.