- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有自定义的 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/
我有两个 UIBezierPath,一个表示图像的多边形部分,另一个是要在其上绘制的路径。 我需要找到它们之间的交点,以便只有在这个交点区域内的点才会被着色。 UIBezierPath 中是否有一种方
我正在制作一个应用程序,允许用户用手指在屏幕上绘制不同的颜色。图纸是用 UIBezierPaths 绘制的,但我需要橡皮擦。我确实有一个橡皮擦,它只是一条以背景图像为颜色的路径,但这种方法会导致内存问
我想用 SceneKit 画一条贝塞尔曲线,并认为这会起作用: func drawCurvedLine() { let scene = SCNScene() let scnView =
我在设置为 iPhone (Retina 4-inch) 的模拟器中运行此代码 -(void)drawRect:(CGRect)rect { [[UIColor whiteColor]set]
我想绘制月亮,然后为月亮的阴影设置动画。但启动此代码后,我可以在动画线上看到一些故障: GIF: 为什么会发生这种情况? Playground 代码 here 更新1:此函数创建的两条路径具有不同的角
假设我们有一个 UIBezierPath...它的边界是完全正方形的...像这样: func getExponentPath(rotate180: Bool) -> UIBezierPath {
我想绘制月亮,然后为月亮的阴影设置动画。但启动此代码后,我可以在动画线上看到一些故障: GIF: 为什么会发生这种情况? Playground 代码 here 更新1:此函数创建的两条路径具有不同的角
假设我们有一个 UIBezierPath...它的边界是完全正方形的...像这样: func getExponentPath(rotate180: Bool) -> UIBezierPath {
我正在试验 UIBezierPath。我想做一个 GridView 。 NSInteger yAxisIncremental = 0; NSInteger xAxisIncremental = 0;
我需要使用bezeirPath绘制此形状: 我做了以下事情: 我创建了矩形路径。 然后我添加了五个圈子。 如下面的代码所示: let stickLayerBezeirPath = UIBezierPa
我将 Apple 文档阅读到 UIBezierPath目的。我是否正确理解它不支持相对路径? 我正在尝试将此 svg 路径转换为 UIBezierPath: // svg path m90 36c
我正在尝试制作一个球从用户画线反弹的游戏。绘制线的代码包含在下面并且可以正常工作,但是一旦球与它接触或玩家画一条新线,我将如何删除线? path = [UIBezierPath bezierPath]
我想画一条这样的路径: 这就是我写的: CGFloat radius = 50; UIBezierPath *path = [UIBezierPath bezierPath]; [path moveT
我在 View 中有一个 UIBezierPath 。我想在单击形状时显示警报,但实际发生的情况是,不仅在我单击形状时显示警报,而且当我单击 View 中的任意位置时也会显示警报。 如何更改此代码,以
我正在尝试从圆形到带圆角的正方形制作动画。据我了解,对于流畅的动画,两条路径的点数应该相等。所以我写了一个基于多条弧构建圆的函数: private func circleShape(segmentNu
对于横向和纵向模式,是否可以将元素重置到相同的%位置(距x = 0轴的距离)?如果是的话你能告诉我怎么做吗?另外,由于我是 Swift 的新手,如果您发现任何错误的代码错误,请DO通知我以便得到更好的
我正在尝试在叠加渲染器中使用 UIBezierPath 绘制一些线条。我收到错误 CGContextSetStrokeColorWithColor: invalid context 0x0 我怀疑这是
我想圆化我的右角,但只适用于左角 let path = UIBezierPath(roundedRect: view.bounds, byRoundingCorners: [UIRectCorner.
我想圆化我的右角,但只适用于左角 let path = UIBezierPath(roundedRect: view.bounds, byRoundingCorners: [UIRectCorner.
当我尝试平移路径,将其移动到原点 {0, 0} 时,生成的路径边界错误。 (或者,我的假设是错误的)。 例如该路径给出以下边界信息: let bezier = UIBezierPath(cgPath:
我是一名优秀的程序员,十分优秀!