複数の画像をそれぞれに指でドラッグして、任意の場所まで動かしたい
swift初心者です。
複数の食べ物の画像と、口の画像を Storybordに配置、指でドラッグして口まで動かす。
最終的に口に運んだ時点で画像が消える。というアプリを作成しています。
画像それぞれに座標を取得、画像の範囲内であればtrue、範囲外であればfalseとすることで、
タッチした画像のみ動かせるようにしたく、コードを作成しました。
タッチは検知できているがドラッグができない。
true、falseの判定はprint(Inside/outside)の結果を見る限り、問題なさそうです。
そうなるとoverride func touchesMovedの関数のなかが怪しいかと思いますが、
特にエラーもないので、何が違うのか辿り着けませんでした。
素人のコードなので見にくかったら申し訳ありません。ご教授お願いします。
該当のソースコード
swift
import UIKit class ViewController: UIViewController { @IBOutlet weak var bananaImageView: UIImageView! @IBOutlet weak var cherryImageView: UIImageView! var startPoint: CGPoint? var startPoint2: CGPoint? var bananaImageNowPoint: CGPoint? var cherryImageNowPoint: CGPoint? var isImageInside: Bool? override func viewDidLoad() { bananaImageView.image = UIImage(named: "banana") cherryImageView.image = UIImage(named:"cherry") // 識別するためにtag設定 bananaImageView.tag = 100 cherryImageView.tag = 200 // 画像のフレームを設定 bananaImageView.frame = CGRect(x:50, y:150, width:100, height:100) cherryImageView.frame = CGRect(x:247, y:151, width:100, height:100) //タップを検出 bananaImageView.isUserInteractionEnabled = true cherryImageView.isUserInteractionEnabled = true //isUserInteractionEnabledとセット? self.view.addSubview(bananaImageView) self.view.addSubview(cherryImageView) } // 画面にタッチで呼ばれる override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { // タッチをやり始めた座標を取得 let touch: UITouch = touches.first! startPoint = touch.location(in: bananaImageView) startPoint2 = touch.location(in: cherryImageView) //println("startPoint =(startPoint)") // タッチをやり始めた時のイメージの座標を取得 bananaImageNowPoint = self.bananaImageView.frame.origin cherryImageNowPoint = self.cherryImageView.frame.origin print("bananaImageNowPoint =(String(describing: bananaImageNowPoint) )") let MinX = bananaImageNowPoint!.x print(MinX) let MaxX = bananaImageNowPoint!.x + self.bananaImageView!.frame.width print(MaxX) let MinY = bananaImageNowPoint!.y print(MinY) let MaxY = bananaImageNowPoint!.y + self.bananaImageView!.frame.height print(MaxY) let MinX2 = cherryImageNowPoint!.x let MaxX2 = cherryImageNowPoint!.x + self.cherryImageView!.frame.width let MinY2 = cherryImageNowPoint!.y let MaxY2 = cherryImageNowPoint!.y + self.cherryImageView!.frame.height print(startPoint!.x) print(startPoint!.y) //print(startPoint2!.x) //print(startPoint2!.y) // イメージの範囲内をタッチした時のみisImageInsideをtrueにする if (MinX <= (startPoint!.x+50) && (startPoint!.x+50) <= MaxX) && (MinY <= (startPoint!.y+150) && (startPoint!.y+150) <= MaxY) { print("Inside of banana") isImageInside = true } else { print("Outside of banana") isImageInside = false } // イメージの範囲内をタッチした時のみisImageInsideをtrueにする if (MinX <= startPoint2!.x && startPoint2!.x <= MaxX) && (MinY <= startPoint2!.y && startPoint2!.y <= MaxY) { print("Inside of cherry") isImageInside = true } else { print("Outside of cherry") isImageInside = false } } // ドラッグ時に呼ばれる override func touchesMoved(_ touches: Set<UITouch>, with event: UIEvent?) { if isImageInside! { // タッチ中の座標を取得 let touch: UITouch = touches.first! let location: CGPoint = touch.location(in: self.view) print("location =(location)") // 移動量を計算 let deltaX: CGFloat = CGFloat((location.x) - (startPoint!.x+50)) let deltaY: CGFloat = CGFloat((location.y) - (startPoint!.y+150)) print("deltaX: (deltaX), deltaY: (deltaY)") let deltaX2: CGFloat = CGFloat(location.x - startPoint2!.x) let deltaY2: CGFloat = CGFloat(location.y - startPoint2!.y) // イメージを移動 self.bananaImageView.frame.origin.x = bananaImageNowPoint!.x + deltaX self.bananaImageView.frame.origin.y = bananaImageNowPoint!.y + deltaY self.cherryImageView.frame.origin.x = cherryImageNowPoint!.x + deltaX self.cherryImageView.frame.origin.y = cherryImageNowPoint!.y + deltaY } else { // Do nothing } } // ドラッグ終了 override func touchesEnded(_ touches: Set<UITouch>, with event: UIEvent?) { } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } }
口の画像の座標で画像が消えるという部分はまだ何もしていない状況です。
下記参考
//タップした画像で座標を取得 https://prince9.hatenablog.com/entry/20150517/1431817999
//Swiftで、複数の画像それぞれに対するドラッグ&ドロップの実装について https://teratail.com/questions/18107
//タッチで画像を動かす https://anthrgrnwrld.hatenablog.com/entry/2015/04/14/231830
まだ回答がついていません
会員登録して回答してみよう