gpt4 book ai didi

ios - 重绘时未清除 UIBezierPath

转载 作者:行者123 更新时间:2023-11-28 23:46:32 25 4
gpt4 key购买 nike

我有自定义的 UIView,我在其中绘制了一个 UIBezierPath。此 View 用于 UITableViewCell。因此,当我滚动时,自定义 View 的贝塞尔曲线路径会被重绘。问题是新路径覆盖了旧路径图(上下文未正确清除)。我在获取表格单元格时调用 setNeedsDisplay(),并且还为 View 设置了 clearsContextBeforeDrawing = true。清除旧绘图的唯一方法是调用 context.clear(rect) 但这一点也不理想,因为我失去了背景(它变成了黑色)。

关于如何解决这个问题有什么想法吗?

class CustomView: UIView {

var percentage: CGFloat = 0 {
didSet {
setNeedsDisplay()
}
}

override init(frame: CGRect) {
super.init(frame: frame)
clearsContextBeforeDrawing = true
contentMode = .redraw
clipsToBounds = false
}

required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}

override func draw(_ rect: CGRect) {
super.draw(rect)

// NOTE: don't really like doing this
let context = UIGraphicsGetCurrentContext()!
context.clear(rect)

let center = CGPoint(x: self.bounds.size.width/2, y: self.bounds.size.height/2)

let path = UIBezierPath(arcCenter: center,
radius: self.bounds.size.width/2-10,
startAngle: 0.5 * .pi,
endAngle: (-2.0 * self.percentage + 0.5) * .pi,
clockwise: false)

path.lineWidth = 4
UIColor.red.setStroke()
path.stroke()
}
}

这是设置我的单元格和自定义 uiview 的地方。

override func tableView(_ tableView: UITableView, cellForItemAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath)
let num = list[indexPath.item]
let percentage = CGFloat(num) / 10
cell.customView.percentage = percentage // Custom view should get redrawn after this call
return cell
}

最佳答案

我认为问题仅仅是您的绘图很大并且偏离了单元格,因为您的 View 没有裁剪到边界。这是不连贯的。每个单元格只需要绘制自己的内容。

换句话说,您看到的重叠与自定义 View 绘图无关;它与单元格绘图有关。你正在用你的绘画感染邻近的细胞。

对了,你说:

but this isn't at all ideal since I lose the background (it becomes black)."

您可以通过在 init 中输入 self.backgroundColor = .clear 来解决这个问题。

关于ios - 重绘时未清除 UIBezierPath,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52573523/

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