پس از فعال کردن صورتحساب و ایجاد یک کلید API، آماده راه اندازی پروژه Xcode هستید که برای توسعه برنامه خود استفاده می کنید.
یادداشت های انتشار برای هر نسخه در دسترس هستند.
مرحله 1: نرم افزار مورد نیاز را نصب کنید
برای ساختن یک پروژه با استفاده از Maps SDK برای iOS، باید دانلود و نصب کنید:
- Xcode نسخه 15.0 یا بالاتر
مرحله 2: پروژه Xcode را ایجاد کرده و Maps SDK را برای iOS نصب کنید
مدیر بسته سوئیفت
Maps SDK برای iOS را می توان از طریق Swift Package Manager نصب کرد. برای افزودن SDK، مطمئن شوید که نقشه های SDK موجود برای وابستگی های iOS را حذف کرده اید.
برای افزودن SDK به یک پروژه جدید یا موجود، مراحل زیر را دنبال کنید:
-
project
یاworkspace
Xcode خود را باز کنید، سپس به File > Add Package Dependencies بروید. - https://github.com/googlemaps/ios-maps-sdk را به عنوان URL وارد کنید، Enter را فشار دهید تا بسته را وارد کنید و روی «افزودن بسته» کلیک کنید.
- برای نصب یک
version
خاص، قسمت Dependency Rule را روی یکی از گزینه های مبتنی بر نسخه تنظیم کنید. برای پروژه های جدید، توصیه می کنیم آخرین نسخه را مشخص کنید و از گزینه "نسخه دقیق" استفاده کنید. پس از تکمیل، روی "افزودن بسته" کلیک کنید. - از پنجره انتخاب محصولات بسته ، تأیید کنید
GoogleMaps
(برای نسخههای قبل از 9.0.0، تأییدGoogleMaps
،GoogleMapsBase
وGoogleMapsCore
) به هدفmain
تعیینشده شما اضافه میشود. پس از تکمیل، روی "افزودن بسته" کلیک کنید. - برای تأیید نصب خود، به صفحه
General
هدف خود بروید. در Frameworks، Libraries و Embedded Content باید بسته های نصب شده را ببینید. همچنین میتوانید برای تأیید بسته و نسخه آن، بخش «وابستگیهای بسته» در «ناوبر پروژه» را مشاهده کنید.
برای به روز رسانی package
برای یک پروژه موجود، این مراحل را دنبال کنید:
اگر از نسخهای زودتر از 9.0.0 ارتقا میدهید، باید وابستگیهای زیر را حذف کنید:
GoogleMapsBase
،GoogleMapsCore
، وGoogleMapsM4B
پس از ارتقا. وابستگیGoogleMaps
را حذف نکنید. برای اطلاعات بیشتر، به یادداشتهای انتشار نسخه 9.0.0 مراجعه کنید.از تنظیمات پیکربندی پروژه Xcode خود، Frameworks، Libraries و Embedded Content را پیدا کنید. برای حذف چارچوب زیر از علامت منفی (-) استفاده کنید:
-
GoogleMapsBase
(فقط برای ارتقا از نسخه های قبل از 9.0.0) -
GoogleMapsCore
(فقط برای ارتقا از نسخه های قبل از 9.0.0) -
GoogleMapsM4B
(فقط برای ارتقاء نسخه های قبل از 9.0.0)
-
- از Xcode، به "File > Packages > Update To Latest Package Versions" بروید.
- برای تأیید نصب خود، به بخش Package Dependencies در Project Navigator بروید تا بسته و نسخه آن را تأیید کنید.
برای حذف Maps SDK موجود برای وابستگیهای iOS اضافه شده با استفاده از CocoaPods
، این مراحل را دنبال کنید:
- فضای کاری Xcode خود را ببندید. ترمینال را باز کنید و دستور زیر را اجرا کنید:
sudo gem install cocoapods-deintegrate cocoapods-clean pod deintegrate pod cache clean --all
- اگر از آنها برای چیزی غیر از CocoaPods استفاده نمی کنید،
Podfile
،Podfile.resolved
وworkspace
Xcode را حذف کنید.
- از تنظیمات پیکربندی پروژه Xcode خود، Frameworks، Libraries و Embedded Content را پیدا کنید. برای حذف چارچوب زیر از علامت منفی (-) استفاده کنید:
-
GoogleMaps
-
GoogleMapsBase
(فقط برای نصب های زودتر از نسخه 9.0.0) -
GoogleMapsCore
(فقط برای نصب های زودتر از نسخه 9.0.0) -
GoogleMapsM4B
(فقط برای نصب های زودتر از نسخه 9.0.0)
-
- از دایرکتوری سطح بالای پروژه Xcode خود، بسته
GoogleMaps
حذف کنید.
CocoaPods
Maps SDK برای iOS به عنوان یک CocoaPods در دسترس است. CocoaPods یک مدیر وابستگی منبع باز برای پروژه های Swift و Objective-C Cocoa است.
اگر از قبل ابزار CocoaPods را ندارید، با اجرای دستور زیر از ترمینال، آن را روی macOS نصب کنید. برای جزئیات، به راهنمای شروع به کار CocoaPods مراجعه کنید.
sudo gem install cocoapods
یک Podfile
برای Maps SDK برای iOS ایجاد کنید و از آن برای نصب API و وابستگی های آن استفاده کنید:
- اگر هنوز پروژه Xcode ندارید، اکنون یکی را ایجاد کرده و آن را در دستگاه محلی خود ذخیره کنید. اگر در توسعه iOS تازه کار هستید:
- یک پروژه جدید ایجاد کنید.
- iOS > قالب برنامه را انتخاب کنید.
- در صفحه گزینه های پروژه:
- نام پروژه را وارد کنید.
- مقدار فیلد شناسه Bundle را ثبت کنید. می توانید از این مقدار برای محدود کردن کلید API خود در زیر استفاده کنید.
- Interface پروژه را روی Storyboard قرار دهید.
- زبان را روی Swift یا Objective-C قرار دهید.
- یک فایل به نام
Podfile
در دایرکتوری پروژه خود ایجاد کنید. این فایل وابستگی های پروژه شما را تعریف می کند. -
Podfile
را ویرایش کنید و وابستگی های خود را به همراه نسخه های آنها اضافه کنید. در اینجا یک مثال است که شامل وابستگی مورد نیاز برای Maps SDK برای iOS است:source 'https://github.com/CocoaPods/Specs.git' platform :ios, '15.0' target 'YOUR_APPLICATION_TARGET_NAME_HERE' do pod 'GoogleMaps', '8.4.0' end
مطمئن شوید که بهطور مرتبpod outdated
را اجرا میکنید تا تشخیص دهید که نسخه جدیدتری وجود دارد تا مطمئن شوید که همیشه در آخرین نسخه هستید. در صورت لزوم، به آخرین نسخه ارتقا دهید . -
Podfile
ذخیره کنید. یک ترمینال را باز کنید و به دایرکتوری حاوی
Podfile
بروید:cd <path-to-project>
دستور
pod install
را اجرا کنید. این API های مشخص شده درPodfile
را به همراه وابستگی هایی که ممکن است داشته باشند نصب می کند.pod install
Xcode را ببندید و سپس فایل
.xcworkspace
پروژه خود را باز کنید (دوبار کلیک کنید) تا Xcode راه اندازی شود. از این زمان به بعد باید از فایل.xcworkspace
برای باز کردن پروژه استفاده کنید.
برای به روز رسانی API برای یک پروژه موجود، این مراحل را دنبال کنید:
- یک ترمینال را باز کنید و به فهرست پروژه حاوی
Podfile
بروید. - دستور
pod update
را اجرا کنید. با این کار همه API های مشخص شده درPodfile
به آخرین نسخه به روز می شوند.
نصب دستی
این راهنما نشان می دهد که چگونه XCFrameworks حاوی Maps SDK برای iOS را به صورت دستی به پروژه خود اضافه کنید و تنظیمات ساخت خود را در Xcode پیکربندی کنید. XCFramework یک بسته باینری است که میتوانید در چندین پلتفرم از جمله ماشینهایی که از سیلیکون اپل استفاده میکنند استفاده کنید.- فایل های باینری و منبع SDK زیر را دانلود کنید:
- برای دسترسی به XCFrameworks و منابع، فایل ها را استخراج کنید.
- اگر هنوز پروژه Xcode ندارید، اکنون یکی را ایجاد کرده و آن را در دستگاه محلی خود ذخیره کنید. اگر در توسعه iOS تازه کار هستید:
- یک پروژه جدید ایجاد کنید.
- iOS > قالب برنامه را انتخاب کنید.
- در صفحه گزینه های پروژه:
- نام پروژه را وارد کنید.
- مقدار فیلد شناسه Bundle را ثبت کنید. می توانید از این مقدار برای محدود کردن کلید API خود در زیر استفاده کنید.
- Interface پروژه را روی Storyboard قرار دهید.
- زبان را روی Swift یا Objective-C قرار دهید.
- تب General را باز کنید. XCFrameworks زیر را به پروژه خود در بخش Frameworks، Libraries و Embedded Content بکشید. مطمئن شوید که برای هر XCFramework گزینه Do Not Embed را انتخاب کنید:
-
GoogleMaps.xcframework
-
GoogleMapsBase.xcframework
-
GoogleMapsCore.xcframework
-
-
GoogleMaps.bundle
از GoogleMapsResources که دانلود کردهاید در فهرست سطح بالای پروژه Xcode خود کپی کنید. وقتی از شما خواسته شد، مطمئن شوید که موارد کپی در پوشه گروه مقصد را انتخاب کنید. - پروژه خود را از Project Navigator انتخاب کنید و هدف برنامه خود را انتخاب کنید.
- تب Build Phases را برای هدف برنامه خود باز کنید. در لینک باینری با کتابخانه ها ، چارچوب ها و کتابخانه های زیر را اضافه کنید:
-
Accelerate.framework
-
Contacts.framework
-
CoreData.framework
-
CoreGraphics.framework
-
CoreImage.framework
-
CoreLocation.framework
-
CoreTelephony.framework
-
CoreText.framework
-
GLKit.framework
-
ImageIO.framework
-
libc++.tbd
-
libz.tbd
-
Metal.framework
-
OpenGLES.framework
(فقط اگر از OpenGL استفاده می کنید) -
QuartzCore.framework
-
SystemConfiguration.framework
-
UIKit.framework
-
پروژه خود را به جای یک هدف خاص انتخاب کنید و تب Build Settings را باز کنید. در بخش Linking - General -> Other Linker Flags ،
-ObjC
به "Debug" و "Release" اضافه کنید. اگر این تنظیمات قابل مشاهده نیستند، فیلتر را در نوار تنظیمات ساخت از Basic به All تغییر دهید.برای نصب Places SDK برای iOS XCFramework، به شروع کار با Places SDK برای iOS مراجعه کنید.
مرحله 3: فایل Apple Privacy Manifest را بررسی کنید
اپل به جزئیات حریم خصوصی برنامه برای برنامه های موجود در فروشگاه App نیاز دارد. برای بهروزرسانیها و اطلاعات بیشتر، از صفحه جزئیات حریم خصوصی فروشگاه App Apple دیدن کنید.
فایل Apple Privacy Manifest در بسته منابع برای SDK گنجانده شده است. برای تأیید اینکه فایل Manifest Privacy گنجانده شده است و برای بررسی محتوای آن، یک بایگانی از برنامه خود ایجاد کنید و یک گزارش حریم خصوصی از بایگانی ایجاد کنید .
مرحله 4: کلید API خود را به پروژه اضافه کنید
در دریافت کلید API ، یک کلید API برای برنامه خود ایجاد کردید. اکنون آن کلید را به پروژه Xcode خود اضافه کنید.
در مثالهای زیر، کلید API خود را جایگزین YOUR_API_KEY
کنید.
سویفت
کلید API خود را به صورت زیر به AppDelegate.swift
خود اضافه کنید:
- عبارت import زیر را اضافه کنید:
import GoogleMaps
- موارد زیر را با استفاده از کلید API خود به روش
application(_:didFinishLaunchingWithOptions:)
خود اضافه کنید:GMSServices.provideAPIKey("YOUR_API_KEY")
- اگر از Places API نیز استفاده میکنید، کلید خود را دوباره همانطور که در اینجا نشان داده شده است اضافه کنید:
GMSPlacesClient.provideAPIKey("YOUR_API_KEY")
هدف-C
کلید API خود را به صورت زیر به AppDelegate.m
خود اضافه کنید:
- عبارت import زیر را اضافه کنید:
@import GoogleMaps;
- موارد زیر را با استفاده از کلید API خود به متد:
application:didFinishLaunchingWithOptions:
خود اضافه کنید:[GMSServices provideAPIKey:@"YOUR_API_KEY"];
- اگر از Places API نیز استفاده میکنید، کلید خود را دوباره همانطور که در اینجا نشان داده شده است اضافه کنید:
[GMSPlacesClient provideAPIKey:@"YOUR_API_KEY"];
مرحله 5: یک نقشه اضافه کنید
سویفت
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 options = GMSMapViewOptions() options.camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 6.0) options.frame = self.view.bounds let mapView = GMSMapView(options: options) 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 } }
هدف-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. GMSMapViewOptions *options = [[GMSMapViewOptions alloc] init]; options.camera = [GMSCameraPosition cameraWithLatitude:-33.8683 longitude:151.2086 zoom:6]; options.frame = self.view.bounds; GMSMapView *mapView = [[GMSMapView alloc] initWithOptions:options]; [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
مرحله 5 (اختیاری): طرح های URL مورد استفاده توسط API را اعلام کنید
با شروع iOS 9 و Xcode 7، برنامهها میتوانند طرحهای URL را که میخواهند باز کنند، با مشخص کردن طرحها در فایل Info.plist
برنامه، اعلام کنند. Maps SDK برای iOS برنامه تلفن همراه Google Maps را زمانی که کاربر روی نشانواره Google روی نقشه کلیک میکند باز میکند و بنابراین برنامه شما میتواند طرحهای URL مربوطه را اعلام کند.
برای اعلام طرحهای URL مورد استفاده توسط Maps SDK برای iOS، خطوط زیر را به Info.plist
خود اضافه کنید:
تصویر زیر پیکربندی در رابط کاربری Xcode را نشان می دهد:
بدون اعلان بالا، هنگام ضربه زدن کاربر روی لوگوی گوگل روی نقشه، خطاهای زیر ممکن است رخ دهد:
- -canOpenURL: برای URL ناموفق بود: "comgooglemaps://" - خطا: "این برنامه مجاز به پرس و جو برای طرح comgooglemaps نیست"
- -canOpenURL: برای URL ناموفق بود: "googlechromes://" - خطا: "این برنامه مجاز به پرس و جو برای طرح googlechromes نیست"
برای حذف این خطاها، اعلان را به Info.plist
خود اضافه کنید.
بعدش چی
اکنون که یک کلید API و یک پروژه Xcode دارید، می توانید برنامه ها را ایجاد و اجرا کنید. Navigation SDK برای iOS آموزش ها و نمونه برنامه های زیادی را ارائه می دهد که می تواند به شما در شروع کار کمک کند. برای جزئیات بیشتر، نگاه کنید به: