إضافة حالة الجهاز في كوردوفا
تُعرّف إضافة حالة الجهاز (cordova-plugin-device) كائنًا عامًّا هو device
، والذي يوفر معلومات حول عتاد وبرامج الجهاز. على الرغم من أن الكائن موجود في النطاق العام (global scope)، إلا أنه لن يكون متوفرًا إلا بعد إطلاق الحدث deviceready
.
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
console.log(device.cordova);
}
التثبيت
يمكنك تثبيت هذه الإضافة عبر الأمر التالي:
cordova plugin add cordova-plugin-device
الخاصيات
device.cordova
تعيد هذه الخاصية إصدار كوردوفا المُثبَّت على الجهاز.
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
- OSX
device.model
تعيد الخاصية device.model
اسم طراز الجهاز أو المنتج. يتم تعيين القيمة من قِبل الشركة المصنعة للجهاز، وقد تختلف بين إصدارات المنتج.
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
- OSX
إليك المثال التالي:
// Android: Nexus One (Nexus One اسم الجهاز) "Passion" تعاد القيمة
// Motorola Droid "voles" تعاد القيمة
// BlackBerry: Torch 9800 "9800" تعاد القيمة
// Browser: Google Chrome "Chrome" تعاد القيمة
// Safari "Safari" تعاد القيمة
// iOS: for the iPad Mini, returns iPad2,5; iPhone 5 is iPhone 5,1. See
// http://theiphonewiki.com/wiki/index.php?title=Models راجع الصفحة
// OSX: "x86_64" تعاد القيمة
//
var model = device.model;
ملاحظات خاصة بمنصة أندرويد
- في منصة أندرويد، يُعاد اسم المنتج بدلًا من اسم الطراز، والذي غالبًا ما يكون اسم رمز الإنتاج (production code). على سبيل المثال، يُعيد الهاتف Nexus One القيمة
Passion
، فيما يعيد Motorola Droid القيمةvoles
.
device.platform
تعيد هذه الخاصية اسم نظام التشغيل المُستخدم على الجهاز.
var string = device.platform;
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
- OSX
مثال على استعمال الخاصية platform
:
// بحسب الجهاز، هذه بعض الأمثلة
// - "Android"
// - "BlackBerry 10"
// - "browser"
// - "iOS"
// - "WinCE"
// - "Tizen"
// - "Mac OS X"
var devicePlatform = device.platform;
device.uuid
تعيد الخاصية uuid
المعرف الفريد العالمي للجهاز (UUID).
var string = device.uuid;
يتم تحديد تفاصيل كيفية توليد قيمة المعرف الفريد العالمي للجهاز (UUID) من طرف الشركة المصنعة للجهاز، وتختلف حسب منصة الجهاز أو طرازه.
المنصات المدعومة:
- أندرويد
- iOS
- ويندوز
- OSX
مثال على الخاصية uuid
:
// Android:
// يعاد عدد صحيح عشوائي من 64 بت على شكل سلسلة نصية
// يُولد الجهاز عند أول تشغيل للجهاز
//
// BlackBerry:
// الخاص بالجهاز PIN يعاد العدد
// وهو عدد فريد مكون من 9 منازل عشرية على شكل سلسلة نصية
//
// iPhone:
// (UIDevice مستخلص من توثيق الصنف)
// يعاد المعرف الفريد العالمي للجهاز، والذي يبقى ثابتًا على كل التطبيقات المُثبتة من
// قبل البائع، لكن المعرف الفريد العالمي للجهاز يمكن أن تختلف قيمته إن حذف المستخدم
// جميع التطبيقات الخاصة بالبائع ثم أعاد تثبيتها
//
// Windows Phone 7:
// للمستخدم الحالي للجهاز hash يعيد القيمة ,
// إن لم يكن المستخدم محددًا، فسيولد المعرف الفريد العالمي للجهاز وسيبقى مخزنًا إلى حين إزالة التطبيق
//
// Tizen:
// الخاصة بالجهاز IMEI تعاد القيمة
// الهوية الدولية للأجهزة المتنقلة = IMEI حيث
// UMTS و GSM تبقى ثابتة لكل أنظمة الاتصال
var deviceID = device.uuid;
ملاحظات خاصة بمنصة iOS
يستخدم المعرف الفريد العالمي للجهاز uuid
على منصة iOS الخاصية identifierForVendor
. فقيمتها تبقى ثابتة على كل الأجهزة المُصنعة من قبل نفس الشركة، بيْد أنها تختلف بين الأجهزة المصنعة من بائعين مختلفين، وستتغير إذا تم حذف جميع التطبيقات القادمة من البائع، ثم أُعيد تثبيتها. ارجع إلى هذه الصفحة لمزيد من التفاصيل.
ستكون قيمة UUID هي نفسها إذا استعيد التطبيق من نسخة احتياطية أو من السحابة iCloud، لأنها تُحفظ في التفضيلات. أما الذين يستخدمون إصدارات قديمة من هذه الإضافة سيتلقّون نفس قيمة UUID السابقة المُولّدة بالوسائل الأخرى، إذ أنها ستُسترَد من التفضيلات.
ملاحظات خاصة بمنصة OSX
يتم إنشاء uuid
على منصة OSX تلقائيًا إذا لم تكن موجودةً بعد، وستُخزّن في standardUserDefaults
في الخاصية CDVUUID
.
device.version
تعيد هذه الخاصية إصدار نظام التشغيل.
var string = device.version;
المنصات المدعومة:
- أندرويد 2.1 وما بعده
- Browser
- iOS
- ويندوز
- OSX
مثال عن استعمال الخاصية version
:
// Android:
// Froyo OS => n "2.2"
// Eclair OS => "2.1", "2.0.1", "2.0"
// "2.1-update1" - يمكن أن يعاد مستوى التحديث
//
// BlackBerry:
// "6.0.0.600" يعيد OS 6.0 الذي يستخدم Torch 9800
//
// Browser:
// يعاد رقم إصدار المتصفح
//
// iPhone:
// iOS 3.2 => "3.2"
//
// Windows Phone 7: Mango
// يعاد إصدار نظام التشغيل الحالي، مثلا، على منصة
// ستعاد القيمة 7.10.7720
//
// Windows 8:
// يعاد إصدار نظام التشغيل الحالي، مثلا، على منصة ويندوز 8.1 ستعاد
// 6.3.9600.16384 القيمة
//
// Tizen:
// "TIZEN_20120425_2" تعاد القيمة
//
// OSX: El Capitan => "10.11.2"
//
var deviceVersion = device.version;
device.manufacturer
تعيد هذه الخاصية اسم الشركة المصنعة للجهاز.
var string = device.manufacturer;
المنصات المدعومة:
- أندرويد
- iOS
- ويندوز
مثال عن استعمال الخاصية manufacturer
:
// Android: Motorola XT1032 => "motorola"
// BlackBerry: => "BlackBerry"
// iPhone: => "Apple"
//
var deviceManufacturer = device.manufacturer;
device.isVirtual
تحدد هذه الخاصية ما إذا كان الجهاز يعمل على جهاز محاكاة.
var isSim = device.isVirtual;
المنصات المدعومة:
- أندرويد 2.1 وما بعده
- المتصفحات (Browser)
- iOS
- ويندوز
- OSX
ملاحظات خاصة بمنصتي OSX و Browser
تعيد الخاصية isVirtual
على منصتي OS X و Browser القيمة false
دائمًا.
device.serial
تعيد هذه الخاصية الرقم التسلسلي للجهاز.
var string = device.serial;
المنصات المدعومة:
- أندرويد
- OSX