پس از فعال کردن پرداخت و ایجاد کلید API، آمادهاید تا پروژه Xcode مورد استفاده برای توسعه برنامه خود را راهاندازی کنید.
یادداشتهای انتشار برای هر نسخه موجود است.
مرحله ۱: نصب نرمافزارهای مورد نیاز
برای ساخت یک پروژه با استفاده از Maps SDK برای iOS، باید موارد زیر را دانلود و نصب کنید:
- نسخه Xcode 16.0 یا بالاتر
مرحله 2: ایجاد پروژه Xcode و نصب Maps SDK برای iOS
حجم نصب SDK میتواند متفاوت باشد. برای مثال، حجم نصب Maps SDK برای iOS نسخه ۹.۰ حدود ۱۸ مگابایت است.
مدیر بسته سوئیفت
کیت توسعه نرمافزار Maps برای iOS را میتوان از طریق Swift Package Manager نصب کرد. برای افزودن SDK، مطمئن شوید که هرگونه وابستگی Maps SDK موجود برای iOS را حذف کردهاید.
برای اضافه کردن SDK به یک پروژه جدید یا موجود، مراحل زیر را دنبال کنید:
-
projectیاworkspaceXcode خود را باز کنید، سپس به File > Add Package Dependencies بروید. - آدرس https://github.com/googlemaps/ios-maps-sdk را به عنوان URL وارد کنید، برای دریافت بسته، Enter را فشار دهید و روی «افزودن بسته» کلیک کنید.
- برای نصب یک
versionخاص، فیلد Dependency Rule را روی یکی از گزینههای مبتنی بر نسخه تنظیم کنید. برای پروژههای جدید، توصیه میکنیم آخرین نسخه را مشخص کرده و از گزینه "Exact Version" استفاده کنید. پس از تکمیل، روی "Add Package" کلیک کنید.
برای بهروزرسانی package برای یک پروژه موجود، مراحل زیر را دنبال کنید:
اگر از نسخهای قبل از ۹.۰.۰ ارتقا میدهید، باید وابستگیهای زیر را حذف کنید:
GoogleMapsBase،GoogleMapsCoreوGoogleMapsM4Bپس از ارتقا. وابستگی مربوط بهGoogleMapsرا حذف نکنید. برای اطلاعات بیشتر، به یادداشتهای انتشار نسخه ۹.۰.۰ مراجعه کنید.از تنظیمات پیکربندی پروژه Xcode خود، Frameworks، Libraries و Embedded Content را پیدا کنید. از علامت منها (-) برای حذف framework زیر استفاده کنید:
-
GoogleMapsBase(فقط برای ارتقاء از نسخههای قبل از ۹.۰.۰) -
GoogleMapsCore(فقط برای ارتقاء از نسخههای پایینتر از ۹.۰.۰) -
GoogleMapsM4B(فقط برای ارتقاء از نسخههای قبل از ۹.۰.۰)
-
- از Xcode، به «فایل > بستهها > بهروزرسانی به آخرین نسخههای بسته» بروید.
- برای تأیید نصب خود، به بخش وابستگیهای بستهبندی در Project Navigator بروید تا بسته و نسخه آن را تأیید کنید.
برای حذف وابستگیهای Maps SDK موجود برای iOS که با استفاده از CocoaPods اضافه شدهاند، این مراحل را دنبال کنید:
- فضای کاری Xcode خود را ببندید. ترمینال را باز کنید و دستور زیر را اجرا کنید:
sudo gem install cocoapods-deintegrate cocoapods-clean pod deintegrate pod cache clean --all
- اگر از
Podfile،Podfile.resolvedوworkspaceXcode برای چیزی غیر از CocoaPods استفاده نمیکنید، آنها را حذف کنید.
- از تنظیمات پیکربندی پروژه Xcode خود، Frameworks، Libraries و Embedded Content را پیدا کنید. از علامت منها (-) برای حذف framework زیر استفاده کنید:
-
GoogleMaps -
GoogleMapsBase(فقط برای نصبهای قدیمیتر از نسخه ۹.۲.۰) -
GoogleMapsCore(فقط برای نصبهای قبل از نسخه ۹.۲.۰) -
GoogleMapsM4B(فقط برای نصبهای قدیمیتر از نسخه ۹.۰.۰)
-
- از دایرکتوری سطح بالای پروژه Xcode خود، بسته
GoogleMapsرا حذف کنید.
نصب دستی
این راهنما نحوه اضافه کردن دستی XCFrameworks حاوی Maps SDK برای iOS را به پروژه شما و پیکربندی تنظیمات ساخت در Xcode نشان میدهد. XCFramework یک بسته دودویی است که میتوانید در چندین پلتفرم، از جمله دستگاههایی که از Apple silicon استفاده میکنند، استفاده کنید.
- فایلهای باینری و منابع SDK زیر را دانلود کنید:
- برای دسترسی به XCFrameworks و منابع، فایلها را استخراج کنید.
- اگر هنوز پروژه Xcode ندارید، همین حالا یکی ایجاد کنید و آن را در دستگاه محلی خود ذخیره کنید. اگر در توسعه iOS تازهکار هستید:
- یک پروژه جدید ایجاد کنید.
- قالب iOS > App را انتخاب کنید.
- در صفحه گزینههای پروژه:
- نام پروژه را وارد کنید.
- مقدار فیلد شناسه بسته (Bundle identifier) را ثبت کنید. میتوانید از آن مقدار برای محدود کردن کلید API خود در زیر استفاده کنید.
- رابط پروژه را روی Storyboard تنظیم کنید.
- زبان را روی Swift یا Objective-C تنظیم کنید.
- برگه عمومی ( General ) را باز کنید. XCFrameworks زیر را در قسمت چارچوبها (Frameworks)، کتابخانهها (Libraries) و محتوای جاسازیشده (Embedded Content) به پروژه خود بکشید (drag) و رها کنید. مطمئن شوید که گزینه «عدم جاسازی» (Do Not Embed) را انتخاب کردهاید:
-
GoogleMaps.xcframework
-
-
GoogleMaps.bundleرا از GoogleMapsResources که دانلود کردهاید، در دایرکتوری سطح بالای پروژه Xcode خود کپی کنید. هنگام درخواست، حتماً گزینه Copy items into destination group’s folder را انتخاب کنید. - پروژه خود را از Project Navigator انتخاب کنید و هدف برنامه خود را نیز مشخص کنید.
- تب Build Phases را برای برنامهی هدف خود باز کنید. در داخل Link Binary with Libraries ، فریمورکها و کتابخانههای زیر را اضافه کنید:
-
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 -
MetricKit.framework -
OpenGLES.framework(فقط در صورتی که از OpenGL استفاده میکنید) -
QuartzCore.framework -
Security.framework -
SystemConfiguration.framework -
UIKit.framework
-
پروژه خود را انتخاب کنید، نه یک هدف خاص، و برگه تنظیمات ساخت را باز کنید. در بخش Linking - General -> Other Linker Flags ،
-ObjCبه "Debug" و "Release" اضافه کنید. اگر این تنظیمات قابل مشاهده نیستند، فیلتر را در نوار تنظیمات ساخت از Basic به All تغییر دهید.برای نصب Places SDK برای iOS XCFramework، به بخش «شروع به کار با Places SDK برای iOS» مراجعه کنید.
کوکوپادز
کیت توسعه نرمافزار نقشهها برای iOS به عنوان یک پاد CocoaPods در دسترس است. CocoaPods یک ابزار مدیریت وابستگی متنباز برای پروژههای Swift و Objective-C Cocoa است.
اگر ابزار CocoaPods را از قبل ندارید، با اجرای دستور زیر از ترمینال، آن را روی macOS نصب کنید. برای جزئیات بیشتر، به راهنمای شروع به کار با CocoaPods مراجعه کنید.
sudo gem install cocoapods
یک Podfile برای Maps SDK برای iOS ایجاد کنید و از آن برای نصب API و وابستگیهای آن استفاده کنید:
- اگر هنوز پروژه Xcode ندارید، همین حالا یکی ایجاد کنید و آن را در دستگاه محلی خود ذخیره کنید. اگر در توسعه iOS تازهکار هستید:
- یک پروژه جدید ایجاد کنید.
- قالب iOS > App را انتخاب کنید.
- در صفحه گزینههای پروژه:
- نام پروژه را وارد کنید.
- مقدار فیلد شناسه بسته (Bundle identifier) را ثبت کنید. میتوانید از آن مقدار برای محدود کردن کلید API خود در زیر استفاده کنید.
- رابط پروژه را روی Storyboard تنظیم کنید.
- زبان را روی Swift یا Objective-C تنظیم کنید.
- فایلی با نام
Podfileدر دایرکتوری پروژه خود ایجاد کنید. این فایل وابستگیهای پروژه شما را تعریف میکند. -
Podfileرا ویرایش کنید و وابستگیهای خود را به همراه نسخههای آنها اضافه کنید. در اینجا مثالی آورده شده است که شامل وابستگی مورد نیاز برای Maps SDK برای iOS است: مرتباًsource 'https://github.com/CocoaPods/Specs.git' platform :ios, '16.0' target 'YOUR_APPLICATION_TARGET_NAME_HERE' do pod 'GoogleMaps', '10.4.0' end
pod outdatedرا اجرا کنید تا زمان انتشار نسخه جدیدتر را تشخیص دهد و مطمئن شوید که همیشه از آخرین نسخه استفاده میکنید. در صورت لزوم، به آخرین نسخه ارتقا دهید . -
Podfileرا ذخیره کنید. یک ترمینال باز کنید و به دایرکتوری حاوی
Podfileبروید:cd <path-to-project>
دستور
pod installرا اجرا کنید. این دستور API های مشخص شده درPodfileرا به همراه هرگونه وابستگی که ممکن است داشته باشند، نصب خواهد کرد.pod install
Xcode را ببندید و سپس فایل
.xcworkspaceپروژه خود را باز کنید (روی آن دوبار کلیک کنید). از این به بعد، برای باز کردن پروژه باید از فایل.xcworkspaceاستفاده کنید.
برای بهروزرسانی API برای یک پروژه موجود، مراحل زیر را دنبال کنید:
- یک ترمینال باز کنید و به دایرکتوری پروژه حاوی
Podfileبروید. - دستور
pod updateرا اجرا کنید. این دستور تمام API های مشخص شده درPodfileرا به آخرین نسخه به روز می کند.
مرحله ۳: کلید API خود را به پروژه اضافه کنید
در بخش Get an API key ، شما یک کلید API برای برنامه خود ایجاد کردهاید. اکنون آن کلید را به پروژه Xcode خود اضافه کنید.
در مثالهای زیر، YOUR_API_KEY با کلید API خود جایگزین کنید.
سویفت
کلید API خود را به صورت زیر به AppDelegate.swift خود اضافه کنید:
- عبارت import زیر را اضافه کنید:
import GoogleMaps
- با استفاده از کلید API خود، کد زیر را به
application(_:didFinishLaunchingWithOptions:)خود اضافه کنید:GMSServices.provideAPIKey("YOUR_API_KEY")
- اگر از Places API نیز استفاده میکنید، کلید خود را دوباره همانطور که در اینجا نشان داده شده است اضافه کنید:
GMSPlacesClient.provideAPIKey("YOUR_API_KEY")
هدف-سی
کلید API خود را به صورت زیر به AppDelegate.m خود اضافه کنید:
- عبارت import زیر را اضافه کنید:
@import GoogleMaps;
- با استفاده از کلید API خود، کد زیر را به
application:didFinishLaunchingWithOptions:اضافه کنید:[GMSServices provideAPIKey:@"YOUR_API_KEY"];
- اگر از Places API نیز استفاده میکنید، کلید خود را دوباره همانطور که در اینجا نشان داده شده است اضافه کنید:
[GMSPlacesClient provideAPIKey:@"YOUR_API_KEY"];
مرحله ۴ (اختیاری): بررسی فایل مانیفست حریم خصوصی اپل
اپل برای برنامههای موجود در اپ استور، جزئیات حریم خصوصی برنامه را الزامی میداند. برای بهروزرسانیها و اطلاعات بیشتر، از صفحه جزئیات حریم خصوصی اپ استور اپل دیدن کنید.
فایل «بیانیه حریم خصوصی اپل» در بسته منابع SDK گنجانده شده است. برای تأیید اینکه فایل «بیانیه حریم خصوصی» گنجانده شده است و برای بررسی محتوای آن، یک بایگانی از برنامه خود ایجاد کنید و یک گزارش حریم خصوصی از بایگانی تهیه کنید .
مرحله ۵ (اختیاری): طرحهای URL مورد استفاده توسط API را اعلام کنید
با شروع iOS 9 و Xcode 7، برنامهها میتوانند طرحهای URL که قصد باز کردن آنها را دارند، با مشخص کردن طرحها در فایل Info.plist برنامه، اعلام کنند. Maps SDK برای iOS، برنامه موبایل Google Maps را هنگامی که کاربر روی لوگوی گوگل روی نقشه کلیک میکند، باز میکند و بنابراین برنامه شما میتواند طرحهای URL مربوطه را اعلام کند.
برای اعلام طرحهای URL مورد استفاده توسط Maps SDK برای iOS، خطوط زیر را به Info.plist خود اضافه کنید:
<key>LSApplicationQueriesSchemes</key>
<array>
<string>googlechromes</string>
<string>comgooglemaps</string>
</array>
تصویر زیر پیکربندی رابط کاربری Xcode را نشان میدهد:

بدون تعریف فوق، وقتی کاربر روی لوگوی گوگل روی نقشه ضربه میزند، خطاهای زیر ممکن است رخ دهد:
-
-canOpenURL: failed for URL: "comgooglemaps://" - error: "This app is not allowed to query for scheme comgooglemaps" -
-canOpenURL: failed for URL: "googlechromes://" - error: "This app is not allowed to query for scheme googlechromes"
برای حذف این خطاها، این اعلان را به Info.plist خود اضافه کنید.
قدم بعدی چیست؟
اکنون که یک کلید API و یک پروژه Xcode دارید، میتوانید برنامهها را ایجاد و اجرا کنید. کیت توسعه نرمافزار ناوبری برای iOS آموزشها و برنامههای نمونه زیادی را ارائه میدهد که میتواند به شما در شروع کار کمک کند. برای جزئیات بیشتر، به موارد زیر مراجعه کنید:
- آموزشهای زیر به عنوان نقطه شروع توصیه میشوند:
- نمونه کدها و آزمایشگاههای کد موجود را بررسی کنید.
- برای راهحلهای جامع، راهحلهای نقشههای موجود را بررسی کنید.