إضافة خريطة تتضمّن علامة

يوضّح هذا الدليل التعليمي كيفية إضافة خريطة Google بسيطة تتضمّن علامة إلى تطبيق iOS. وهو مناسب للمستخدمين الذين لديهم معرفة مبتدئة أو متوسطة بلغة Swift أو Objective-C بالإضافة إلى معرفة عامة بـ Xcode. للحصول على دليل متقدّم ل إنشاء الخرائط، يُرجى قراءة دليل المطوّرين.

ستُنشئ الخريطة التالية باستخدام هذا الدليل التعليمي. تم وضع العلامة في سيدني، أستراليا.

لقطة شاشة تعرض خريطة تتضمّن علامة فوق سيدني

الحصول على الشفرة‏

استنسِخ أو نزِّل مستودع نماذج "خرائط Google" لنظام التشغيل iOS على GitHub.

بدلاً من ذلك، انقر على الزر التالي لتنزيل رمز المصدر:

أريد الرمز

Swift

import UIKit
import GoogleMaps

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.
        // Create a GMSCameraPosition that tells the map to display the
        // coordinate -33.86,151.20 at zoom level 6.
        let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 6.0)
        let mapView = GMSMapView.map(withFrame: self.view.frame, camera: camera)
        self.view.addSubview(mapView)

        // Creates a marker in the center of the map.
        let marker = GMSMarker()
        marker.position = CLLocationCoordinate2D(latitude: -33.86, longitude: 151.20)
        marker.title = "Sydney"
        marker.snippet = "Australia"
        marker.map = mapView
  }
}
      

Objective-C

#import "ViewController.h"
#import <GoogleMaps/GoogleMaps.h>

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
  // Do any additional setup after loading the view.
  // Create a GMSCameraPosition that tells the map to display the
  // coordinate -33.86,151.20 at zoom level 6.
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                          longitude:151.20
                                                               zoom:6];
  GMSMapView *mapView = [GMSMapView mapWithFrame:self.view.frame camera:camera];
  mapView.myLocationEnabled = YES;
  [self.view addSubview:mapView];

  // Creates a marker in the center of the map.
  GMSMarker *marker = [[GMSMarker alloc] init];
  marker.position = CLLocationCoordinate2DMake(-33.86, 151.20);
  marker.title = @"Sydney";
  marker.snippet = @"Australia";
  marker.map = mapView;
}

@end
      

البدء

أداة إدارة حِزم Swift

يمكن تثبيت حزمة تطوير البرامج (SDK) لتطبيق "خرائط Google" لنظام التشغيل iOS باستخدام أداة Swift Package Manager.

  1. تأكَّد من إزالة أي تبعيات حالية لحزمة تطوير البرامج (SDK) لتطبيق "خرائط Google" لنظام التشغيل iOS.
  2. افتح نافذة أوامر طرفية وانتقِل إلى الدليل tutorials/map-with-marker.
  3. تأكَّد من إغلاق مساحة عمل Xcode وشغِّل الأوامر التالية:
    sudo gem install cocoapods-deintegrate cocoapods-clean
    pod deintegrate
    pod cache clean --all
    rm Podfile
    rm map-with-marker.xcworkspace
  4. افتح مشروع Xcode واحذِف ملف podfile.
  5. انتقِل إلى ملف > إضافة تبعيات الحِزم.
  6. أدخِل https://github.com/googlemaps/ios-maps-sdk كعنوان URL، واضغط على مفتاح Enter لسحب الحزمة، ثم انقر على إضافة حزمة.
  7. قد تحتاج إلى إعادة ضبط ذاكرة التخزين المؤقت للحِزم باستخدام ملف > الحِزم > إعادة ضبط ذاكرة التخزين المؤقت للحِزم.

استخدام CocoaPods

  1. نزِّل Xcode الإصدار 15.0 أو إصدار أحدث مثبَّتًا عليه.
  2. إذا لم يكن لديك CocoaPods، ثبِّته على نظام التشغيل macOS من خلال تنفيذ الأمر التالي من المحطة الطرفية:
    sudo gem install cocoapods
  3. انتقِل إلى دليل tutorials/map-with-marker.
  4. نفِّذ الأمر pod install. سيؤدي ذلك إلى تثبيت حزمة تطوير البرامج (SDK) لتطبيق "خرائط Google" المحدّدة في Podfile، بالإضافة إلى أي ملحقات.
  5. شغِّل pod outdated لمقارنة إصدار الحِزمة المثبَّتة بأي تحديثات جديدة. في حال رصد إصدار جديد، عليك تشغيل pod update لتحديث Podfile وتثبيت أحدث إصدار من حزمة SDK. لمزيد من التفاصيل، يُرجى الاطّلاع على دليل CocoaPods.
  6. افتح (انقر نقرًا مزدوجًا) ملف المشروع map-with-marker.xcworkspace لفتحه في Xcode. يجب استخدام ملف .xcworkspace لفتح المشروع.

الحصول على مفتاح واجهة برمجة التطبيقات وتفعيل واجهات برمجة التطبيقات اللازمة

لإكمال هذا الدليل التعليمي، تحتاج إلى مفتاح Google API مفوَّض باستخدام حزمة تطوير البرامج (SDK) لخرائط Google لنظام التشغيل iOS. انقر على الزر التالي للحصول على مفتاح وتفعيل واجهة برمجة التطبيقات.

البدء

لمزيد من التفاصيل، يُرجى الاطّلاع على مقالة الحصول على مفتاح واجهة برمجة التطبيقات.

إضافة مفتاح واجهة برمجة التطبيقات إلى تطبيقك

أضِف مفتاح واجهة برمجة التطبيقات إلى AppDelegate.swift على النحو التالي:

  1. يُرجى العلم أنّه تمت إضافة بيان الاستيراد التالي إلى الملف:
    import GoogleMaps
  2. عدِّل السطر التالي في طريقة application(_:didFinishLaunchingWithOptions:) ، واستبدِل YOUR_API_KEY بمفتاح واجهة برمجة التطبيقات:
    GMSServices.provideAPIKey("YOUR_API_KEY")

إنشاء تطبيقك وتشغيله

  1. وصِّل جهاز iOS بالكمبيوتر، أو اختَر محاكيًا من قائمة مخطّط Xcode.
  2. إذا كنت تستخدم جهازًا، تأكَّد من تفعيل خدمات الموقع الجغرافي. إذا كنت تستخدم محاكيًا، اختَر موقعًا جغرافيًا من قائمة الميزات.
  3. في Xcode، انقر على خيار القائمة التطبيق/التشغيل (أو رمز زر التشغيل ).
    • ينشئ Xcode التطبيق، ثم يشغّله على الجهاز أو على المحاكي.
    • من المفترض أن تظهر لك خريطة تتضمّن علامة في منتصف سيدني على الساحل الشرقي لأستراليا، على غرار الصورة في هذه الصفحة.

تحرّي الخلل وإصلاحه:

  • إذا لم تظهر لك خريطة، تأكَّد من أنّك حصلت على مفتاح واجهة برمجة التطبيقات وأضفته إلى التطبيق، على النحو الموضّح سابقًا. اطّلِع على وحدة تحكّم تصحيح الأخطاء في Xcode بحثًا عن رسائل خطأ بشأن مفتاح واجهة برمجة التطبيقات.
  • إذا فرضت قيودًا على مفتاح واجهة برمجة التطبيقات حسب معرّف حزمة iOS، عدِّل المفتاح لإضافة معرّف الحزمة للتطبيق: com.google.examples.map-with-marker.
  • تأكَّد من توفّر اتصال جيد بشبكة Wi-Fi أو نظام تحديد المواقع العالمي (GPS).
  • استخدِم أدوات تصحيح الأخطاء في Xcode لعرض السجلات وتصحيح أخطاء التطبيق.

فهم الرمز

  1. أنشئ خريطة واضبطها على أنّها طريقة العرض في viewDidLoad().

    Swift

    // Create a GMSCameraPosition that tells the map to display the
    // coordinate -33.86,151.20 at zoom level 6.
    let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 6.0)
    let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)
    view = mapView
          

    Objective-C

    // Create a GMSCameraPosition that tells the map to display the
    // coordinate -33.86,151.20 at zoom level 6.
    GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                            longitude:151.20
                                                                 zoom:6.0];
    GMSMapView *mapView = [[GMSMapView alloc] initWithFrame: CGRectZero camera:camera];
    self.view = mapView;
          
  2. أضِف علامة إلى الخريطة في viewDidLoad().

    Swift

    // Creates a marker in the center of the map.
    let marker = GMSMarker()
    marker.position = CLLocationCoordinate2D(latitude: -33.86, longitude: 151.20)
    marker.title = "Sydney"
    marker.snippet = "Australia"
    marker.map = mapView
          

    Objective-C

    // Creates a marker in the center of the map.
    GMSMarker *marker = [[GMSMarker alloc] init];
    marker.position = CLLocationCoordinate2DMake(-33.86, 151.20);
    marker.title = @"Sydney";
    marker.snippet = @"Australia";
    marker.map = mapView;
          

تعرض حزمة تطوير البرامج (SDK) لتطبيق "خرائط Google" لنظام التشغيل iOS تلقائيًا محتوى النافذة عندما ينقر المستخدم على علامة. ليس عليك إضافة مستمع للنقرات لعلامة التعليق التوضيحي إذا كنت تريد استخدام السلوك التلقائي.

تهانينا! لقد أنشأت تطبيقًا لنظام التشغيل iOS يعرض خريطة Google مع علامة للإشارة إلى موقع جغرافي معيّن. وتعرّفت أيضًا على كيفية استخدام حزمة تطوير البرامج بالاستناد إلى بيانات "خرائط Google" لتطبيقات iOS.

الخطوات التالية

اطّلِع على مزيد من المعلومات عن كائن الخريطة والإجراءات التي يمكنك اتّخاذها باستخدام العلامات.