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

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

ただいまの
回答率

89.13%

iPhoneのMKMapでマップをボタンで回転させたい。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,116

harima

score 20

MKMapViewでマップアプリを作っております。手に障がいを持つ方のためにボタンでマップを30度くらいずつ回転させたいのですが、どのように記述すれば良いか分かりません。どなたかお分かりの方はご教授お願いいたします。

確かに質問は丸投げになってしまって、気分を害された方には申し訳有りません。ですが、実際は2〜3時間、検索して色々試してみてどれもうまくいかなかった背景があります。大変失礼ですが、この方法が、一番分かりやすいと思って、ソースも付けずに質問をさせていただきました。申し訳有りません。

            if(rotation == ROTATION_RIGHT ) {
                var myRotateView: MKMapView = MKMapView(frame: CGRect(x: 0, y: 70, width: maxWidth, height: maxHeight - 20.0 - 50.0))
                let angle:CGFloat = CGFloat((30.0 * M_PI) / 180.0)
                myRotateView.transform = CGAffineTransform(rotationAngle: angle)
                self.view.addSubview(myRotateView)
            } else if (rotation == ROTATION_LEFT){

            }


大変失礼しております。マップの表示、拡大・縮小、ボタンでの動作はできています。マップの回転だけが分かりません。
上記のように回転をすると、長方形の画面が回転して、地図も縮小されたり、ボタンの上に乗っていたりして、地図を二本指で回転させた状態とは程遠い表示になってしまいます。申し訳有りませんが宜しくお願い致します。

let maxWidth: CGFloat = self.view.bounds.width
let maxHeight: CGFloat = self.view.bounds.height


letで定義している定数の追加

ある程度回転ができるようになったのですが、長方形のまま回転しているため、表示がおかしくなっています。改善点・修正点などございましたら、ご教授ください。

//
//  ViewController.swift
//  Map
//

import UIKit
import MapKit
import CoreLocation

class ViewController: UIViewController, MKMapViewDelegate, CLLocationManagerDelegate {

    var myMapView: MKMapView!
    var coordinate: CLLocationCoordinate2D!
    var locationManager: CLLocationManager!

    var myLatitudeDelta = 1.0
    var myLongitudeDelta = 1.0

    var myDegree = 0.0

    let DBL_MAX = 1.7976931348623157E+308
    let DBL_MIN = 50.0 //4.9E-324

    private var rotateBtn: UIButton!

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib
        setupLocationManager()

        let maxWidth: CGFloat = self.view.bounds.width
        let maxHeight: CGFloat = self.view.bounds.height

//        locationManager = CLLocationManager()

        myMapView = MKMapView()
        myMapView.frame = self.view.frame(forAlignmentRect: CGRect(x: 0.0, y: 20.0 + 50.0, width: maxWidth, height: maxHeight - 20.0 - 50.0 - 50.0))
        myMapView.delegate = self
        myMapView.setCenter(myMapView.userLocation.coordinate, animated: true)
        myMapView.setUserTrackingMode(.followWithHeading, animated: true)
        myMapView.showsUserLocation = true
        self.view.addSubview(myMapView)


        rotateBtn = UIButton()
        rotateBtn.frame = CGRect(x: maxWidth / 4.0 * 3.0, y: maxHeight - 50.0, width: maxWidth / 4.0, height: 50.0)
        rotateBtn.setTitleColor(UIColor.black, for: .normal)
        rotateBtn.backgroundColor = UIColor.yellow
        rotateBtn.layer.cornerRadius = 20.0
        rotateBtn.setTitle("回転", for: .normal)
        rotateBtn.tag = 4
        rotateBtn.addTarget(self, action: #selector(ViewController.onClickMyButton(sender:)), for: .touchDown)
        self.view.addSubview(rotateBtn)


    }

    func setupLocationManager() {
        locationManager = CLLocationManager()
        guard let locationManager = locationManager else { return }

        locationManager.requestWhenInUseAuthorization()
    }

    func mapView(_ mapView: MKMapView, regionDidChangeAnimated animated: Bool) {
        //        print("regionDidChangeAnimated")
    }

    func onClickMyButton(sender: UIButton) {

        if (sender.tag == 1) {
        } else if (sender.tag == 2){
        } else if (sender.tag == 3){
        } else if (sender.tag == 4){

            myDegree = myDegree + 15.0
            let scaleTransform = CGAffineTransform(scaleX: 1.0, y: 1.0)
            let rotationTransform = CGAffineTransform(rotationAngle: CGFloat(-Double.pi / 180.0 * myDegree))
            let transform = scaleTransform.concatenating(rotationTransform)
            myMapView.transform = transform

        }

    }


    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


    override var prefersStatusBarHidden: Bool {
        return false
    }

    override func viewWillTransition(to size: CGSize,
                                     with coordinator: UIViewControllerTransitionCoordinator) {
        super.viewWillTransition(to: size, with: coordinator)


    }
}



extension ViewController {

    func locationManager(_ manager: CLLocationManager, didChangeAuthorization status: CLAuthorizationStatus) {
        switch status {
        case .notDetermined:
            print("ユーザーはこのアプリケーションに関してまだ選択を行っていません")
            // 許可を求めるコードを記述する(後述)
            locationManager.requestWhenInUseAuthorization()
            break

        case .denied:
            print("ローケーションサービスの設定が「無効」になっています (ユーザーによって、明示的に拒否されています)")
            // 「設定 > プライバシー > 位置情報サービス で、位置情報サービスの利用を許可して下さい」を表示する
            let alert = UIAlertController(title: "ローケーションサービスの設定が「無効」になっています。", message: "「設定 > プライバシー > 位置情報サービス で、位置情報サービスの利用を許可して下さい」", preferredStyle: .alert)
            alert.addAction(UIAlertAction(title: "OK", style: .default))
            self.present(alert, animated: true, completion: nil)
            break

        case .restricted:
            print("このアプリケーションは位置情報サービスを使用できません(ユーザによって拒否されたわけではありません)")
            // 「このアプリは、位置情報を取得できないために、正常に動作できません」を表示する
            let alert = UIAlertController(title: "このアプリケーションは位置情報サービスを使用できません(ユーザによって拒否されたわけではありません)", message: "「このアプリは、位置情報を取得できないために、正常に動作できません」", preferredStyle: .alert)
            alert.addAction(UIAlertAction(title: "OK", style: .default))
            self.present(alert, animated: true, completion: nil)
            break

        case .authorizedAlways:
            print("常時、位置情報の取得が許可されています。")
            // 位置情報取得の開始処理
            break
        case .authorizedWhenInUse:
            print("起動時のみ、位置情報の取得が許可されています。")
            // 位置情報取得の開始処理
            locationManager.startUpdatingLocation()
            break
        }
    }

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • fuzzball

    2017/06/05 14:07 編集

    コードの有無が問題なのではありません。やりたいことしか書かれておらず、現状がどうなのか(何が出来ていて何が分からないのか)が分かりません。ボタンの処理が分からないのか、マップの回転が分からないのか、そもそもマップは表示できているのか、など。

    キャンセル

回答 1

checkベストアンサー

+1

myMapView.camera.heading += 15

この回転ではダメですか?

myMapView.camera.altitudeを増減させることで拡大縮小も可能です。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/06/07 14:10

    誠にありがとうございました。1行で完璧な回転ができて目から鱗が落ちる思いです。色々と指摘していただき、勉強になりました。今後も分かり易い質問を目指してまいります。本当にありがとうございました。

    キャンセル

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

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