質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

Q&A

解決済

1回答

1656閲覧

地図上にルートを表示させたい

sennin2911

総合スコア4

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

0グッド

0クリップ

投稿2020/06/27 17:57

東京の座標を基準に、ロングタップした位置までのルートをマップに表示させたいです。
リンクを参考にしましたが、ラインを表示させられません。

html

1 2import UIKit 3import MapKit 4import CoreLocation 5 6class ViewController: UIViewController,CLLocationManagerDelegate,UIGestureRecognizerDelegate { 7 8 9 10 @IBOutlet weak var mapView: MKMapView! 11 12 var routePolyLine: MKPolyline! 13 14 override func viewDidLoad() { 15 super.viewDidLoad() 16 // Do any additional setup after loading the view. 17 } 18 19 @IBAction func longTapAction(_ sender: UILongPressGestureRecognizer) { 20 21 if sender.state == .began{ 22 23 }else if sender.state == .ended{ 24 25 let tapPoint = sender.location(in: view) 26 27 let tapCenter = mapView.convert(tapPoint, toCoordinateFrom: mapView) 28 29 routeSearch(tapCenter: tapCenter) 30 } 31 } 32 33 34 public func routeSearch(tapCenter:CLLocationCoordinate2D){ 35 36 let latitude = 35.681236 37 let longitude = 139.767125 38 39 let tokyoLocation = CLLocationCoordinate2DMake(latitude, longitude) 40 41 42 let sourcePlaceMark = MKPlacemark(coordinate: tokyoLocation) 43 44 let destinationPlaceMark = MKPlacemark(coordinate: tapCenter) 45 46 let directionRequest = MKDirections.Request() 47 directionRequest.source = MKMapItem(placemark: sourcePlaceMark) 48 directionRequest.destination = MKMapItem(placemark: destinationPlaceMark) 49 50 directionRequest.transportType = .walking 51 52 let directions = MKDirections(request: directionRequest) 53 directions.calculate { (response, error) in 54 guard let directionResonse = response else{ 55 56 if let error = error{ 57 58 print("we have errpr getting directions==(error.localizedDescription)") 59 60 } 61 return 62 } 63 64 DispatchQueue.main.async { 65 66 let route = directionResonse.routes[0] 67 self.routePolyLine = route.polyline 68 self.routePolyLine.subtitle = "route" 69 self.mapView.addOverlay(self.routePolyLine) 70 71 let rect = route.polyline.boundingMapRect 72 self.mapView.setRegion(MKCoordinateRegion(rect), animated: true) 73 74 } 75 76 77 } 78 79 } 80 81 func mapView(_ mapView: MKMapView, renderFor overlay: MKOverlay) -> MKOverlayRenderer { 82 let myPolyLineRendere: MKPolylineRenderer = MKPolylineRenderer(overlay: overlay) 83 84 if("route" == overlay.subtitle){ 85 86 myPolyLineRendere.lineWidth = 6 87 88 myPolyLineRendere.strokeColor = UIColor.green 89 90 } 91 else{ 92 93 myPolyLineRendere.lineWidth = 5 94 95 myPolyLineRendere.strokeColor = UIColor.blue 96 } 97 98 return myPolyLineRendere 99 100 } 101 102 103} 104

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

mapView(_:rendererFor:)は delegate method なので、次のような記述を追加する必要があります。

Swift

1// MARK: 追加 - MKMapViewDelegate を追加 2class ViewController: UIViewController,CLLocationManagerDelegate,UIGestureRecognizerDelegate, MKMapViewDelegate {

ViewController内部にmapView()を置くのであれば、クラス名の宣言部分にMKMapViewDelegateを追加する必要があります。

Swift

1 override func viewDidLoad() { 2 super.viewDidLoad() 3 // Do any additional setup after loading the view. 4 // MARK: 追加 - delegate の移譲先を追加 5 mapView.delegate = self 6 }

次に、delegate の移譲先をViewController(つまり自分自身であるself)にするため、上記のような記述を追加します。

基本的には上記の設定で動くのですが、ご質問のコードは次の部分を修正する必要があります。

Swift

1 // MARK: 修正 - 引数名が間違っている 2// func mapView(_ mapView: MKMapView, renderFor overlay: MKOverlay) -> MKOverlayRenderer { 3// 上記ではなく下記の通り 4 5 func mapView(_ mapView: MKMapView, rendererFor overlay: MKOverlay) -> MKOverlayRenderer {

rendererFor(レンダラーフォー)とすべきところをrenderFor(レンダーフォー)としています。間違っているとオーバーレイするときに呼び出されませんので、delegateとして定義されている通りに修正します。

上記の修正で動くことは確認しましたので、修正していただけますでしょうか。

参考にされたコードは、

でかなり細かく、また割合基本的なところから応用までステップを追って説明してありますから、一つひとつ内容を確実に押さえながら習得されるのもまた一つの手かと思います(記事も新しいので、作者にご質問されるともっと的確な回答が得られるかもしれません)。

投稿2020/06/27 23:33

TsukubaDepot

総合スコア5086

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問