الفرق بين المراجعتين لصفحة: «Cordova/webview ios»
لا ملخص تعديل |
لا ملخص تعديل |
||
سطر 2: | سطر 2: | ||
[[تصنيف: Cordova]] | [[تصنيف: Cordova]] | ||
[[تصنيف: iOS]] | [[تصنيف: iOS]] | ||
يوضح هذا المجلد كيفية تضمين مُكوّن (component) [[Cordova/webviews|عارض]] كوردوفا في تطبيقات منصة iOS الكبيرة. للمزيد من التفاصيل حول كيفية جعل تلك المكوّنات تتواصل مع بعضها، [[Cordova/plugins|دليل تطوير الإضافات]]. | يوضح هذا المجلد كيفية تضمين مُكوّن (component) [[Cordova/webviews|عارض]] كوردوفا في تطبيقات منصة iOS الكبيرة. للمزيد من التفاصيل حول كيفية جعل تلك المكوّنات تتواصل مع بعضها، راجع [[Cordova/plugins|دليل تطوير الإضافات]]. | ||
بدأ دعم [[Cordova/webviews|العوارض]] في منصة iOS منذ الإصدار 1.4 كوردوفا، باستخدام مكوِّن <code>Cleaver</code> الذي بُنِي على قالب Xcode. منصة كوردوفا 2.0 والإصدارات الأحدث لا تدعم إلا التقديم المستند إلى المشروع الفرعي (subproject-based) للمكُوِّن <code>Cleaver</code>. | بدأ دعم [[Cordova/webviews|العوارض]] في منصة iOS منذ الإصدار 1.4 كوردوفا، باستخدام مكوِّن <code>Cleaver</code> الذي بُنِي على قالب Xcode. منصة كوردوفا 2.0 والإصدارات الأحدث لا تدعم إلا التقديم المستند إلى المشروع الفرعي (subproject-based) للمكُوِّن <code>Cleaver</code>. | ||
تتطلب هذه الإرشادات | تتطلب هذه الإرشادات على الأقل الإصدار الرابع من كوردوفا، والثامن من Xcode، بالإضافة إلى الملف <code>[[Cordova/config ref|config.xml]]</code> من مشروع iOS المُنشا حديثًا. يمكنك استخدام هذا الإجراء في [[Cordova/cli|واجهة سطر الأوامر]] لإنشاء مشروع جديد، ثم الحصول على الملف <code>[[Cordova/config ref|config.xml]]</code> من المجلد الفرعي للتطبيق <code>platforms/ios</code>. | ||
* لاتباع هذه التعليمات، تأكد من أنّ لديك أحدث توزيعة من كوردوفا. نزِّلها من [http://cordova.apache.org cordova.apache.org]، وفُكَّ ضغط حزمة iOS الموجودة فيها. | * لاتباع هذه التعليمات، تأكد من أنّ لديك أحدث توزيعة من كوردوفا. نزِّلها من [http://cordova.apache.org cordova.apache.org]، وفُكَّ ضغط حزمة iOS الموجودة فيها. | ||
سطر 12: | سطر 12: | ||
هناك طريقتان لإضافة كوردوفا إلى مشروعك. الطريقة الأولى هي استخدام الأداة [https://github.com/Carthage/Carthage Carthage]، أمّا الطريقة الثانية فتعتمد إضافة كوردوفا يدويًا. تذكر أنّ Carthage ليست مدعومة إلا في الإصدار 4.0.0 من cordova-ios أو ما فوقه. | هناك طريقتان لإضافة كوردوفا إلى مشروعك. الطريقة الأولى هي استخدام الأداة [https://github.com/Carthage/Carthage Carthage]، أمّا الطريقة الثانية فتعتمد إضافة كوردوفا يدويًا. تذكر أنّ Carthage ليست مدعومة إلا في الإصدار 4.0.0 من cordova-ios أو ما فوقه. | ||
بعد استخدام أيٍّ من هاتين الطريقتين، | بعد استخدام أيٍّ من هاتين الطريقتين، يمكنك الانتقال إلى قسم [[Cordova/webview ios#.D8.A7.D8.B3.D8.AA.D8.AE.D8.AF.D8.A7.D9.85 CDVViewController|استخدام <code>CDVViewController</code>]]. | ||
==إضافة <code>Cordova.framework</code> إلى مشروع Xcode باستخدام أداة Carthage == | ==إضافة <code>Cordova.framework</code> إلى مشروع Xcode باستخدام أداة Carthage == | ||
* قم بتثبيت [https://github.com/Carthage/Carthage Carthage] | * قم بتثبيت [https://github.com/Carthage/Carthage Carthage] | ||
* في الملف [https://github.com/Carthage/Carthage/blob/master/Documentation/Artifacts.md#cartfile Cartfile]، أضف ما يلي (مع استبدال الإصدار المناسب | * في الملف [https://github.com/Carthage/Carthage/blob/master/Documentation/Artifacts.md#cartfile Cartfile]، أضف ما يلي (مع استبدال الإصدار المناسب بـ <code><versionortag></code>): | ||
<syntaxhighlight lang="shell">git "git://git.apache.org/cordova-ios.git" "<version_or_tag>" # Apache</syntaxhighlight> | <syntaxhighlight lang="shell">git "git://git.apache.org/cordova-ios.git" "<version_or_tag>" # Apache</syntaxhighlight> | ||
*قم بتنفيذ الأمر التالي: | *قم بتنفيذ الأمر التالي: | ||
<syntaxhighlight lang="shell">carthage update</syntaxhighlight> | <syntaxhighlight lang="shell">carthage update</syntaxhighlight> | ||
* أضف <code>Carthage/Build/iOS/Cordova.framework</code> إلى مشروع Xcode | * أضف <code>Carthage/Build/iOS/Cordova.framework</code> إلى مشروع Xcode. | ||
== إضافة Cleaver إلى مشروع Xcode (CordovaLib Sub-Project) == | == إضافة Cleaver إلى مشروع Xcode (CordovaLib Sub-Project) == | ||
* قم بإنهاء Xcode إذا كان قيد التشغيل. | * قم بإنهاء Xcode إذا كان قيد التشغيل. | ||
سطر 27: | سطر 27: | ||
* اختر <code>Create groups for any added folders</code> واضغط على الزر <code>Finish</code>. | * اختر <code>Create groups for any added folders</code> واضغط على الزر <code>Finish</code>. | ||
* استخدم Finder لنسخ الملف <code>CordovaLib/CordovaLib.xcodeproj</code> إلى <code>Project Navigator</code> الخاص بإطار العمل Xcode. | * استخدم Finder لنسخ الملف <code>CordovaLib/CordovaLib.xcodeproj</code> إلى <code>Project Navigator</code> الخاص بإطار العمل Xcode. | ||
* | * حدّد <code>CordovaLib.xcodeproj</code> في النافذة <code>Project Navigator</code>. | ||
* ارقُم تركيبة المفاتيح <code>Option-Command-1</code> لإظهار <code>File Inspector</code>. | * ارقُم تركيبة المفاتيح <code>Option-Command-1</code> لإظهار <code>File Inspector</code>. | ||
* | * حدد <code>Relative to Group</code> في <code>File Inspector</code> من القائمة المنسدلة الخاصة بالموقع <code>Location</code>. | ||
* | * حدّد أيقونة المشروع <code>project icon</code> في <code>Project Navigator</code>، واختر <code>Target</code>، ثم اذهب إلى علامة التبويب <code>Build Settings</code>. | ||
* اضف <code>-force_load</code> و <code>-ObjC</code> لقيمة <code>Other Linker Flags</code>. | * اضف <code>-force_load</code> و <code>-ObjC</code> لقيمة <code>Other Linker Flags</code>. | ||
* انقر على <code>project icon</code> في النافذة Project Navigator، واختر قيمة <code>Target</code>، ثم اذهب إلى علامة التبويب <code>Build Phases</code>. | * انقر على أيقونة المشروع <code>project icon</code> في النافذة Project Navigator، واختر قيمة <code>Target</code>، ثم اذهب إلى علامة التبويب <code>Build Phases</code>. | ||
* قم بتوسيع <code>Link Binaries with Libraries</code>. | * قم بتوسيع <code>Link Binaries with Libraries</code>. | ||
* اضغط على الزر <code>+</code>، وأضف الإطارات <code>frameworks</code> التالية. | * اضغط على الزر <code>+</code>، وأضف الإطارات <code>frameworks</code> التالية. وبشكلٍ اختياريٍ، قم بنقلها إلى المجموعة <code>Frameworks</code> داخل <code>Project Navigator</code>: | ||
<syntaxhighlight lang="shell">AssetsLibrary.framework | <syntaxhighlight lang="shell">AssetsLibrary.framework | ||
CoreLocation.framework | CoreLocation.framework | ||
سطر 51: | سطر 51: | ||
"$(BUILT_PRODUCTS_DIR)"</syntaxhighlight> | "$(BUILT_PRODUCTS_DIR)"</syntaxhighlight> | ||
بدءًا من الإصدار 2.1.0 من كوردوفا، تمت ترقية <code>CordovaLib</code> لاستخدام <code>Automatic Reference Counting (ARC)</code>. فلم تعد تحتاج إلى الترقية إلى <code>ARC</code> | بدءًا من الإصدار 2.1.0 من كوردوفا، تمت ترقية <code>CordovaLib</code> لاستخدام <code>Automatic Reference Counting (ARC)</code>. فلم تعد تحتاج إلى الترقية إلى <code>ARC</code> لاستعمال <code>CordovaLib</code>، ولكن إن أردت ترقية مشروعك لاستخدام <code>ARC</code>، فاستعمل أداة الترحيل (migration wizard) في إطار العمل Xcode من القائمة <code>Edit → Refactor → Convert to Objective-C ARC...</code>، ثم <code>de-select libCordova.a</code>، ثم قم بتشغيل الأداة لاكمال المهمّة. | ||
== استخدام <code>CDVViewController</code> == | == استخدام <code>CDVViewController</code> == | ||
* أضف الترويسة التالية: | * أضف الترويسة التالية: | ||
سطر 57: | سطر 57: | ||
* قم بإنشاء نسخة جديدة من <code>CDVViewController</code> واحتفظ بها في مكانٍ ما، على سبيل المثال، احتفظ بها في خاصية صنفيةٍ (class property): | * قم بإنشاء نسخة جديدة من <code>CDVViewController</code> واحتفظ بها في مكانٍ ما، على سبيل المثال، احتفظ بها في خاصية صنفيةٍ (class property): | ||
<syntaxhighlight lang="javascript">CDVViewController* viewController = [CDVViewController new];</syntaxhighlight> | <syntaxhighlight lang="javascript">CDVViewController* viewController = [CDVViewController new];</syntaxhighlight> | ||
* بشكل اختياري، قم بتعيين الخاصية <code>wwwFolderName</code>، ذات القيمة الافتراضية <code>www</code>: | * بشكل اختياري، قم بتعيين قيمة الخاصية <code>wwwFolderName</code>، ذات القيمة الافتراضية <code>www</code>: | ||
<syntaxhighlight lang="javascript">viewController.wwwFolderName = @"myfolder";</syntaxhighlight> | <syntaxhighlight lang="javascript">viewController.wwwFolderName = @"myfolder";</syntaxhighlight> | ||
* بشكل اختياري، قم بتعيين صفحة البداية في الوسم <code><content></code> داخل الملف <code>config.xml</code>، إما لملفٍ محلي: | * بشكل اختياري، قم بتعيين صفحة البداية في الوسم <code><content></code> داخل الملف <code>config.xml</code>، إما لملفٍ محلي: | ||
سطر 72: | سطر 72: | ||
== إضافة أصول HTML و CSS و JavaScript == | == إضافة أصول HTML و CSS و JavaScript == | ||
* أنشئ مجلدًا جديدًا داخل المشروع، مثلا: <code>www</code>. | * أنشئ مجلدًا جديدًا داخل المشروع، مثلا: <code>www</code>. | ||
* ضع أصول [[HTML]] و [[CSS]] | * ضع أصول [[HTML]] و [[CSS]] و<nowiki/>[[JavaScript|جافاسكريبت]] في هذا المجلد. | ||
* استخدم Finder لنسخ المجلد في نافذة <code>Project Navigator</code> في Xcode. | * استخدم Finder لنسخ المجلد في نافذة <code>Project Navigator</code> في Xcode. | ||
* اختر <code>Create folder references for any added folders</code>. | * اختر <code>Create folder references for any added folders</code>. |
مراجعة 22:12، 26 ديسمبر 2018
يوضح هذا المجلد كيفية تضمين مُكوّن (component) عارض كوردوفا في تطبيقات منصة iOS الكبيرة. للمزيد من التفاصيل حول كيفية جعل تلك المكوّنات تتواصل مع بعضها، راجع دليل تطوير الإضافات.
بدأ دعم العوارض في منصة iOS منذ الإصدار 1.4 كوردوفا، باستخدام مكوِّن Cleaver
الذي بُنِي على قالب Xcode. منصة كوردوفا 2.0 والإصدارات الأحدث لا تدعم إلا التقديم المستند إلى المشروع الفرعي (subproject-based) للمكُوِّن Cleaver
.
تتطلب هذه الإرشادات على الأقل الإصدار الرابع من كوردوفا، والثامن من Xcode، بالإضافة إلى الملف config.xml
من مشروع iOS المُنشا حديثًا. يمكنك استخدام هذا الإجراء في واجهة سطر الأوامر لإنشاء مشروع جديد، ثم الحصول على الملف config.xml
من المجلد الفرعي للتطبيق platforms/ios
.
- لاتباع هذه التعليمات، تأكد من أنّ لديك أحدث توزيعة من كوردوفا. نزِّلها من cordova.apache.org، وفُكَّ ضغط حزمة iOS الموجودة فيها.
هناك طريقتان لإضافة كوردوفا إلى مشروعك. الطريقة الأولى هي استخدام الأداة Carthage، أمّا الطريقة الثانية فتعتمد إضافة كوردوفا يدويًا. تذكر أنّ Carthage ليست مدعومة إلا في الإصدار 4.0.0 من cordova-ios أو ما فوقه.
بعد استخدام أيٍّ من هاتين الطريقتين، يمكنك الانتقال إلى قسم استخدام CDVViewController
.
إضافة Cordova.framework
إلى مشروع Xcode باستخدام أداة Carthage
git "git://git.apache.org/cordova-ios.git" "<version_or_tag>" # Apache
- قم بتنفيذ الأمر التالي:
carthage update
- أضف
Carthage/Build/iOS/Cordova.framework
إلى مشروع Xcode.
إضافة Cleaver إلى مشروع Xcode (CordovaLib Sub-Project)
- قم بإنهاء Xcode إذا كان قيد التشغيل.
- افتح طرفيةً، وانتقل إلى المجلد المصدري لكوردوفا iOS.
- انسخ الملف
config.xml
الموضح أعلاه في مجلد المشروع. - افتح Xcode واستخدم أداة Finder لنسخ الملف
config.xml
في النافذةProject Navigator
. - اختر
Create groups for any added folders
واضغط على الزرFinish
. - استخدم Finder لنسخ الملف
CordovaLib/CordovaLib.xcodeproj
إلىProject Navigator
الخاص بإطار العمل Xcode. - حدّد
CordovaLib.xcodeproj
في النافذةProject Navigator
. - ارقُم تركيبة المفاتيح
Option-Command-1
لإظهارFile Inspector
. - حدد
Relative to Group
فيFile Inspector
من القائمة المنسدلة الخاصة بالموقعLocation
. - حدّد أيقونة المشروع
project icon
فيProject Navigator
، واخترTarget
، ثم اذهب إلى علامة التبويبBuild Settings
. - اضف
-force_load
و -ObjC
لقيمةOther Linker Flags
. - انقر على أيقونة المشروع
project icon
في النافذة Project Navigator، واختر قيمةTarget
، ثم اذهب إلى علامة التبويبBuild Phases
. - قم بتوسيع
Link Binaries with Libraries
. - اضغط على الزر
+
، وأضف الإطاراتframeworks
التالية. وبشكلٍ اختياريٍ، قم بنقلها إلى المجموعةFrameworks
داخلProject Navigator
:
AssetsLibrary.framework
CoreLocation.framework
CoreGraphics.framework
MobileCoreServices.framework
- قم بتوسيع
Target Dependencies
، في حال كان هناك أكثر من مربع واحد، فاذهب إلى المربع العلوي الذي له ذلك الاسم. - اضغك على الزر
+
، وأضف منتج البناءCordovaLib
. - قم بتوسيع
Link Binaries with Libraries
، أو المربع العلوي الذي له هذا الاسم إذا كان هناك أكثر من مربع واحد. - اضغط على الزر
+
، وأضفlibCordova.a
. - عيّن
Xcode Preferences → Locations → Derived Data → Advanced...
إلى القيمةUnique
. - حدد أيقونة المشروع
project icon
في النافذة Project Navigator، وحددTarget
، ثم اذهب إلى علامة التبويبBuild Settings
. - ابحث عن
Header Search Paths
. وأضف إلى ذلك الإعداد القيمَ الثلاثة أدناه، بما في ذلك علامات الاقتباس:
"$(TARGET_BUILD_DIR)/usr/local/lib/include"
"$(OBJROOT)/UninstalledProducts/include"
"$(OBJROOT)/UninstalledProducts/$(PLATFORM_NAME)/include"
"$(BUILT_PRODUCTS_DIR)"
بدءًا من الإصدار 2.1.0 من كوردوفا، تمت ترقية CordovaLib
لاستخدام Automatic Reference Counting (ARC)
. فلم تعد تحتاج إلى الترقية إلى ARC
لاستعمال CordovaLib
، ولكن إن أردت ترقية مشروعك لاستخدام ARC
، فاستعمل أداة الترحيل (migration wizard) في إطار العمل Xcode من القائمة Edit → Refactor → Convert to Objective-C ARC...
، ثم de-select libCordova.a
، ثم قم بتشغيل الأداة لاكمال المهمّة.
استخدام CDVViewController
- أضف الترويسة التالية:
#import <Cordova/CDVViewController.h>
- قم بإنشاء نسخة جديدة من
CDVViewController
واحتفظ بها في مكانٍ ما، على سبيل المثال، احتفظ بها في خاصية صنفيةٍ (class property):
CDVViewController* viewController = [CDVViewController new];
- بشكل اختياري، قم بتعيين قيمة الخاصية
wwwFolderName
، ذات القيمة الافتراضيةwww
:
viewController.wwwFolderName = @"myfolder";
- بشكل اختياري، قم بتعيين صفحة البداية في الوسم
<content>
داخل الملفconfig.xml
، إما لملفٍ محلي:
<content src="index.html" />
... أو لموقع بعيد:
<content src="http://apache.org" />
- بشكل اختياري، عيّن قيمة الخاصية
useSplashScreen
، ذات القيمة الافتراضيةNO
:
viewController.useSplashScreen = YES;
- عيّن قيمة الخاصية
view frame
. اترك تعيين هذه الخاصية دائمًا إلى الأخير:
viewController.view.frame = CGRectMake(0, 0, 320, 480);
- أضف Cleaver إلى العارض:
[myView addSubview:viewController.view];
إضافة أصول HTML و CSS و JavaScript
- أنشئ مجلدًا جديدًا داخل المشروع، مثلا:
www
. - ضع أصول HTML و CSS وجافاسكريبت في هذا المجلد.
- استخدم Finder لنسخ المجلد في نافذة
Project Navigator
في Xcode. - اختر
Create folder references for any added folders
. - قم بتعيين قيم الخاصيتين
wwwFolderName
وstartPage
المناسبتين للمجلد الذي قمت بإنشائه في البداية، أو استخدم الإعدادات الافتراضية (المحددة في القسم السابق) عند إنشاء نسخة منCDVViewController
.
/*
myfolder إن أنشأت ملفا اسمه
الموجود فيه mypage.html وأردت أن يكون الملف
startPage هو صفحة البداية
*/
viewController.wwwFolderName = @"myfolder";
viewController.startPage = @"mypage.html"