मार्कर वाला मैप जोड़ना

इस ट्यूटोरियल में, iOS ऐप्लिकेशन में मार्कर के साथ Google मैप जोड़ने का तरीका बताया गया है. यह उन लोगों के लिए सही है जिन्हें Swift या Objective-C की बुनियादी या सामान्य जानकारी है. साथ ही, उन्हें Xcode की सामान्य जानकारी भी है. मैप बनाने के बारे में बेहतर गाइड के लिए, डेवलपर गाइड पढ़ें.

इस ट्यूटोरियल का इस्तेमाल करके, यह मैप बनाया जाएगा. मार्कर को ऑस्ट्रेलिया के सिडनी शहर में रखा गया है.

सिडनी के ऊपर मार्कर के साथ मैप दिखाने वाला स्क्रीनशॉट

कोड प्राप्त करें

GitHub पर मौजूद Google Maps iOS के सैंपल की रिपॉज़िटरी को क्लोन करें या डाउनलोड करें.

इसके अलावा, सोर्स कोड को डाउनलोड करने के लिए, इस बटन पर क्लिक करें:

मुझे कोड दें

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 Package Manager

Maps SDK for iOS को Swift Package Manager का इस्तेमाल करके इंस्टॉल किया जा सकता है.

  1. Maps SDK for 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. File > Add Package Dependencies पर जाएं.
  6. यूआरएल के तौर पर https://github.com/googlemaps/ios-maps-sdk डालें. इसके बाद, पैकेज को पुल करने के लिए Enter दबाएं और Add Package पर क्लिक करें.
  7. आपको File > Packages > Reset Package Cache का इस्तेमाल करके, पैकेज कैश मेमोरी को रीसेट करना पड़ सकता है.

CocoaPods का इस्तेमाल करना

  1. Xcode version 16.0 या इसके बाद का वर्शन डाउनलोड और इंस्टॉल करें.
  2. अगर आपके पास पहले से CocoaPods नहीं है, तो macOS पर इसे इंस्टॉल करें. इसके लिए, टर्मिनल में यह कमांड डालें:
    sudo gem install cocoapods
  3. tutorials/map-with-marker डायरेक्ट्री पर जाएं.
  4. pod install कमांड चलाएं. इससे Podfile में बताया गया Maps SDK और उससे जुड़ी सभी डिपेंडेंसी इंस्टॉल हो जाएंगी.
  5. इंस्टॉल किए गए पॉड के वर्शन की तुलना नए अपडेट से करने के लिए, pod outdated चलाएं. अगर कोई नया वर्शन मिलता है, तो Podfile को अपडेट करने और एसडीके का नया वर्शन इंस्टॉल करने के लिए, pod update चलाएं. ज़्यादा जानकारी के लिए, CocoaPods गाइड देखें.
  6. प्रोजेक्ट की map-with-marker.xcworkspace फ़ाइल को Xcode में खोलने के लिए, उसे खोलें (दो बार क्लिक करें). प्रोजेक्ट खोलने के लिए, आपको .xcworkspace फ़ाइल का इस्तेमाल करना होगा.

एपीआई पासकोड पाएं और ज़रूरी एपीआई चालू करें

इस ट्यूटोरियल को पूरा करने के लिए, आपके पास Google API कुंजी होनी चाहिए. साथ ही, उसे Maps SDK for iOS का इस्तेमाल करने की अनुमति मिली होनी चाहिए. कुंजी पाने और एपीआई चालू करने के लिए, इस बटन पर क्लिक करें.

शुरू करें

ज़्यादा जानकारी के लिए, एपीआई कुंजी पाना लेख पढ़ें.

अपने ऐप्लिकेशन में एपीआई पासकोड जोड़ना

अपनी एपीआई कुंजी को AppDelegate.swift में इस तरह जोड़ें:

  1. ध्यान दें कि फ़ाइल में यह इंपोर्ट स्टेटमेंट जोड़ा गया है:
    import GoogleMaps
  2. अपने application(_:didFinishLaunchingWithOptions:) तरीके में इस लाइन में बदलाव करें. साथ ही, YOUR_API_KEY को अपनी एपीआई पासकोड से बदलें:
    GMSServices.provideAPIKey("YOUR_API_KEY")

ऐप्लिकेशन बनाना और उसे चलाना

  1. किसी iOS डिवाइस को अपने कंप्यूटर से कनेक्ट करें या Xcode स्कीम मेन्यू से कोई सिम्युलेटर चुनें.
  2. अगर किसी डिवाइस का इस्तेमाल किया जा रहा है, तो पक्का करें कि जगह की जानकारी देने वाली सेवाएं चालू हों. अगर सिम्युलेटर का इस्तेमाल किया जा रहा है, तो सुविधाएं मेन्यू से कोई जगह चुनें.
  3. Xcode में, Product/Run मेन्यू विकल्प पर क्लिक करें या प्ले बटन आइकॉन पर क्लिक करें.
    • Xcode, ऐप्लिकेशन को बनाता है. इसके बाद, ऐप्लिकेशन को डिवाइस या सिम्युलेटर पर चलाता है.
    • आपको ऑस्ट्रेलिया के पूर्वी तट पर मौजूद सिडनी शहर का मैप दिखेगा. इसमें सिडनी को सेंटर में दिखाया गया होगा. यह मैप, इस पेज पर मौजूद इमेज की तरह दिखेगा.

समस्या का हल:

  • अगर आपको मैप नहीं दिख रहा है, तो पक्का करें कि आपने एपीआई कुंजी हासिल कर ली हो और उसे ऐप्लिकेशन में जोड़ दिया हो. इसके बारे में पहले बताया जा चुका है. एपीआई पासकोड से जुड़ी गड़बड़ी के मैसेज देखने के लिए, Xcode के डीबगिंग कंसोल को देखें.
  • अगर आपने एपीआई कुंजी को iOS बंडल आइडेंटिफ़ायर के हिसाब से सीमित किया है, तो ऐप्लिकेशन के लिए बंडल आइडेंटिफ़ायर जोड़ने के लिए, कुंजी में बदलाव करें: com.google.examples.map-with-marker.
  • पक्का करें कि आपके पास अच्छा वाई-फ़ाई या जीपीएस कनेक्शन हो.
  • ऐप्लिकेशन को डीबग करने और लॉग देखने के लिए, 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;
          

डिफ़ॉल्ट रूप से, Maps SDK for iOS, उपयोगकर्ता के मार्कर पर टैप करने पर जानकारी वाली विंडो का कॉन्टेंट दिखाता है. अगर आपको डिफ़ॉल्ट व्यवहार का इस्तेमाल करना है, तो मार्कर के लिए क्लिक लिसनर जोड़ने की ज़रूरत नहीं है.

बधाई हो! आपने एक iOS ऐप्लिकेशन बनाया है. यह ऐप्लिकेशन, Google मैप दिखाता है. इसमें किसी जगह को दिखाने के लिए मार्कर का इस्तेमाल किया जाता है. आपने iOS के लिए Maps SDK का इस्तेमाल करने का तरीका भी सीखा है.

अगले चरण

मैप ऑब्जेक्ट के बारे में ज़्यादा जानें. साथ ही, जानें कि मार्कर का इस्तेमाल कैसे किया जा सकता है.