【问题标题】:Sliding a UIView in a UITableViewCell在 UITableViewCell 中滑动 UIView
【发布时间】:2017-05-16 22:37:28
【问题描述】:

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

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)
    }
}

我希望每个单元格中的每个 containerView 都相互独立。有什么帮助吗?谢谢!

【问题讨论】:

  • 您是否为每个视图添加了任何标签?你可以通过标签来实现,特定的标签视图会滑动。

标签: ios swift uitableview uiview slide


【解决方案1】:

尝试在 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)
        }
    }
}

【讨论】:

    猜你喜欢
    • 2017-11-24
    • 1970-01-01
    • 1970-01-01
    • 2021-01-18
    • 1970-01-01
    • 1970-01-01
    • 2016-04-28
    • 2014-07-06
    • 2015-02-13
    相关资源
    最近更新 更多