2

MKReverseGeoCoderを使用してユーザーの現在地の都市の名前を取得しようとしていますが、認識できないエラーがいくつかあります。詳細は次のとおりです。

認識できないエラーがあります

Undefined symbols:
  ".objc_class_name_CLLocationManager", referenced from:
      literal-pointer@__OBJC@__cls_refs@CLLocationManager in mapViewController.o
  "_kCLLocationAccuracyNearestTenMeters", referenced from:
      _kCLLocationAccuracyNearestTenMeters$non_lazy_ptr in mapViewController.o
ld: symbol(s) not found
collect2: ld returned 1 exit status

ここに私のコードがあります:

mapViewController.m

//
//  mapViewController.m
//  map
//
//  Created by Ashutosh Tiwari on 7/23/10.
//  Copyright ISU 2010. All rights reserved.
//
#import <MapKit/MapKit.h>
#import "mapViewController.h"

@implementation mapViewController


// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
- (void)viewDidLoad {
    CLLocationManager *locationManager = [[[CLLocationManager alloc] init] autorelease];
    locationManager.delegate = self;
    locationManager.desiredAccuracy = kCLLocationAccuracyNearestTenMeters;
    [locationManager startUpdatingLocation];

    [super viewDidLoad];
}

- (void)locationManager:(CLLocationManager *)manager didUpdateToLocation:(CLLocation *)newLocation fromLocation:(CLLocation *)oldLocation 
{

    MKReverseGeocoder *geoCoder = [[MKReverseGeocoder alloc] initWithCoordinate:newLocation.coordinate];
    geoCoder.delegate = self;
    [geoCoder start];
}

- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error 
{
    NSLog(@"locationManager:%@ didFailWithError:%@", manager, error);
}

- (void)reverseGeocoder:(MKReverseGeocoder *)geocoder didFindPlacemark:(MKPlacemark *)placemark
{
    MKPlacemark * myPlacemark = placemark;

    NSString *kABPersonAddressCityKey;
    NSString *city = [myPlacemark.addressDictionary objectForKey:(NSString*) kABPersonAddressCityKey];
}

- (void)reverseGeocoder:(MKReverseGeocoder *)geocoder didFailWithError:(NSError *)error
{
    NSLog(@"reverseGeocoder:%@ didFailWithError:%@", geocoder, error);
}

- (void)dealloc {
    [super dealloc];
}

@end
4

1 に答える 1

8

プロジェクトにリンクするために追加CoreLocation.frameworkします(ターゲット設定/リンクされたライブラリ/追加/ CoreLocation.frameworkを選択します)

追加:各メソッドの機能を簡単に説明します。

  • viewDidLoad:
    インスタンスを作成CLLocationManagerし、場所の更新を開始します-現在のユーザー座標を取得します

  • locationManager:didUpdateToLocation:
    CLLocationManagerがユーザー座標を受信したときに呼び出されます。これで、それらをに渡してMKReverseGeocoder、ユーザーの場所(国、都市など)の情報を取得できます。

  • locationManager:didFailWithError:reverseGeocoder:didFailWithError:
    発生する可能性のあるエラーを処理します-現在の実装にログインするだけです

  • reverseGeocoder:didFindPlacemark:座標の情報が見つかっ
    たときに呼び出され、取得したインスタンスMKReverseGeocoderの対応するフィールドから必要な情報を取得できます。MKPlacemark

kABPersonAddressCityKey-目印アドレスディクショナリのCityフィールドのキー文字列です。目印とABRecordアドレスのアドレスフィールドが同じであるため、ABPerson.hヘッダーで定義されています。したがって、そのキーを使用するには、フレームワークともリンクする必要がある場合がありAddressBookます。

于 2010-07-25T16:45:42.510 に答える