iOS - Mengakses Peta

Peta selalu membantu kami untuk menemukan tempat. Peta terintegrasi di iOS menggunakan kerangka kerja MapKit.

Langkah-langkah yang Terlibat

Step 1 - Buat aplikasi berbasis tampilan sederhana.

Step 2 - Pilih file proyek Anda, lalu pilih target dan kemudian tambahkan MapKit.framework.

Step 3 - Kami juga harus menambahkan Corelocation.framework.

Step 4 - Tambahkan MapView ke ViewController.xib dan buat ibOutlet dan beri nama sebagai mapView.

Step 5 - Buat file baru dengan memilih File → New → File ... → pilih kelas Objective C dan klik next.

Step 6 - Beri nama kelas sebagai MapAnnotation dengan "subkelas" sebagai NSObject.

Step 7 - Pilih buat.

Step 8 - Perbarui MapAnnotation.h sebagai berikut -

#import <Foundation/Foundation.h>
#import <MapKit/MapKit.h>

@interface MapAnnotation : NSObject<MKAnnotation>
@property (nonatomic, strong) NSString *title;
@property (nonatomic, readwrite) CLLocationCoordinate2D coordinate;

- (id)initWithTitle:(NSString *)title andCoordinate:
   (CLLocationCoordinate2D)coordinate2d;

@end

Step 9 - Perbarui MapAnnotation.m sebagai berikut -

#import "MapAnnotation.h"

@implementation MapAnnotation
-(id)initWithTitle:(NSString *)title andCoordinate:
   (CLLocationCoordinate2D)coordinate2d {
  
   self.title = title;
   self.coordinate =coordinate2d;
   return self;
}
@end

Step 10 - Perbarui ViewController.h sebagai berikut -

#import <UIKit/UIKit.h>
#import <MapKit/MapKit.h>
#import <CoreLocation/CoreLocation.h>

@interface ViewController : UIViewController<MKMapViewDelegate> {
   MKMapView *mapView;
}
@end

Step 11 - Perbarui ViewController.m sebagai berikut -

#import "ViewController.h"
#import "MapAnnotation.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   mapView = [[MKMapView alloc]initWithFrame:
   CGRectMake(10, 100, 300, 300)];
   mapView.delegate = self;
   mapView.centerCoordinate = CLLocationCoordinate2DMake(37.32, -122.03);
   mapView.mapType = MKMapTypeHybrid;
   CLLocationCoordinate2D location;
   location.latitude = (double) 37.332768;
   location.longitude = (double) -122.030039;
   
   // Add the annotation to our map view
   MapAnnotation *newAnnotation = [[MapAnnotation alloc]
   initWithTitle:@"Apple Head quaters" andCoordinate:location];
   [mapView addAnnotation:newAnnotation];
   CLLocationCoordinate2D location2;
   location2.latitude = (double) 37.35239;
   location2.longitude = (double) -122.025919;
   MapAnnotation *newAnnotation2 = [[MapAnnotation alloc] 
   initWithTitle:@"Test annotation" andCoordinate:location2];
   [mapView addAnnotation:newAnnotation2];
   [self.view addSubview:mapView];
}

// When a map annotation point is added, zoom to it (1500 range)
- (void)mapView:(MKMapView *)mv didAddAnnotationViews:(NSArray *)views {
   MKAnnotationView *annotationView = [views objectAtIndex:0];
   id <MKAnnotation> mp = [annotationView annotation];
   MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance
   ([mp coordinate], 1500, 1500);
   [mv setRegion:region animated:YES];
   [mv selectAnnotation:mp animated:YES];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

Keluaran

Saat kami menjalankan aplikasi, kami akan mendapatkan output seperti yang ditunjukkan di bawah ini -

Saat kita menggulir peta ke atas, kita akan mendapatkan output seperti yang ditunjukkan di bawah ini -