gpt4 book ai didi

ios - 在 UITableViewCell 中滑动 UIView

转载 作者:行者123 更新时间:2023-11-30 12:47:35 24 4
gpt4 key购买 nike

我正在 UITableView 的每个单元格中创建一个名为“containerView”的可滑动 UIView。但是,当我在特定单元格中滑动容器 View 时,所有单元格中的所有容器 View 都会随之滑动。这是我的代码:

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell  {

let cell = self.tableView.dequeueReusableCell(withIdentifier: "TestCell") as! TestTableViewCell
cell.containerView.frame = CGRect(x: self.view.frame.size.width - 100, y:200, width: 225, height: 70)
cell.containerView.center.x = self.view.frame.size.width - 100
cell.containerView.backgroundColor = UIColor.black
cell.containerView.layer.cornerRadius = 20
let gesture = UIPanGestureRecognizer(target: self, action: #selector(wasDragged(gestureRecognizer:)))
cell.containerView.addGestureRecognizer(gesture)
cell.containerView.isUserInteractionEnabled = true
gesture.delegate = self
return cell
}

这是我的拖动功能:

func wasDragged(gestureRecognizer: UIPanGestureRecognizer) {

print("wassss dragggggeeed")
if gestureRecognizer.state == .began || gestureRecognizer.state == .changed {
let translation = gestureRecognizer.translation(in: self.view)
print(gestureRecognizer.view!.center.x)
let newx = gestureRecognizer.view!.center.x + translation.x

if(newx <= self.view.frame.width + 50) && (newx >= self.view.frame.width - 100) {
gestureRecognizer.view!.center = CGPoint(x: newx, y: gestureRecognizer.view!.center.y)
}else if (newx > self.view.frame.width + 50){
gestureRecognizer.view!.center = CGPoint(x: self.view.frame.width + 50, y: gestureRecognizer.view!.center.y)
}else if (newx < self.view.frame.width - 100){
gestureRecognizer.view!.center = CGPoint(x: self.view.frame.width - 100, y: gestureRecognizer.view!.center.y)
}

gestureRecognizer.setTranslation(CGPoint(x: 0,y: 0), in: self.view)
}
}

我希望每个单元格中的每个容器 View 彼此独立。有什么帮助吗?谢谢!

最佳答案

尝试在 cellForRowAt 方法中替换此代码

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "CellIdentifier", for: indexPath) as! TestTableViewCell

cell.containerView.backgroundColor = UIColor.black
let gesture = UIPanGestureRecognizer(target: self, action: #selector(wasDragged(gestureRecognizer:)))
cell.containerView.addGestureRecognizer(gesture)
cell.containerView.isUserInteractionEnabled = true

return cell
}

以及wasDragged(gestureRecognizer: UIPanGestureRecognizer)方法

func wasDragged(gestureRecognizer: UIPanGestureRecognizer) {

let gestureView = gestureRecognizer.view!
let translation = gestureRecognizer.translation(in: self.view)

// manage translation as per your requirement
let newx = gestureRecognizer.view!.center.x + translation.x/10

if gestureRecognizer.state == .changed {
// while dragging
if newx < view.frame.size.width && newx >= view.frame.size.width/2 {
gestureView.center = CGPoint(x: newx, y: gestureRecognizer.view!.center.y)
}
} else if gestureRecognizer.state == .ended {
// when dragging ends
if newx >= view.frame.size.width {
gestureView.center = CGPoint(x: view.frame.size.width, y: gestureRecognizer.view!.center.y)
} else {
gestureView.center = CGPoint(x: view.frame.size.width/2, y: gestureRecognizer.view!.center.y)
}
}
}

关于ios - 在 UITableViewCell 中滑动 UIView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41433302/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com