1

主にタイ向けに作成されているため、インターネット接続が難しいことが多いため、アプリのオフライン マップを作成する必要があります。私は現在 OpenStreetMap を使用してMKTileOverlayいますが、オフラインで使用するために実装する際に問題があります。MKTileOverlay をサブクラス化するというチュートリアルを見つけました。したがって、マップがあるViewControllerには次のものがあります。

 -(void) viewWillAppear:(BOOL)animated {
CLLocationCoordinate2D coord = {.latitude =  15.8700320, .longitude =  100.9925410};
MKCoordinateSpan span = {.latitudeDelta =  3, .longitudeDelta =  3};
MKCoordinateRegion region = {coord, span};
[mapView setRegion:region];
}
- (void)viewDidLoad {
    [super viewDidLoad];
    self.title = @"Map";
    NSString *template = @"http://tile.openstreetmap.org/{z}/{x}/{y}.png";
    self.overlay = [[XXTileOverlay alloc] initWithURLTemplate:template];
    self.overlay.canReplaceMapContent = YES;
    [mapView addOverlay:self.overlay level:MKOverlayLevelAboveLabels];


}
- (MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id)overlay {

        return [[MKTileOverlayRenderer alloc] initWithTileOverlay:overlay];

}

MKTileOverlay のサブクラスには、次のものがあります。

- (NSURL *)URLForTilePath:(MKTileOverlayPath)path {
    return [NSURL URLWithString:[NSString stringWithFormat:@"http://tile.openstreetmap.org/{%ld}/{%ld}/{%ld}.png", (long)path.z, (long)path.x, (long)path.y]];
}

- (void)loadTileAtPath:(MKTileOverlayPath)path
                result:(void (^)(NSData *data, NSError *error))result
{
    if (!result) {
        return;
    }
    NSData *cachedData = [self.cache objectForKey:[self URLForTilePath:path]];
    if (cachedData) {
        result(cachedData, nil);
    } else {
        NSURLRequest *request = [NSURLRequest requestWithURL:[self URLForTilePath:path]];
        [NSURLConnection sendAsynchronousRequest:request queue:self.operationQueue completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
            result(data, connectionError);
        }];
    }
}

問題は、サブクラスのコードをコメントアウトしない限り、何もロードされないことです。私はどこを台無しにしていますか?

4

2 に答える 2

2

オフライン モードでマップを読み込むことにも興味があります。

  1. まず、gmapcatcherを使用してタイルをローカル システム (コンピューター) にダウンロードしました。

    gmapcatcherに関する情報は、こちらで入手できます。このアプリケーションは、ここからダウンロードできます。

    ファイルをダウンロードしてオフラインでチェックする場合のもう 1 つの重要な点 は、ファイルを保存する方法がたくさんあることです。このシナリオでは、設定ウィンドウでOSMを選択します (設定ウィンドウでダウンロードするパスを指定する左側にあります)。

  2. 作成したタイル フォルダーをプロジェクトに追加するだけです。

  3. そして、私はobjective-cを知らないので、迅速に実装していて、そのコードのみを投稿しました。

ここにコードがあります

import UIKit
import MapKit
class ViewController: UIViewController, MKMapViewDelegate {
    @IBOutlet weak var mapView: MKMapView!

    override func viewDidLoad() {
        super.viewDidLoad()
        self.mapView.delegate = self

        let baseURL = NSBundle.mainBundle().bundleURL.absoluteString
        let urlTemplate = baseURL.stringByAppendingString("OSM_sat_tiles/{z}/{x}/{y}.png")
        //OSM_sat_tiles is the folder name which has the tiles.
        let layer = MKTileOverlay(URLTemplate: urlTemplate)
        layer.canReplaceMapContent = true
        self.mapView.addOverlay(layer)
    }

    func mapView(mapView: MKMapView, rendererForOverlay overlay: MKOverlay) -> MKOverlayRenderer {
        if overlay is MKTileOverlay {
            let renderer = MKTileOverlayRenderer(overlay:overlay)
            renderer.alpha = 0.8
            return renderer
        }
        return MKTileOverlayRenderer(overlay: overlay)
    }
}

コードについて簡単に説明します。

viewDidLoadデリゲート メソッドで、タイル フォルダーのパスを指定してMKTileOverlayを作成しています。プロジェクトに配置したので、バンドルになります。

rendererForOverlayデリゲート メソッドでは、MKTileOverlayRenderer を返して います

于 2016-08-12T04:44:49.277 に答える