前提・実現したいこと
画像を長押しすると、画像が大きく表示され、かつピンチができるようにしたい。
発生している問題・エラーメッセージ
セル長押しのレコグナイザを設定してそのメソッドの中にピンチのレコグナイザを追加しようとしたのですが
エラーが発生する。
>Type 'UIViewController' has no member 'pinchAction(sender:)'
ViewDidRoadの中にピンチのレコグナイザを置き直してみたが、同じエラーとなる
そもそもの書き方が違うなどあったらご指摘ください
該当のソースコード
class MediaViewController: UIViewController ,UICollectionViewDataSource,
UICollectionViewDelegate,UICollectionViewDelegateFlowLayout,UIImagePickerControllerDelegate,UINavigationControllerDelegate,UIGestureRecognizerDelegate{
//画面遷移用変数生成 var screenTransitionData:ScreenTransitionData! //どの画面からの遷移だったかを保持する変数 var souceView:String = "" //データ保持クラスのインスタンス生成 var dataStrage:DataStrage! //選択された画像のIdentifierを保持するための配列() var selectedAssetLocalIdentifiers:[String] = [] //選択されたセルのインデックスを保持 var didSelectItemAtTarget: IndexPath? //画像のリスト var imageList:[UIImage] = [] //画像のPathリスト var imagePathList:[URL] = [] //mainImageタップ判定 var tappDecision = "" //ドキュメントディレクトリに保存されるファイルのパス var filePath = "" //ファイル名 var fileName = "" var navBar:UINavigationBar! var navItem:UINavigationItem! var cancelButton: UIButton! // 選択可能枚数(上限値は10枚) let maxSelectionsCount = 10 @IBOutlet var collectionView:UICollectionView! @IBOutlet var mainImage: UIImageView! @IBOutlet var mainLabel: UILabel! @IBOutlet var mainImageLabel: UILabel! //長押し時のアイテム生成 var screenWidth: Int! var screenHeight: Int! var coverView: UIView! var tapImage: UIImageView! var backButton: UIButton! var photo: UIImage! //スクロール var scrollView: UIScrollView! let baseScrollViewTag:Int=1 // 拡大率 let zoomMin:CGFloat=1.0 let zoomMax:CGFloat=5.0 //初期処理 override func viewDidLoad() { super.viewDidLoad() //メイン画像に対する長押し検知設定 mainImage.isUserInteractionEnabled = true let longPressRecognizer = UILongPressGestureRecognizer(target: self, action: #selector(self.onMainCellPressedLong(_:))) mainImage.addGestureRecognizer(longPressRecognizer) }
//メイン画像長押しされた時の処理
@objc func onMainCellPressedLong(_ recognizer: UILongPressGestureRecognizer) {
if recognizer.state == .began {
//背景作る
backGroundView()
//UIImageViewの設定 tapImage = UIImageView() //UIImageの設定 photo = imageList[0] tapImage.image = photo tapImage.frame = CGRect.init(x: 0, y: 200, width: screenWidth, height: screenWidth) //座標 tapImage.contentMode = UIView.ContentMode.scaleAspectFit //aspectfit //viewに追加 self.view.addSubview(coverView) self.view.addSubview(tapImage) self.view.addSubview(backButton) //ピンチ設定 let pinchGesture = UIPinchGestureRecognizer(target: self, action: #selector(UIViewController.pinchAction(sender:))) pinchGesture.delegate = self as? UIGestureRecognizerDelegate tapImage.addGestureRecognizer(pinchGesture) tapImage.isUserInteractionEnabled = trueViewController. } } func backGroundView() { //背景viewの設定 screenWidth = Int( UIScreen.main.bounds.size.width); //画面の幅 screenHeight = Int(UIScreen.main.bounds.size.height); //画面の高さ coverView = UIView.init(frame: CGRect.init(x: 0, y: 0, width: screenWidth, height: screenHeight)) //座標設定 coverView.backgroundColor = UIColor.white //画面の色 coverView.alpha = 0.9 //UIButtonの設定 backButton = UIButton() backButton = UIButton(frame: CGRect(x: 0, y: 50, width: self.view.frame.width, height: self.view.frame.height / 9)) //座標設定 backButton.backgroundColor = .black //背景の色 backButton.setTitleColor(.white, for: .normal) //文字色 backButton.setTitle("戻る", for: .normal) //文字 //戻るボタンを押した時 backButton.addTarget(self, action: #selector(pushButton), for: .touchUpInside) }
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。