我正在以编程方式向自定义集合视图单元格类添加轻击手势识别器。由于某种原因,它似乎没有用。框架不为0,isUserInteractionEnabled设置为true,并且我确保水龙头视图位于所有其他视图之上:
自定义单元格类:
let containerView: UIView = {
let view = UIView()
view.isUserInteractionEnabled = true
view.translatesAutoresizingMaskIntoConstraints = false
return view
}()
let tapView: UIView = {
let v = UIView()
v.isUserInteractionEnabled = true
return v
}()
let tap: UITapGestureRecognizer = {
let t = UITapGestureRecognizer(target: self, action: #selector(tapped))
return t
}()
@objc fileprivate func tapped() {
print("tap")
}
func setTap() {
self.containerView.addSubview(tapView)
tapView.frame = self.frame
// layout constraint code - printing frame shows its not 0 after this
tapView.addGestureRecognizer(tap)
}
在具有集合视图的视图控制器文件中:
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: cellId, for: indexPath) as! SuggestCell
cell.category.text = data[indexPath.row].category
cell.word.text = data[indexPath.row].word
cell.setTap()
print(cell.tapView.frame)
return cell
}
我确实意识到有一个didSelectItemAt方法,但是我正在尝试一些自定义行为,该行为检测对单元格的多次点击并执行操作
答案 0 :(得分:2)
问题在于在您定义的tap
属性中,self
不是自定义单元格类的实例,因为在创建该属性时,该对象尚未完全初始化。
如果添加:
print(type(of: self))
对于该代码,您将看到它打印:
(CustomCell) -> () -> CustomCell
而不是期望的:
CustomCell
因此您的目标/操作使用了错误的目标。
解决此问题的一种简单方法是将tap
设为lazy var
:
lazy var tap: UITapGestureRecognizer = {
let t = UITapGestureRecognizer(target: self, action: #selector(tapped))
return t
}()
然后,当您第一次访问tap
时,将创建轻击手势识别器,然后将创建您的自定义单元格,并且self
将引用该类的实例。< / p>
或者,您可以将tap
设为计算属性:
var tap: UITapGestureRecognizer {
let t = UITapGestureRecognizer(target: self, action: #selector(tapped))
return t
}
和tap
将在访问时创建并返回一个UITapGestureRecognizer
。同样,在这种情况下,将创建自定义单元格,因此self
将正确地引用该类的实例。