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

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

ただいまの
回答率

89.04%

swiftマップにピンを表示できない

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 159

hayati

score 7

swiftマップにピンを表示できず困っています。
printなどで値が渡っているかを確かめたのですが、print自体が表示されませんでした。

コード


import UIKit
import Firebase
import MapKit

class ViewController: UIViewController {


   var Address = "addressPoint"


    @IBOutlet weak var mapview: MKMapView!
    @IBOutlet weak var search1: UIButton!
    @IBOutlet weak var holding: UIButton!
    @IBOutlet weak var compass: UIButton!



    override func viewDidLoad() {
        super.viewDidLoad()

        search1.layer.cornerRadius = 5.0
        // 影の方向(width=右方向、height=下方向、CGSize.zero=方向指定なし)
        search1.layer.shadowOffset = CGSize(width: 0.0, height: 2.0)
        // 影の色
        search1.layer.shadowColor = UIColor.black.cgColor
        // 影の濃さ
        search1.layer.shadowOpacity = 0.6
        // 影をぼかし
        search1.layer.shadowRadius = 4
        holding.layer.cornerRadius = 20.0
        // 影の方向(width=右方向、height=下方向、CGSize.zero=方向指定なし)
        holding.layer.shadowOffset = CGSize(width: 0.0, height: 2.0)
        // 影の色
        holding.layer.shadowColor = UIColor.black.cgColor
        // 影の濃さ
        holding.layer.shadowOpacity = 0.6
        // 影をぼかし
        holding.layer.shadowRadius = 4

        // 影の方向(width=右方向、height=下方向、CGSize.zero=方向指定なし)
        compass.layer.shadowOffset = CGSize(width: 0.0, height: 2.0)
        // 影の色
        compass.layer.shadowColor = UIColor.black.cgColor
        // 影の濃さ
        compass.layer.shadowOpacity = 0.6
        // 影をぼかし
        compass.layer.shadowRadius = 4


    }



    //HoldingViewControllarから持ってきたaddressの値を入れ、MAPにピンを立てる。
    @IBAction func pin(_ sender: Any){

        self.view.endEditing(true)

           let myGeocoder:CLGeocoder = CLGeocoder()

           //住所
           let searchStr = Address

           //住所を座標に変換する。
           myGeocoder.geocodeAddressString(searchStr, completionHandler: {(placemarks, error) in

               if(error == nil) {
                   for placemark in placemarks! {
                       let location:CLLocation = placemark.location!

                       //中心座標
                       let center = CLLocationCoordinate2DMake(location.coordinate.latitude, location.coordinate.longitude)

                       //表示範囲
                    let span = MKCoordinateSpan(latitudeDelta: 0.001, longitudeDelta: 0.001)

                       //中心座標と表示範囲をマップに登録する。
                    let region = MKCoordinateRegion(center: center, span: span)
                    self.mapview.setRegion(region, animated: true)

                       //地図にピンを立てる。
                       let annotation = MKPointAnnotation()
                       annotation.coordinate = CLLocationCoordinate2DMake(location.coordinate.latitude, location.coordinate.longitude)
                       self.mapview.addAnnotation(annotation)

                   }
               } else {
                print("検索できませんでした。")
               }
           })
           //改行を入れない。
        print(Error.self)


    }





}//

import UIKit
import Firebase

class HoldingViewController: UIViewController {

@IBOutlet weak var cyphertext: UITextField!
@IBOutlet weak var addresstext: UITextField!
@IBOutlet weak var daystext: UITextField!
@IBOutlet weak var timetext: UITextField!
@IBOutlet weak var HowManytext: UITextField!
@IBOutlet weak var commenttext: UITextField!
@IBOutlet weak var decide: UIButton!

let db = Firestore.firestore()

var addressValue = String?.self

override func viewDidLoad() {
super.viewDidLoad()

decide.layer.cornerRadius = 20.0
}

@IBAction func decideButton(_ sender: Any) {

//書き込まれた情報をfirebaseに保存する
db.collection("users").document("user").setData([

"CypherName": cyphertext.text as Any,
"day": daystext.text as Any,
"address": addresstext.text as Any,
"time": timetext.text as Any,
"HowMany": HowManytext.text as Any,
"comment": commenttext.text as Any

]) { err in
if let err = err {
print("Error writing document: \(err)")
} else {
print("ドキュメントに保存されたよ!")

//保存したデータを取り出す。
let docRef = self.db.collection("users").document("user")

docRef.getDocument { (document, error) in
if let document = document, document.exists {
let dataDescription = document.data().map(String.init(describing:)) ?? "nil"
print("Document data: \(dataDescription)")
//画面遷移と値渡し
let VC = self.storyboard?.instantiateViewController(withIdentifier: "View") as! ViewController
var addressPoint = "address"
self.present(VC, animated: true, completion: nil)
self.dismiss(animated: true, completion: nil)
//                          self.performSegue(withIdentifier: "home", sender: nil)

} else {
print("ドキュメントが取得できませんでした。")

}
}
}
}

//取り出した"address"(住所)をViewControllarに渡す

//        prepare(for: UIStoryboardSegue, sender: Any?)
//
//        let VC = segue.destination as! ViewController
//
//        VC.addressValue = "address"
//
}

@IBAction func back(_ sender: Any) {
dismiss(animated: true, completion: nil)
}

}//

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

0

丁寧にコードを見たわけではありませんが、前回のご質問の流れから考えると

   var Address = "addressPoint"


ここには実在する住所を入れなければジオコーディング(住所から緯度経度を求めること)はできません。


念のため、質問者さんのコードから、地図を表示させるだけの最小限のコードを取り出して実行してみました。
ボタンを押すとレバレジーズ(teratailの運営会社)にズームします。
住所はAddressという変数に入れています(質問者さんのオリジナルではaddressPointとなっていました)。

StoryBoard でMapViewとボタンに関連づける必要はありますが、住所を正しく設定するだけできちんと目的地にズームして表示できるようになっていたので、それ以外のところに間違いはありません。

もし、動作に疑いがあるのであれば、まずこのような感じで最低限の動作を確認できるコードを書いてみるといいと思います。

import UIKit
import MapKit

class ViewController: UIViewController {
   var Address = "東京都渋谷区渋谷2丁目24−12"

    @IBOutlet weak var mapview: MKMapView!

    override func viewDidLoad() {
        super.viewDidLoad()
    }

    @IBAction func pin(_ sender: Any){

        self.view.endEditing(true)

           let myGeocoder:CLGeocoder = CLGeocoder()

           //住所
           let searchStr = Address

           //住所を座標に変換する。
           myGeocoder.geocodeAddressString(searchStr, completionHandler: {(placemarks, error) in

               if(error == nil) {
                   for placemark in placemarks! {
                       let location:CLLocation = placemark.location!

                       //中心座標
                       let center = CLLocationCoordinate2DMake(location.coordinate.latitude, location.coordinate.longitude)

                       //表示範囲
                    let span = MKCoordinateSpan(latitudeDelta: 0.001, longitudeDelta: 0.001)

                       //中心座標と表示範囲をマップに登録する。
                    let region = MKCoordinateRegion(center: center, span: span)
                    self.mapview.setRegion(region, animated: true)

                       //地図にピンを立てる。
                       let annotation = MKPointAnnotation()
                       annotation.coordinate = CLLocationCoordinate2DMake(location.coordinate.latitude, location.coordinate.longitude)
                       self.mapview.addAnnotation(annotation)

                   }
               } else {
                print("検索できませんでした。")
               }
           })
    }
}

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 89.04%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る