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

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

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

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

Swift

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

Q&A

0回答

1371閲覧

Swiftui で複数のimageに同じgestureを付けたいです。

Hayato1201

総合スコア231

Xcode

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

Swift

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

0グッド

0クリップ

投稿2020/10/03 02:11

編集2020/10/03 02:11

こちらのリンクで紹介されている様な方法(以下のコード)で1つのimageに対してgestureを追加してdragする事はできるのですが、このviewを複数作ってそれらをそれぞれドラッグするにはどうすれば良いでしょうか?

やりたい事としては、
0. ボタンを押したら画面にimageが1つ追加される
0. そのimageにそれぞれdragのgestureを追加する

といった感じです。下記の例は1つのimageに対してpositionを設定してそれを変更していますが、imageが複数になったらpositionも複数用意し、それぞれのgestureがそのpositionを参照しなければならないと思いますが、どうすればよいでしょうか?また、ボタンを押した際にImageを追加する方法もいまいちよくわからないです。

ご回答いただければありがたいです!!

swiftUI

1struct ContentView: View { 2 3 @State var position: CGSize = CGSize(width: 200, height: 300) 4 5 var drag: some Gesture { 6 DragGesture() 7 .onChanged{ value in 8 self.position = CGSize( 9 width: value.startLocation.x 10 + value.translation.width, 11 height: value.startLocation.y 12 + value.translation.height 13 ) 14 } 15 .onEnded{ value in 16 self.position = CGSize( 17 width: value.startLocation.x 18 + value.translation.width, 19 height: value.startLocation.y 20 + value.translation.height 21 ) 22 } 23 24 } 25 26 var body: some View { 27 28 VStack { 29 Text("x: (position.width)") 30 Text("y: (position.height)") 31 32 Image("handbag") 33 .position(x: position.width, y: position.height) 34 .gesture(drag) 35 } 36 } 37}

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問