mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 01:25:39 +00:00
7a68691686
Summary: ### MapView to support Pin annotation var pinLocation = { latitude: property.latitude, longitude: property.longitude, title: property.title }; this.state = {propertyPoint: pinLocation}; <MapView style={styles.map} region={this.state.region} annotate={this.state.propertyPoint}> </MapView> ![mapview-pinannotation](https://cloud.githubusercontent.com/assets/845379/7100280/6c1ffc08-dfe5-11e4-9d1b-8da6a65da1bc.png) Closes https://github.com/facebook/react-native/pull/810 Github Author: guru inamdar <guru.inamdar@gmail.com> Test Plan: Imported from GitHub, without a `Test Plan:` line.
47 lines
1010 B
Objective-C
47 lines
1010 B
Objective-C
//
|
|
// RCTConvert+MapKit.m
|
|
// React
|
|
//
|
|
// Created by Nick Lockwood on 12/04/2015.
|
|
// Copyright (c) 2015 Facebook. All rights reserved.
|
|
//
|
|
|
|
#import "RCTConvert+MapKit.h"
|
|
|
|
#import "RCTConvert+CoreLocation.h"
|
|
|
|
@implementation RCTConvert(MapKit)
|
|
|
|
+ (MKCoordinateSpan)MKCoordinateSpan:(id)json
|
|
{
|
|
json = [self NSDictionary:json];
|
|
return (MKCoordinateSpan){
|
|
[self CLLocationDegrees:json[@"latitudeDelta"]],
|
|
[self CLLocationDegrees:json[@"longitudeDelta"]]
|
|
};
|
|
}
|
|
|
|
+ (MKCoordinateRegion)MKCoordinateRegion:(id)json
|
|
{
|
|
return (MKCoordinateRegion){
|
|
[self CLLocationCoordinate2D:json],
|
|
[self MKCoordinateSpan:json]
|
|
};
|
|
}
|
|
|
|
+ (MKShape *)MKShape:(id)json
|
|
{
|
|
json = [self NSDictionary:json];
|
|
|
|
// TODO: more shape types
|
|
MKShape *shape = [[MKPointAnnotation alloc] init];
|
|
shape.coordinate = [self CLLocationCoordinate2D:json];
|
|
shape.title = [RCTConvert NSString:json[@"title"]];
|
|
shape.subtitle = [RCTConvert NSString:json[@"subtitle"]];
|
|
return shape;
|
|
}
|
|
|
|
RCT_ARRAY_CONVERTER(MKShape)
|
|
|
|
@end
|