إضافة حالة الجهاز في كوردوفا

من موسوعة حسوب

تُعرّف إضافة حالة الجهاز (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

انظر أيضًا

مصادر