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

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

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

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

Swift

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

AppleWatch

AppleWatchは、iPhoneと連動して動作する時計型のデバイスです。時間の確認だけでなく、通話や受信メールの確認などを行うことができます。

Q&A

解決済

1回答

626閲覧

WatchOSにおける画面間のセグエによる値渡しについて

kenkenpa0907

総合スコア55

Xcode

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

Swift

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

AppleWatch

AppleWatchは、iPhoneと連動して動作する時計型のデバイスです。時間の確認だけでなく、通話や受信メールの確認などを行うことができます。

0グッド

0クリップ

投稿2022/07/20 05:58

前提

swift初学者で、初めてAppleWatchのアプリ開発を行なっています。
タイトルのとおり、画面間のセグエによる値渡しの方法についてうまくできなくて困っています。
iOSでのセグエによる値渡しは実現できたのですが、WatchOSはiOSとは考え方が違っていて実現できていません。
WatchOSに関する記事も少なく、自分で解決できなかったため質問させていただきました。

実現したいこと

1ページ目のボタンをタップしたら、ボタンのコードに記載されているテキストデータを2ページ目のラベルに表示させるようにしたいと思っています。
コードは下記のとおりです

//InterfaceController import WatchKit import Foundation class InterfaceController: WKInterfaceController { //ボタンを押して値渡し @IBAction func buttonAction() { //ダイアログ表示 let okButtonAction = WKAlertAction(title:"OK" , style: .default ){() -> Void in              //値渡しコード func contextForSegue(withIdentifier segueIdentifier: String) -> Any? { if segueIdentifier == "GoNext"{ return "成功" } return nil } } let cancelButtonAction = WKAlertAction(title:"キャンセル" , style: .default ){() -> Void in } presentAlert(withTitle: "次ページへデータを送ります", message: "よろしいですか?", preferredStyle: .alert, actions: [okButtonAction, cancelButtonAction]) } override func awake(withContext context: Any?) { // Configure interface objects here. } override func willActivate() { // This method is called when watch view controller is about to be visible to user } override func didDeactivate() { // This method is called when watch view controller is no longer visible } }
//nextInterfaceController import Foundation import WatchKit class nextInterfaceController: WKInterfaceController { @IBOutlet weak var textLabel: WKInterfaceLabel! //値の格納変数 var context = "" override func awake(withContext context: Any?) { // Configure interface objects here. //データをラベルへ表示 self.textLabel.setText(context as! String) } override func willActivate() { // This method is called when watch view controller is about to be visible to user } override func didDeactivate() { // This method is called when watch view controller is no longer visible } }

コードは以上です。
この状態でボタンを1ページ目のボタンをタップしても2枚目に値が渡されないです。
コードをどう修正すればいいのかがわかりません。

1ページ目
イメージ説明
2ページ目(ボタンタップ後)
イメージ説明

このように何も表示されません

試したこと

試しにボタンアクション外に値渡しコードを記載した結果、2ページ目に値が渡されているのですが、常にデータが渡されているため、任意のタイミングで値を渡すことができない状態です。
コードは下記のとおりです。

import WatchKit import Foundation class InterfaceController: WKInterfaceController { @IBAction func buttonAction() { //ダイアログ表示 let okButtonAction = WKAlertAction(title:"OK" , style: .default ){() -> Void in } let cancelButtonAction = WKAlertAction(title:"キャンセル" , style: .default ){() -> Void in } presentAlert(withTitle: "次ページへデータを送ります", message: "よろしいですか?", preferredStyle: .alert, actions: [okButtonAction, cancelButtonAction]) } //値渡しコード override func contextForSegue(withIdentifier segueIdentifier: String) -> Any? { if segueIdentifier == "GoNext"{ return "成功" } return nil } override func awake(withContext context: Any?) { // Configure interface objects here. } override func willActivate() { // This method is called when watch view controller is about to be visible to user } override func didDeactivate() { // This method is called when watch view controller is no longer visible } }

2ページ目(ボタンタップ前)
イメージ説明
このようにデータは受け渡されているのが確認できます。

ボタンをタップした時になぜデータが送られないのかがわかりません。

もしかしたら、2ページ目のデータの受け取り方にミスがあるのかもしれませんが、正しいデータの受け取り方がわかりません。
よければご教授いただきたいです。
またそれ以外で間違いがあればご指摘いただきたいです。
よろしくお願致します。

補足情報

参考URL
Class WKInterfaceController
https://developer.apple.com/documentation/watchkit/wkinterfacecontroller

func awake(withContext context: Any?)
https://developer.apple.com/documentation/watchkit/wkinterfacecontroller/1619543-awake

func contextForSegue(withIdentifier segueIdentifier: String) -> Any?
https://developer.apple.com/documentation/watchkit/wkinterfacecontroller/1619522-contextforsegue

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

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

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

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

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

guest

回答1

0

ベストアンサー

contextForSegue(withIdentifier:)
WKInterfaceControllerのメソッドですので、
buttonActionの中に記述したらダメそうですね。

次のような感じはいかがでしょうか。
*試していないので雰囲気だけ見てください
*質問の内容を正しく解釈できていなかったらすみません・・

swift

1class InterfaceController: WKInterfaceController { 2 var value: String? 3 //ボタンを押して値渡し 4 @IBAction func buttonAction() { 5 //ダイアログ表示 6 let okButtonAction = WKAlertAction(title:"OK" , style: .default ){() -> Void in 7 self.value = "成功" 8 } 9 let cancelButtonAction = WKAlertAction(title:"キャンセル" , style: .default ){() -> Void in 10 } 11 presentAlert(withTitle: "次ページへデータを送ります", message: "よろしいですか?", preferredStyle: .alert, actions: [okButtonAction, cancelButtonAction]) 12 } 13 //値渡しコード 14 override func contextForSegue(withIdentifier segueIdentifier: String) -> Any? { 15 if segueIdentifier == "GoNext"{ 16 return value 17 } 18 return nil 19 }

投稿2022/07/20 13:43

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

kenkenpa0907

2022/07/22 01:59

回答ありがとうござきます。 試してみたら実現できました。 自分でも色々調べてみて、非常に勉強になりました! 本当にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問