下記の画像のようにsecondViewControllerとSecondSwitchViewControllerをPresent Modallyで繋げてButtonをタップすると画面遷移するように作りました。
ですが、Tab Bar ControllerのHistoryをタップすると直接SecondSwitchViewControllerに繋がってしまいます。その後戻るをタップしてSeconViewControllerに戻るとButton部分をタップしないと画面遷移しない理想的に動きます。最初だけ強制的に切り替わってしまうのはなぜでしょうか? 教えて頂けると嬉しいです。よろしくお願いします。
SecondViewControllerのコードを添付しておきます
SecondViewCOntroller
1import UIKit 2import AVFoundation 3 4class SecondViewController: UIViewController, AVAudioPlayerDelegate, UITableViewDelegate, UITableViewDataSource, GADBannerViewDelegate { 5 6 let TODO = ["a", "b", "c", "d", "e", "f"] 7 8 var counter = 0 9 var timer = Timer() 10 var startTime:Double = 0.0 11 var audioPlayer: AVAudioPlayer! 12 @IBOutlet weak var tableView: UITableView! 13 14 @IBAction func switch1(_ sender: UISwitch) 15 { 16 if (sender).isOn 17 { 18 timer = Timer.scheduledTimer(withTimeInterval: 1 * 1, repeats: false, block: { timer in 19 20 self.audioPlayer.play() 21 22 self.audioPlayer.numberOfLoops = -1 23 print(self.audioPlayer.isPlaying) 24 }) 25 }else{ 26 timer.invalidate() 27 print("switch1stopped") 28 self.audioPlayer.stop() 29 } 30 } 31 @IBAction func switch1setting(_ sender: UIButton) 32 { 33 counter = counter + 1 34 print(counter) 35 36 if counter == 2{ 37 self.performSegue(withIdentifier: "nextView", sender: nil) 38 counter = 0 39 } 40 //まずは、同じstororyboard内であることをここで定義します 41 let storyboard: UIStoryboard = self.storyboard! 42 //ここで移動先のstoryboardを選択(今回の場合は先ほどsecondと名付けたのでそれを書きます) 43 let second = storyboard.instantiateViewController(withIdentifier: "nextView") 44 //ここが実際に移動するコードとなります 45 self.present(second, animated: true, completion: nil) 46 } 47 48 @IBAction func switch2(_ sender: UISwitch) 49 { 50 if (sender).isOn 51 { 52 timer = Timer.scheduledTimer(withTimeInterval: 1 * 1, repeats: false, block: { timer in 53 54 self.audioPlayer.play() 55 self.audioPlayer.numberOfLoops = -1 56 print(self.audioPlayer.isPlaying) 57 }) 58 }else{ 59 timer.invalidate() 60 print("switch2stopped") 61 self.audioPlayer.stop() 62 } 63 } 64 @IBAction func switch2setting(_ sender: UIButton) 65 { 66 counter = counter + 1 67 print(counter) 68 69 if counter == 2{ 70 self.performSegue(withIdentifier: "secondsetting", sender: nil) 71 counter = 0 72 } 73 //まずは、同じstororyboard内であることをここで定義します 74 let storyboard: UIStoryboard = self.storyboard! 75 //ここで移動先のstoryboardを選択(今回の場合は先ほどsecondと名付けたのでそれを書きます) 76 let second = storyboard.instantiateViewController(withIdentifier: "secondsetting") 77 //ここが実際に移動するコードとなります 78 self.present(second, animated: true, completion: nil) 79 } 80 81 82 override func viewDidLoad() { 83 super.viewDidLoad() 84 85 } 86 87 88
回答でなくて申し訳ないのですが、var counter = 0 の変数counterの意図を教えてもらえないでしょうか?最近何回か見たのですが、意図をつかめません。コピペでしたら参考になられたURLを教えていだだけないでしょうか?
@IBAction func switch1setting(_ sender: UIButton) { counter = counter + 1 print(counter) if counter == 2{ self.performSegue(withIdentifier: "nextView", sender: nil) counter = 0 }このコードに対して必要かなと思ったので入れました。
もし間違いでしたらご指摘下さい
回答ありがとうございます。お時間取らせて申し訳ありませんでした。
ボタンを初めて押したときと二度目に押したときの遷移の方法を変えているのは意図されてですか?
すみませんそれは意図してませんでした。詳しく教えて頂けないでしょうか? if counter == 2{ self.performSegue(withIdentifier: "nextView", sender: nil) counter = 0 } 今はif counter == 1{ としています
遷移の方法が二通り書いてあるのですが、使い分けする意味がありますか?ボタンを押したら遷移すればいいんですよね?
switch1setting とswitch2settingの事ですか?それぞれ違うviewcontrollerに繋げようと思っています。
switch1settingの中で遷移の方法が2とおり書いてありませんか?つなげる先は"nextView"ってやつです。
編集
恐らくこれが不必要だと思い削除しましたが実行結果は同じでした。//まずは、同じstororyboard内であることをここで定義します let storyboard: UIStoryboard = self.storyboard! //ここで移動先のstoryboardを選択(今回の場合は先ほどsecondと名付けたのでそれを書きます) let second = storyboard.instantiateViewController(withIdentifier: "nextView") //ここが実際に移動するコードとなります self.present(second, animated: true, completion: nil)
そこを削除して実行してみるとはじめにボタンを押したときは何も起こらずに、2回めに押した時に遷移するようになりませんか?
上記の質問と同じ様にtabを切り替えた(サーチのアイコンタップした)瞬間に切り替わってしまいます。buttonが干渉してるのかもと思い接続し直してもみましたが同じでした。。。
サーチのアイコンじゃないですhistoryです。すみません
質問の件についてですが、私ではお役に立てないようです。申し訳ないです。
画面遷移について参考URLを置いておきます。先に進むよりも、よく読んでみてください。https://qiita.com/fromage-blanc/items/b3cb0e7833a1d5659463
問題が発生する必要最小限のコードにして試すとともに、そのコードをご提示ください。不要なコードがあると確認する際に大きな負担となります。
回答1件
あなたの回答
tips
プレビュー