[英]Adding TapGesture to ImageViews in paging ScrollView
我有一个分页的UIScrollView
,每个页面只有一个UIImageView
和一个View。 我想添加对在View上显示的Image的描述,我希望能够通过点击UIImageView
来显示/隐藏View。
我尝试了几种添加GestureRecognizer
,但是它似乎不起作用。 下面的代码是创建我的页面的地方。 在Slide1和Slide 2显示2种不同方式的情况下,我尝试添加GestureRecognizer
。
let tapGesture = UITapGestureRecognizer(target: self, action: #selector(showOrHide))
@objc func showOrHide(){
print("tapped")
for slide in slides{
slide.labelView.isHidden = true
}
}
func createSlides() -> [Slide] {
print("creating Slides")
let slide1:Slide = Bundle.main.loadNibNamed("Slide", owner: self, options: nil)?.first as! Slide
slide1.imageView.image = UIImage(named: "img1.jpg")
slide1.imageView.isUserInteractionEnabled = true
slide1.tapGestureRecogizer = UITapGestureRecognizer(target: self, action: #selector(showOrHide))
let slide2:Slide = Bundle.main.loadNibNamed("Slide", owner: self, options: nil)?.first as! Slide
slide2.imageView.image = UIImage(named: "img2.jpg")
slide2.imageView.isUserInteractionEnabled = true
slide2.imageView.addGestureRecognizer(tapGesture)
我认为我对这些页面的创建方式有误解,希望有人能帮助我。
谢谢!
tapGesture
作为内部的局部变量createSlides
。 更新的代码:
func createSlides() -> [Slide] {
print("creating Slides")
let slide1 = Bundle.main.loadNibNamed("Slide", owner: self, options: nil)?.first as! Slide
slide1.imageView.image = UIImage(named: "img1.jpg")
slide1.imageView.isUserInteractionEnabled = true
var tapGesture = UITapGestureRecognizer(target: self, action: #selector(showOrHide))
slide1.imageView.addGestureRecognizer(tapGesture)
let slide2 = Bundle.main.loadNibNamed("Slide", owner: self, options: nil)?.first as! Slide
slide2.imageView.image = UIImage(named: "img2.jpg")
slide2.imageView.isUserInteractionEnabled = true
tapGesture = UITapGestureRecognizer(target: self, action: #selector(showOrHide))
slide2.imageView.addGestureRecognizer(tapGesture)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.