واجهات برمجة تطبيقات Android 4.1

مستوى واجهة برمجة التطبيقات: 16

Android 4.1 (JELLY_BEAN) هو تطور النظام الأساسي الذي يقدم الأداء وتجربة المستخدم المحسّنة. تضيف ميزات جديدة للمستخدمين والتطبيق المطورين. يقدم هذا المستند مقدمة إلى أهم واجهات برمجة تطبيقات جديدة ومفيدة لمطوري التطبيقات.

وبصفتك مطوّر تطبيقات، يتوفر لك Android 4.1 بدءًا من مدير حزمة تطوير البرامج (SDK) كصورة نظام يمكنك التي تعمل في محاكي Android وفي نظام SDK الأساسي الذي يمكنك من خلاله إنشاء التطبيق. عليك لتنزيل صورة النظام والنظام الأساسي في أقرب وقت ممكن لإنشاء واختبار تطبيقك على Android 4.1.

لتحسين تطبيقك بشكل أفضل على الأجهزة التي تعمل بنظام التشغيل Android 4.1، يجب ضبط targetSdkVersion على "16"، ثبِّته على نسخة نظام Android 4.1، واختباره، ثم نشر تحديث يتضمّن هذا التغيير

إِنْتَ استخدام واجهات برمجة التطبيقات في الإصدار 4.1 من نظام التشغيل Android مع دعم الإصدارات الأقدم أيضًا من خلال إضافة الشروط إلى الرمز البرمجي الذي يتحقّق من مستوى واجهة برمجة تطبيقات النظام قبل التنفيذ واجهات برمجة التطبيقات غير متوافقة مع minSdkVersion. لمزيد من المعلومات حول الحفاظ على التوافق مع الأنظمة القديمة، اقرأ إنشاء متوافقة مع الإصدارات القديمة واجهات المستخدم:

يتوفّر مزيد من المعلومات حول طريقة عمل مستويات واجهة برمجة التطبيقات في مقالة ما هي واجهة برمجة التطبيقات؟ ما هو المستوى؟

مكونات التطبيق

الخدمات المعزولة

من خلال تحديد android:isolatedProcess="true" في علامة <service>، سيتم تشغيل Service ضمن عملية رقم تعريف المستخدم المعزولة الخاصة بها والتي لا تتضمن أذونات خاصة بها.

إدارة الذاكرة

تكون ثوابت ComponentCallbacks2 الجديدة، مثل TRIM_MEMORY_RUNNING_LOW وTRIM_MEMORY_RUNNING_CRITICAL، مقدّمة معالجة المزيد من المعلومات حول حالة الذاكرة قبل استدعاء النظام onLowMemory().

تتيح لك طريقة getMyMemoryState(ActivityManager.RunningAppProcessInfo) الجديدة ما يلي: لاسترداد حالة الذاكرة العامة.

موفّرو المحتوى

تتيح لك طريقة جديدة، acquireUnstableContentProviderClient()، الوصول إلى ContentProviderClient قد يكون "غير ثابت". بحيث لا يتعطّل التطبيق إذا يفعله موفر المحتوى. وهي مفيدة عندما تتفاعل مع مقدمي المحتوى في موقع منفصل، التطبيق.

خلفيات متحركة

بروتوكول intent جديد لتشغيل نشاط معاينة الخلفية المتحركة مباشرةً لمساعدتك في المساعدة يمكن للمستخدمين اختيار خلفيتك المتحركة بسهولة دون إجبارهم على المغادرة تطبيقك والانتقال من خلال منتقي خلفية الشاشة الرئيسية.

لتشغيل "أداة اختيار الخلفيات المتحركة"، اتّصِل بـ startActivity() من خلال Intent باستخدام ACTION_CHANGE_LIVE_WALLPAPER وعنصر إضافي تحدد الخلفية المتحركة ComponentName كسلسلة في EXTRA_LIVE_WALLPAPER_COMPONENT.

التنقّل في حِزم التطبيقات

يسهّل Android 4.1 تنفيذ أنماط التصميم المناسبة للتنقل للأعلى. ما عليك سوى إضافة android:parentActivityName إلى كل عنصر <activity> في ملف البيان. يستخدم النظام هذه المعلومات لفتح النشاط المناسب عندما يكون المستخدم يضغط على الزر لأعلى في شريط الإجراءات (أثناء إنهاء النشاط الحالي أيضًا). لذلك إذا تعريف android:parentActivityName لكل نشاط، ولن تحتاج إلى طريقة onOptionsItemSelected() للتعامل مع النقرات الأحداث الموجودة على رمز تطبيق شريط الإجراءات، وسيعالج النظام الآن هذا الحدث ويستأنف أو وينشئ النشاط المناسب.

ويُعدّ هذا الإجراء فعّالاً على وجه الخصوص في الحالات التي يدخل فيها المستخدم أحد أنشطة تطبيقك. "مراجعة تفصيلية" عن طريق الخطأ من إشعار أو غرض من تطبيق مختلف (كما هو موضح في دليل التصميم للتنقل بين التطبيقات). فعندما إذا أدخل المستخدم نشاطك بهذه الطريقة، فقد لا يحتوي تطبيقك بطبيعة الحال على حزمة خلفية من الأنشطة التي يمكن استئنافها أثناء انتقال المستخدم لأعلى. ومع ذلك، عند تقديم السمة android:parentActivityName لأنشطتك، يتعرّف النظام على ما إذا كان تطبيقك يحتوي حاليًا على حزمة خلفية للأنشطة الرئيسية أم لا، وإذا لم يكن كذلك، بُنى كيس خلفية اصطناعية تحتوي على كل الأنشطة الرئيسية.

ملاحظة: عندما يدخل المستخدم نشاطًا عميقًا في تطبيقك سيؤدي ذلك إلى إنشاء مهمة جديدة لتطبيقك، وسيدرج النظام مجموعة من الأنشطة الرئيسية في المهمة. وعلى هذا النحو، يؤدي الضغط على الزر "رجوع" أيضًا إلى الانتقال مرة أخرى عبر حزمة الوحدة الرئيسية والأنشطة السابقة.

عندما ينشئ النظام حزمة خلفية اصطناعية لتطبيقك، فإنه ينشئ Intent أساسية لإنشاء مثيل جديد لكل نشاط رئيسي. لذلك لا توجد المحفوظة للأنشطة الرئيسية بالطريقة التي كنت تتوقعها إذا تنقّل المستخدم بشكل طبيعي خلال لكل نشاط. إذا كان أي من الأنشطة الرئيسية يعرض عادةً واجهة مستخدم تعتمد على سياق المستخدم، فإن معلومات السياق ستكون مفقودة ويجب عليك تقديمها عند مستخدم ينتقل مرة أخرى من خلال المكدس. على سبيل المثال، إذا كان المستخدم يعرض ألبومًا في أحد تطبيقات الموسيقى، فإن التنقل لأعلى قد يؤدي إلى الانتقال إلى نشاط يسرد جميع الألبومات في قائمة نوع الموسيقى. في هذه الحالة، إذا كان يجب إنشاء الحزمة، يجب إبلاغ المؤسسة الرئيسية. كما يمكن تحديد النوع الذي ينتمي إليه الألبوم الحالي بحيث يمكن للوالدَين عرض القائمة المناسبة ما إذا كان المستخدم قد أتى من هذا النشاط لتقديم هذه المعلومات إلى أحد الوالدَين الاصطناعيين نشاطك، يجب إلغاء طريقة onPrepareNavigateUpTaskStack(). هذا النمط يزوّدك عنصر TaskStackBuilder الذي أنشأه النظام من أجل تجميع الأنشطة الرئيسية. يحتوي TaskStackBuilder على عناصر Intent يستخدمها النظام لإنشاء كل نشاط رئيسي. في تنفيذ onPrepareNavigateUpTaskStack()، يمكنك تعديل Intent المناسب إضافة بيانات إضافية يمكن للنشاط الأصلي استخدامها لتحديد السياق المناسب وعرضها واجهة المستخدم المناسبة.

عندما ينشئ النظام TaskStackBuilder، فإنّه يضيف عناصر Intent التي يتم استخدامها لإنشاء الأنشطة الرئيسية بترتيبها المنطقي. ترتيبًا بدءًا من أعلى شجرة النشاط. وبالتالي، فإن آخر Intent تمت إضافته إلى الصفيف الداخلي هو الأصل المباشر للنشاط الحالي. في حال حذف كنت تريد تعديل Intent للعنصر الرئيسي للنشاط، عليك أولاً تحديد طول الصفيفة مع getIntentCount() وتمرير ذلك إلى editIntentAt().

إذا كانت بنية تطبيقك أكثر تعقيدًا، فهناك العديد من واجهات برمجة التطبيقات الأخرى المتاحة التي تسمح لك بمعالجة سلوك التنقل لأعلى تخصيص حقيبة الظهر الاصطناعية بالكامل بعض واجهات برمجة التطبيقات التي توفر لك تشمل التحكم ما يلي:

onNavigateUp()
يمكنك إلغاء هذا الإعداد لتنفيذ إجراء مخصّص عندما يضغط المستخدم على الزرّ للأعلى.
navigateUpTo(Intent)
يمكنك الاتصال بهذا الخيار لإنهاء النشاط الحالي والانتقال إلى النشاط المشار إليه في تم توفيره في Intent. إذا كان النشاط موجودًا في الحزمة الخلفية، ولكن ليس الأقرب من الوالدين، فإن جميع الأنشطة الأخرى بين النشاط الحالي النشاط المحدد بقصد الانتهاء أيضًا.
getParentActivityIntent()
استدعِ هذا الأمر للحصول على Intent الذي يبدأ القيمة المنطقية النشاط الحالي.
shouldUpRecreateTask(Intent)
يمكنك استدعاء هذا الإجراء للاستفسار عما إذا كان يجب إنشاء حزمة خلفية اصطناعية للتنقل لأعلى. تعرض القيمة "صحيح" إذا كان يجب إنشاء حزمة اصطناعية، وتعرض القيمة "خطأ" إذا كانت الحزمة المناسبة موجودة سلفًا.
finishAffinity()
يمكنك الاتصال بهذا العنصر لإنهاء النشاط الحالي وجميع الأنشطة الرئيسية بنفسه تقارب المهمة المرتبطة بالنشاط الحالي. فإذا تم إلغاء السلوكيات الافتراضية مثل onNavigateUp()، يجب استدعاء هذه الطريقة عند إنشاء حزمة خلفية اصطناعية عند التنقل للأعلى.
onCreateNavigateUpTaskStack
يمكنك إلغاء هذا إذا كنت بحاجة إلى التحكّم الكامل في كيفية إنشاء حزمة المهام الاصطناعية. إذا كنت تريد إضافة بعض البيانات الإضافية إلى أهداف حزمة الظهر، عليك بدلاً من ذلك إلغاء onPrepareNavigateUpTaskStack().

ومع ذلك، لا تحتاج معظم التطبيقات إلى استخدام واجهات برمجة التطبيقات هذه أو تنفيذ onPrepareNavigateUpTaskStack()، ولكن يمكنها تحقيق السلوك الصحيح ببساطة من خلال إضافة android:parentActivityName إلى كل عنصر في <activity>

وسائط متعددة

برامج ترميز الوسائط

توفّر الفئة MediaCodec إمكانية الوصول إلى برامج ترميز الوسائط المنخفضة المستوى لإجراء الترميز. وفك ترميز الوسائط الخاصة بك يمكنك إنشاء مثيل MediaCodec عن طريق إرسال طلب إلى createEncoderByType() لترميز الوسائط أو الاتصال بـ createDecoderByType() لفك ترميز الوسائط. كل من هذه تأخذ الطريقتان نوع MIME لنوع الوسائط التي تريد ترميزها أو فك ترميزها، مثل "video/3gpp" أو "audio/vorbis".

عند إنشاء مثيل MediaCodec، يمكنك عندئذٍ استدعاء configure() لتحديد الخصائص مثل تنسيق الوسائط أو ما إذا كان المحتوى مشفّرًا أم لا.

سواء كنت تقوم بترميز الوسائط أو فك تشفيرها، فإن باقي العملية تبقى كما هي بعد لإنشاء MediaCodec. عليك استدعاء getInputBuffers() أولاً للحصول على مصفوفة إدخال ByteBuffer. وgetOutputBuffers() للحصول على صفيف من كائنات ByteBuffer للمخرجات.

عندما تكون جاهزًا لترميز أو فك الترميز، اطلب dequeueInputBuffer() للحصول على موضع الفهرس في ByteBuffer (من مصفوفة المخازن المؤقتة للإدخالات) الذي يجب استخدامه في الخلاصة في المصدر. الوسائط. بعد ملء ByteBuffer بالوسائط المصدر، عليك سحب الملكية. للمخزن المؤقت عن طريق طلب queueInputBuffer().

على نحو مماثل للمخزن المؤقت للمخرجات، يمكنك استدعاء الدالة dequeueOutputBuffer() للحصول على موضع الفهرس في ByteBuffer. حيث ستتلقى النتائج. بعد قراءة الناتج من ByteBuffer، التنازل عن الملكية من خلال الاتصال بـ releaseOutputBuffer().

ويمكنك التعامل مع بيانات الوسائط المشفّرة في برامج الترميز من خلال طلب الرقم queueSecureInputBuffer() جنبًا إلى جنب مع واجهات برمجة تطبيقات MediaCrypto بدلاً من queueInputBuffer() العادية.

لمزيد من المعلومات حول كيفية استخدام برامج الترميز، يُرجى الاطّلاع على مستندات MediaCodec.

تسجيل الصوت عند إشارة المرور

الطريقة الجديدة التي يسمح بها startRecording() عليك بدء التسجيل الصوتي بناءً على إشارة يتم تحديدها بواسطة MediaSyncEvent. يحدّد MediaSyncEvent جلسة صوتية. (مثل تلك المحددة من خلال MediaPlayer)، والتي عند اكتمالها، يتم تشغيلها مسجل الصوت لبدء التسجيل. على سبيل المثال، يمكنك استخدام هذه الوظيفة تشغيل نغمة صوتية تشير إلى بداية جلسة التسجيل والتسجيل تلقائيًا بحيث لا تضطر إلى مزامنة النغمة وبداية التسجيل.

المقاطع الصوتية النصية المحددة بوقت

يتعامل MediaPlayer الآن مع المقاطع الصوتية النصية داخل النطاق وخارجه. تتوفر المسارات النصية ضمن النطاق كمسار نصي ضمن مصدر وسائط بتنسيق MP4 أو 3GPP. النص خارج الإطار يمكن إضافة المقاطع الصوتية كمصدر نص خارجي باستخدام طريقة addTimedTextSource(). بعد كل النص الخارجي مصادر التتبع، يجب استدعاء getTrackInfo() للحصول على قائمة جديدة تضم جميع قنوات الإصدار المتاحة في مصدر بيانات

لضبط المقطع الصوتي للاستخدام مع MediaPlayer، يجب عليك طلب selectTrack()، باستخدام الفهرس موضع المقطع الصوتي الذي تريد استخدامه.

ليتم إشعارك عندما يكون المقطع النصي جاهزًا للتشغيل، عليك تنفيذ واجهة وتمريرة "MediaPlayer.OnTimedTextListener" إلى setOnTimedTextListener().

تأثيرات الصوت

تتيح الفئة "AudioEffect" الآن المحتوى الصوتي الإضافي. أنواع المعالجة المسبقة عند التقاط الصوت:

  • وحدة إلغاء صدى الصوت (AEC) مع "AcousticEchoCanceler" إزالة مساهمة الإشارة المُستلَمة من الطرف البعيد من الإشارة الصوتية التي تم التقاطها.
  • التحكّم التلقائي في الاكتساب (AGC) باستخدام AutomaticGainControl تعمل تلقائيًا على تسوية مخرجات الإشارة التي تم التقاطها.
  • كتم الضوضاء (NS) مع "NoiseSuppressor" لإزالة ضوضاء الخلفية من الإشارة التي تم التقاطها.

يمكنك تطبيق هذه التأثيرات الصوتية التي تمت معالجتها مسبقًا على الصوت الذي تم تسجيله باستخدام AudioRecord باستخدام إحدى AudioEffect. والفئات الفرعية.

ملاحظة: لا يمكن ضمان توفّر هذه الميزات على جميع الأجهزة. عليك، لذا يجب دائمًا التحقق أولاً من مدى التوفّر من خلال طلب الرقم isAvailable() على فئة التأثيرات الصوتية.

تشغيل بدون فجوات

يمكنك الآن تشغيل المحتوى بدون أي أجزاء بين شاشتَين منفصلتَين. MediaPlayer عناصر وفي أي وقت قبل انتهاء أول MediaPlayer، الاتصال بـ setNextMediaPlayer() وAndroid محاولة تشغيل اللاعب الثاني عند توقف اللاعب الأول.

جهاز توجيه الوسائط. توفر واجهات برمجة التطبيقات MediaRouter وMediaRouteActionProvider وMediaRouteButton الجديدة. والآليات القياسية وواجهة المستخدم لاختيار مكان تشغيل الوسائط.

الكاميرا

حركة التركيز التلقائي

تتيح لك الواجهة الجديدة "Camera.AutoFocusMoveCallback" الاستماع إلى الموسيقى لإجراء تغييرات على حركة التركيز التلقائي. يمكنك تسجيل واجهتك في setAutoFocusMoveCallback(). ثم عندما تنظر الكاميرا في وضع التركيز التلقائي المستمر (FOCUS_MODE_CONTINUOUS_VIDEO أو FOCUS_MODE_CONTINUOUS_PICTURE)، ستصلك مكالمة. إلى onAutoFocusMoving()، التي تخبرك ما إذا كان التركيز التلقائي قد بدأ في التحرك أو توقف عن الحركة.

أصوات الكاميرا

توفّر الفئة MediaActionSound مجموعة بسيطة من واجهات برمجة التطبيقات لإنشاء الأصوات العادية التي تصدرها الكاميرا أو إجراءات الوسائط الأخرى. يجب استخدام واجهات برمجة التطبيقات هذه لتشغيل الصوت المناسب عند إنشاء كاميرا ثابتة أو كاميرا فيديو مخصصة.

لتشغيل صوت، ما عليك سوى إنشاء مثيل كائن "MediaActionSound" ثم طلب load() لتحميل الصوت المطلوب مسبقًا، ثم الانتقال إلى في الوقت المناسب، اتصل بـ play().

إمكانية الاتصال

شعاع Android

يدعم شعاع Android الآن عمليات نقل الحمولات الكبيرة عبر البلوتوث. عندما تقوم بتعريف البيانات لنقله مع تطبيق "setBeamPushUris()" الجديد الطريقة أو واجهة معاودة الاتصال الجديدة NfcAdapter.CreateBeamUrisCallback، Android تسليم عملية نقل البيانات إلى البلوتوث أو أي وسيلة نقل بديلة أخرى تحقيق سرعات نقل أعلى هذا مفيد بشكل خاص للحمولات الكبيرة مثل الصور الملفات الصوتية ولا تتطلب إقرانًا مرئيًا بين الأجهزة. ليس هناك حاجة إلى أي عمل إضافي بحلول تطبيقك بالاستفادة من عمليات النقل عبر البلوتوث.

تستخدم الطريقة setBeamPushUris() صفيفًا من Uri عناصر تحدِّد البيانات التي تريد نقلها من تطبيقك. أو يمكنك تنفيذ NfcAdapter.CreateBeamUrisCallback التي يمكنك تحديدها لنشاطك من خلال طلب الرقم setBeamPushUrisCallback().

عند استخدام في واجهة معاودة الاتصال، يستدعي النظام طريقة createBeamUris() للواجهة عند ينفِّذ المستخدم عملية مشاركة باستخدام شعاع Android حتى تتمكن من تحديد معرفات الموارد المنتظمة (URI) التي يجب مشاركتها في وقت المشاركة. يكون هذا مفيدًا إذا كانت معرفات الموارد المنتظمة (URI) المطلوب مشاركتها قد تختلف بناءً على سياق المستخدم داخل نشاط، بينما الاتصال بـ setBeamPushUris() عندما تكون معرّفات الموارد المنتظمة (URI) المطلوب مشاركتها غير متغيرة، ويمكنك تحديدها مسبقًا بأمان.

اكتشاف خدمة الشبكة

يتيح الإصدار Android 4.1 إمكانية اكتشاف الخدمات المستندة إلى نظام أسماء النطاقات ذي البث المتعدد، ما يتيح لك البحث عن الخدمات المقدمة من الأجهزة المشابهة والاتصال بها عبر شبكة Wi-Fi، مثل الأجهزة الجوّالة الطابعات والكاميرات ومشغّلات الوسائط وغيرها من الأجهزة المسجلة على الشبكة المحلية.

تحتوي الحزمة الجديدة android.net.nsd على واجهات برمجة التطبيقات الجديدة التي تتيح لك وبث خدماتك على الشبكة المحلية واكتشاف الأجهزة المحلية على الشبكة وتوصيلها بالأجهزة.

لتسجيل خدمتك، يجب أولاً إنشاء NsdServiceInfo. المستخدم وتحديد الخصائص المختلفة لخدمتك باستخدام طرق مثل setServiceName(), setServiceType()، setPort()

بعد ذلك، عليك تنفيذ NsdManager.RegistrationListener. وأرسِله إلى registerService() من خلال NsdServiceInfo.

لاكتشاف الخدمات على الشبكة، نفِّذ NsdManager.DiscoveryListener ومرِّره إلى discoverServices().

عندما يتلقّى جهاز "NsdManager.DiscoveryListener" معاودة الاتصال بشأن الخدمات عليك حل الخدمة من خلال الاتصال resolveService()، تمريره تنفيذ NsdManager.ResolveListener التي تتلقى عنصر NsdServiceInfo يحتوي على معلومات حول خدمة جديدة، مما يسمح لك ببدء الاتصال.

اكتشاف خدمة Wi-Fi P2P

تم تحسين واجهات برمجة تطبيقات Wi-Fi P2P في الإصدار 4.1 من نظام التشغيل Android لدعم اكتشاف خدمة ما قبل الربط في WifiP2pManager. يتيح لك ذلك اكتشاف الأماكن القريبة منك وفلترتها الأجهزة من خلال خدمات تستخدم اتصال Wi-Fi من نظير لنظير (P2P) قبل الاتصال بأحد الأجهزة، في حين تستخدم خدمة الشبكة تسمح لك ميزة "الاكتشاف" باكتشاف خدمة على إحدى الشبكات الحالية المتصلة (مثل شبكة Wi-Fi محلية). شبكة).

لبثّ تطبيقك كخدمة عبر Wi-Fi حتى تتمكّن الأجهزة الأخرى من اكتشافه تطبيقك وربطه به، أو الاتصال بـ addLocalService() من خلال عنصر واحد (WifiP2pServiceInfo) يصف خدمات تطبيقك.

لبدء اكتشاف الأجهزة المجاورة عبر Wi-Fi، يجب أولاً أن تقرر ما إذا كنت والتواصل باستخدام Bonjour أو Upnp. لاستخدام Bonjour، قم أولاً بإعداد بعض مستمعي معاودة الاتصال باستخدام setDnsSdResponseListeners()، والذي يأخذ كلاً من WifiP2pManager.DnsSdServiceResponseListener وWifiP2pManager.DnsSdTxtRecordListener. لاستخدام Upnp، عليك إجراء مكالمة setUpnpServiceResponseListener()، ويستغرق WifiP2pManager.UpnpServiceResponseListener.

قبل بدء استكشاف الخدمات على الأجهزة المحلية، يجب أيضًا الاتصال بـ addServiceRequest(). عندما تتلقّى قيمة WifiP2pManager.ActionListener التي تنقلها إلى هذه الطريقة يمكنك عندئذٍ البدء في اكتشاف الخدمات على الأجهزة المحلية من خلال الاتصال بالرقم discoverServices().

عندما يتم العثور على الخدمات المحلّية، ستتلقى معاودة الاتصال إما على WifiP2pManager.DnsSdServiceResponseListener أو WifiP2pManager.UpnpServiceResponseListener، ويتوقف ذلك على ما إذا كنت المسجلين لاستخدام Bonjour أو Upnp. تحتوي معاودة الاتصال المستلمة في كلتا الحالتين على عنصر WifiP2pDevice يمثّل الجهاز النظير.

بيانات استخدام الشبكة

تتيح لك الطريقة الجديدة isActiveNetworkMetered() التحقق مما إذا كان الجهاز متصلاً حاليًا بشبكة تفرض تكلفة استخدام. من خلال تحديد هذه الحالة قبل إجراء معاملات مكثفة للشبكة، يمكنك المساعدة في إدارة استخدام البيانات التي قد تكلف المستخدمين أموالاً وتحقيق اتخاذ قرارات مدروسة بشأن ما إذا كان سيتم إجراء المعاملات الآن أو لاحقًا (على سبيل المثال، عندما اتصال الجهاز بشبكة Wi-Fi).

تسهيل الاستخدام

واجهات برمجة التطبيقات لخدمات تسهيل الاستخدام

زادت بشكل كبير من مدى وصول واجهات برمجة التطبيقات لخدمات تسهيل الاستخدام في Android 4.1. الآن السماح لك بإنشاء خدمات تراقب وتستجيب للمزيد من أحداث الإدخال، مثل الإيماءات المعقّدة باستخدام onGesture() وأدوات أخرى إدخال الأحداث من خلال الإضافات إلى الفئات AccessibilityEvent وAccessibilityNodeInfo وAccessibilityRecord.

يمكن لخدمات تسهيل الاستخدام أيضًا تنفيذ إجراءات نيابةً عن المستخدم، بما في ذلك النقر على التنقّل والتنقل بين النصوص باستخدام performAction وsetMovementGranularities الطريقة performGlobalAction() تسمح أيضًا للخدمات بتنفيذ إجراءات مثل "الرجوع" و"الصفحة الرئيسية" وفتح "الرسائل الأخيرة". التطبيقات والإشعارات.

التنقل القابل للتخصيص داخل التطبيق

عند إنشاء تطبيق Android، يمكنك الآن تخصيص مخططات التنقل من خلال العثور على عناصر يمكن التركيز عليها العناصر وعناصر الإدخال المصغّرة باستخدام findFocus() وfocusSearch()، وضبط التركيز باستخدام setAccessibilityFocused().

تطبيقات مصغّرة أكثر سهولة في الاستخدام

وتتيح لك فئة android.view.accessibility.AccessibilityNodeProvider الجديدة ما يلي: تظهر طرق عرض مخصصة معقدة لخدمات إمكانية الوصول حتى تتمكن من تقديم المعلومات في وأكثر سهولة في الوصول إليها. يتيح android.view.accessibility.AccessibilityNodeProvider للمستخدم. محتوى متقدم مثل شبكة التقويم، لتقديم بنية دلالية منطقية خدمات إمكانية الوصول المنفصلة تمامًا عن هيكل تخطيط الأداة. هذا الدلالي هيكلية الوصول لخدمات تسهيل الاستخدام تقديم نموذج تفاعل أكثر فائدة للمستخدمين ضعف البصر.

نسخ ولصق

النسخ واللصق باستخدام عناصر intent

يمكنك الآن ربط كائن ClipData بالعنصر Intent باستخدام الطريقة setClipData(). ويمكن الاستفادة من ذلك بشكل خاص عند استخدام intent لنقل معرّفات موارد منتظمة (URI) متعدّدة content: إلى عنوان آخر. التطبيق، مثلاً عند مشاركة مستندات متعددة. معرّفات الموارد المنتظِمة content: المقدّمة ستحترم هذه الطريقة أيضًا علامات intent لتوفير إمكانية الوصول للقراءة أو الكتابة، ما يسمح لك بمنح الوصول إلى معرفات موارد منتظمة (URI) متعددة لغرض معين. عند بدء intent في ACTION_SEND أو ACTION_SEND_MULTIPLE، تصبح معرّفات الموارد المنتظِمة (URI) المُقدّمة في intent الآن. تلقائيًا إلى ClipData بحيث يمكن للمستلم إذن الوصول الممنوح لهم.

دعم أنماط HTML وأنماط السلاسل

تدعم الفئة ClipData الآن النصوص ذات النمط (إما كـ HTML أو بنمط Android السلاسل). يمكنك إضافة نص نمط HTML إلى ClipData باستخدام newHtmlText().

نص Renderscript

تم تحسين وظيفة احتساب Renderscript باستخدام الميزات التالية:

  • دعم نواة متعددة في نص برمجي واحد
  • إتاحة القراءة من التخصيص باستخدام العيّنات المفلتَرة من الحوسبة في واجهة برمجة تطبيقات جديدة للنص البرمجي rsSample
  • إتاحة مستويات مختلفة من دقة FP في #pragma
  • إتاحة الاستعلام عن معلومات إضافية من كائنات RS من نص برمجي للحوسبة.
  • تحسينات عديدة على الأداء.

كما تتوفر طرق براغا جديدة لتحديد دقة النقطة العائمة التي يتطلبها حوسبة العروض. يتيح لك هذا تفعيل العمليات المشابهة لـ NEON مثل عمليات حسابية المتجهات السريعة على مسار وحدة المعالجة المركزية (CPU)، ما لم يكن ذلك ممكنًا باستخدام معيار IEEE 754-2008 الكامل.

ملاحظة: أصبح محرك رسومات Renderscript التجريبي متاحًا الآن. نهائيًا.

Animation

الصور المتحركة لبدء النشاط

يمكنك الآن تشغيل Activity باستخدام الصور المتحركة للتكبير أو التصغير أو الرسوم المتحركة المخصصة لديك. لتحديد الحركة التي تريدها، استخدِم واجهات برمجة تطبيقات ActivityOptions لإنشاء Bundle يمكنك استخدامه. ثم تمريرها إلى أي من طرق تؤدّي إلى بدء نشاط، مثل startActivity().

تتضمّن الفئة ActivityOptions طريقة مختلفة لكل فئة. نوع الرسوم المتحركة الذي تريد عرضه عندما يفتح نشاطك:

makeScaleUpAnimation()
ينشئ رسمًا متحركًا يزيد حجم نافذة النشاط من بداية محددة الموضع على الشاشة وحجم بداية محدد. على سبيل المثال، الشاشة الرئيسية في ويستخدم Android 4.1 هذه الميزة عند فتح أحد التطبيقات.
makeThumbnailScaleUpAnimation()
ينشئ رسمًا متحركًا يزيد حجم نافذة النشاط بدءًا من نافذة محددة موضع الإعلان وصورة مصغّرة مقدمة. على سبيل المثال، تظهر نافذة "التطبيقات الأخيرة" في ويستخدم Android 4.1 هذه الميزة عند الرجوع إلى أحد التطبيقات.
makeCustomAnimation()
يتم إنشاء صورة متحركة يتم تحديدها حسب مواردك الخاصة، أي صورة متحركة يتم من خلالها تحديد الحركة فتح النشاط وآخر للنشاط الذي تم إيقافه.

أخصائي صور متحركة للوقت

يوفّر TimeAnimator الجديد معاودة اتصال بسيطة آلية مع TimeAnimator.TimeListener لإرسال الإشعارات عند كل إطار من الرسوم المتحركة. ما مِن مدة أو إكمال أو إعداد لقيمة العنصر في أداة الصور المتحركة هذه. تتلقى معاودة الاتصال بالمستمِع معلومات عن كل إطار بما في ذلك إجمالي الوقت المنقضي والوقت المنقضي منذ إطار الرسوم المتحركة السابق.

واجهة المستخدم

الإشعارات

في Android 4.1، يمكنك إنشاء إشعارات بمناطق محتوى أكبر أو معاينات للصور الكبيرة وأزرار إجراءات متعددة وأولوية قابلة للتهيئة.

أنماط الإشعارات

تتيح لك الطريقة الجديدة setStyle() تحديد وهو واحد من ثلاثة أنماط جديدة لإشعارك بأنّ كل نمط يوفّر منطقة محتوى أكبر. إلى لتحديد نمط منطقة المحتوى الكبيرة، اضغط setStyle() على أحد الكائنات التالية:

Notification.BigPictureStyle
الإشعارات التي تتضمّن مرفق صورة كبيرًا
Notification.BigTextStyle
للإشعارات التي تتضمّن الكثير من النصوص، مثلاً رسالة إلكترونية واحدة
Notification.InboxStyle
للإشعارات التي تتضمّن قائمة بالسلاسل، مثل مقتطفات من رسائل إلكترونية متعددة
إجراءات الإشعارات

يتوفر الآن ما يصل إلى زري إجراءات يظهران في أسفل لمعرفة ما إذا كان الإشعار يستخدم النمط العادي أو الأكبر.

لإضافة زر إجراء، يمكنك الاتصال بالرقم addAction(). تستخدم هذه الطريقة ثلاث وسيطات: مورد قابل للرسم للأيقونة، ونص الزر وPendingIntent الذي يحدد الإجراء إلى لكلمن.

الأولويات

يمكنك الآن إعلام النظام بمدى أهمية تأثير الإشعار في ترتيب الإشعار في القائمة من خلال الإعداد الأولوية مع setPriority(). إِنْتَ يمكن أن يجتاز هذا المستوى أحد مستويات الأولوية الخمسة المختلفة المحددة بواسطة PRIORITY_* ثوابت. في الصف Notification. الإعداد التلقائي هو PRIORITY_DEFAULT، وهناك مستويان أعلى ومستويان أقل.

الإشعارات ذات الأولوية العالية هي الأشياء التي يرغب المستخدمون بشكل عام في الرد عليها بسرعة، مثل رسالة فورية جديدة أو رسالة نصية جديدة أو تذكير بحدث وشيك. أولوية منخفضة الإشعارات هي أشياء مثل أحداث التقويم المنتهية الصلاحية أو العروض الترويجية للتطبيقات.

عناصر التحكُّم في واجهة مستخدم النظام

أضاف الإصدار Android 4.0 (Iceكريم ساندويتش) علامات جديدة للتحكم في مستوى رؤية واجهة مستخدم النظام مثل تعتيم مظهر شريط النظام أو جعله يختفي تمامًا على الهواتف المحمولة. يضيف Android 4.1 بعض الميزات الأخرى التي تتيح لك التحكم بشكل أكبر في مظهر النظام عناصر واجهة المستخدم وتنسيق النشاط في ما يتعلّق بها من خلال طلب الرقم setSystemUiVisibility() وتمرير العلامات التالية:

SYSTEM_UI_FLAG_FULLSCREEN
يخفي هذا الإعداد واجهة مستخدم النظام غير المهمة (مثل شريط الحالة). إذا كان نشاطك يستخدم شريط الإجراءات في وضع التراكب (من خلال تفعيل android:windowActionBarOverlay)، فإن هذه العلامة أيضًا تخفي شريط الإجراءات باستخدام رسم متحرك منسّق عند إخفاء الاثنين وإظهارهما.
SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
يضبط تنسيق نشاطك على استخدام منطقة الشاشة نفسها التي تكون متاحة عند إجراء ما يلي: تم تفعيل SYSTEM_UI_FLAG_FULLSCREEN حتى إذا كانت عناصر واجهة مستخدم النظام لا تزال مرئية. على الرغم من أن أجزاءً من تخطيطك سيتم تركيبها بواسطة في واجهة مستخدم النظام، يكون ذلك مفيدًا إذا كان تطبيقك غالبًا ما يخفي ويعرض واجهة مستخدم النظام SYSTEM_UI_FLAG_FULLSCREEN، لأنّه يتجنّب تنسيقك من بما يتوافق مع حدود التخطيط الجديد في كل مرة تختفي فيها واجهة مستخدم النظام أو تظهر فيها.
SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
يضبط تنسيق نشاطك على استخدام منطقة الشاشة نفسها التي تكون متاحة عند إجراء ما يلي: تم تفعيل SYSTEM_UI_FLAG_HIDE_NAVIGATION (مُضافة في Android 4.0) حتى إذا كانت عناصر واجهة مستخدم النظام لا تزال مرئية. وعلى الرغم من أن أجزاء من التخطيط سيتم مركّبة شريط التنقل، يكون هذا مفيدًا إذا كان تطبيقك غالبًا ما يُخفي شريط التنقل ويعرضه مع SYSTEM_UI_FLAG_HIDE_NAVIGATION، لأنه يتجنّب تنسيقك من تعديل حدود التخطيط الجديد في كل مرة يختفي فيها شريط التنقل أو يظهر فيه.
SYSTEM_UI_FLAG_LAYOUT_STABLE
قد تحتاج إلى إضافة هذه العلامة إذا كنت تستخدم SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN و/أو SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION للتأكد من ذلك عند إجراء الاتصال fitSystemWindows() على طريقة عرض تظل الحدود المحددة متسقة فيما يتعلق بمساحة الشاشة المتاحة. بمعنى آخر، من خلال ضبط العلامات هذه، سيعمل fitSystemWindows() كما لو لم يتغيّر مستوى رؤية عناصر واجهة مستخدم النظام. حتى بعد إخفاء جميع واجهات مستخدم النظام.

لمزيد من المناقشة حول علامات واجهة مستخدم النظام الأخرى ذات الصلة، يمكنك الاطّلاع على تلك التي تمت إضافتها في Android 4.0.

طرق العرض عن بُعد

GridLayout وViewStub هي طرق عرض قابلة للتعديل حتى تتمكن من استخدامها في تخطيطات تطبيقات مصغّرة وتنسيقات مخصّصة للإشعارات.

مجموعات الخطوط

يضيف Android 4.1 العديد من المتغيرات الأخرى لنمط خط Roboto لإجمالي 10 أنواع، وجميعها قابلة للاستخدام بواسطة التطبيقات. يمكن لتطبيقاتك الآن الوصول إلى المجموعة الكاملة من وحدات الإضاءة المختلفة المختصرة.

في ما يلي المجموعة الكاملة لمتغيرات خط Roboto المتاحة:

  • منتظمة
  • مائل
  • غامق
  • غامق ومائل
  • فاتح
  • فاتح مائل
  • مكثف عادي
  • مائل مكثف
  • غامق غامق
  • مكثف غامق ومائل

يمكنك تطبيق أي من هذه الخيارات باستخدام fontFamily الجديدة. إلى جانب السمة textStyle.

القيم المسموح بها لـ fontFamily هي:

  • "sans-serif" للعبة Roboto العادية
  • "sans-serif-light" لـ Roboto Light
  • "sans-serif-condensed" لـ Roboto المكثف

يمكنك بعد ذلك تطبيق التنسيق الغامق و/أو المائل باستخدام قيمة textStyle. "bold" و"italic" يمكنك تطبيق الاثنين على النحو التالي: android:textStyle="bold|italic".

ويمكنك أيضًا استخدام Typeface.create(). مثلاً: Typeface.create("sans-serif-light", Typeface.NORMAL)

إطار عمل الإدخال

أجهزة إدخال متعددة

تتيح لك الفئة InputManager الجديدة إجراء طلب بحث عن مجموعة من أجهزة الإدخال المتصلة حاليًا ويتم تسجيلها ليتم إرسال إشعار عند وصول جهاز جديد إضافة أو تغيير أو إزالة. ويكون ذلك مفيدًا بشكل خاص إذا كنت تصمم لعبة التي تتوافق مع عدة لاعبين وتريد معرفة عدد وحدات التحكّم المتصلة وعندما تكون هناك تغييرات في عدد وحدات التحكم.

يمكنك الاستعلام عن جميع أجهزة الإدخال المتصلة من خلال استدعاء getInputDeviceIds() يؤدي هذا إلى إرجاع مصفوفة من الأعداد الصحيحة، كلٌ منها عبارة عن معرّف لجهاز إدخال مختلف. يمكنك بعد ذلك الاتصال يجب الحصول على getInputDevice() InputDevice لمعرّف جهاز إدخال محدد.

إذا كنت تريد تلقّي إشعارات عند توصيل أجهزة إدخال جديدة أو تغييرها أو فصلها، تنفيذ واجهة InputManager.InputDeviceListener سجِّله لدى registerInputDeviceListener().

الاهتزاز مع وحدات تحكم الإدخال

إذا كانت أجهزة الإدخال المتصلة بها إمكانات الاهتزاز الخاصة بها، يمكنك الآن التحكُّم في لاهتزاز تلك الأجهزة باستخدام واجهات برمجة تطبيقات Vibrator الحالية، عن طريق الاتصال بـ getVibrator() على InputDevice.

الأذونات

في ما يلي الأذونات الجديدة:

READ_EXTERNAL_STORAGE
يوفر وصولًا آمنًا للقراءة إلى وحدة التخزين الخارجية. في Android 4.1 من خلال الوضع الافتراضي لا تزال جميع التطبيقات تقرأ الوصول إليه. سيتم تغيير ذلك في إصدار مستقبلي لاشتراط أن تطلب التطبيقات بشكل صريح إذنًا بالقراءة باستخدام هذا الإذن. إذا كان تطبيقك يطلب بالفعل إذنًا بالكتابة، فسوف يطلب تحصل تلقائيًا على حق الوصول للقراءة أيضًا. يتوفّر خيار جديد للمطوّرين يتيح تفعيل إذن القراءة. أن يختبر المطوّرون تطبيقاتهم وفقًا لسلوك Android في المستقبلية.
الإذن android.Manifest.permission.READ_USER_DICTIONARY
يسمح للتطبيق بقراءة قاموس المستخدم. من المفترض ألا يكون ذلك مطلوبًا إلا من خلال أداة تحرير أسلوب الإدخال (IME) أو محرّر القاموس مثل تطبيق "الإعدادات".
READ_CALL_LOG
يسمح للتطبيق بقراءة سجل مكالمات النظام الذي يحتوي على معلومات حول. الواردة والصادرة.
WRITE_CALL_LOG
يسمح للتطبيق بتعديل سجلّ مكالمات النظام المُخزَّن على الهاتف.
الإذن android.Manifest.permission.WRITE_USER_DICTIONARY
يسمح للتطبيق بالكتابة إلى قاموس كلمات المستخدم.

ميزات الجهاز

يتضمّن Android 4.1 بيان ميزات جديدة للأجهزة المخصّصة لعرض واجهة المستخدم على شاشة التلفزيون: FEATURE_TELEVISION الإقرار بأنّ تطبيقك يتطلّب واجهة تلفزيون، يُرجى الإفصاح عن هذه الميزة في ملف البيان باستخدام العنصر <uses-feature>:

<manifest ... >
    <uses-feature android:name="android.hardware.type.television"
                  android:required="true" />
    ...
</manifest>

تُعرِّف هذه الميزة "التلفزيون" ليكون تجربة مشاهدة تلفزيون عادية في غرفة المعيشة: معروضة على شاشة كبيرة، حيث يجلس المستخدم بعيدًا، والشكل السائد يكون الإدخال شيئًا مثل لوحة الاتجاهات، وعمومًا لا يكون عن طريق اللمس أو الماوس/جهاز المؤشر.