• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 为什么我的 CGImage 在 setNeedsDisplay 后无法正确显示

[复制链接]
菜鸟教程小白 发表于 2022-12-11 16:42:44 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我正在我的应用程序中绘制一个 colorWheel。我通过在单独的函数中生成 CGImage 并在 drawRect 中使用 CGContextDrawImage 将其放在屏幕上来做到这一点。

在最初的演示中,它看起来不错,但在我调用 setNeedsDisplay(或 setNeedsDisplayInRect)之后,图像变黑/失真。我一定在做一些愚蠢的事情,但看不到什么。

Cool Wheel Cool Wheel

DrawRect 代码如下:

override func drawRect(rect: CGRect) {

    if let context = UIGraphicsGetCurrentContext() {

        let wheelFrame = CGRectMake(0,0,circleRadius*2,circleRadius*2)
        CGContextSaveGState(context)

            //create clipping mask for circular wheel
        CGContextAddEllipseInRect(context, wheelFrame)
        CGContextClip(context)

            //draw the wheel
        if colorWheelImage != nil { CGContextDrawImage(context, CGRectMake(0,0,circleRadius*2,circleRadius*2), colorWheelImage) }
        CGContextRestoreGState(context)

            //draw a selector element
        self.drawSliderElement(context)
    }
}

CG图像生成函数:

func generateColorWheelImage() {

    let width       = Int(circleRadius*2)
    let height      = Int(circleRadius*2)

    var pixels = [PixelData]()

    for yIndex in 0..<width {
        for xIndex in 0..<height {
            pixels.append(colorAtPoint(CGPoint(x: xIndex, y: yIndex)))
        }
    }

    let rgbColorSpace   = CGColorSpaceCreateDeviceRGB()
    let bitmapInfo      = CGBitmapInfo.ByteOrderDefault

    let bitsPerComponent: Int   = 8
    let bitsPerPixel: Int       = 24

    let renderingIntent = CGColorRenderingIntent.RenderingIntentDefault

    assert(pixels.count == Int(width * height))

    var data = pixels

    let providerRef = CGDataProviderCreateWithData(nil, data, data.count * sizeof(PixelData), nil)

    colorWheelImage = CGImageCreate(width, height, bitsPerComponent, bitsPerPixel, width * Int(sizeof(PixelData)), rgbColorSpace, bitmapInfo, providerRef, nil, true,renderingIntent)

}



Best Answer-推荐答案


当我开始在 ipad 而不是模拟器上运行代码并收到 BAD_ACCESS_ERROR,而不是看到扭曲的图像时,我终于找到了这个问题的答案(这里:https://stackoverflow.com/a/10798750/5233176)。

正如答案所解释的:'[The] CMSampleBuffer 直接用于创建 CGImageRef,因此一旦释放缓冲区,[the] CGImageRef 将变得无效。'

因此问题出在这一行:

    let providerRef = CGDataProviderCreateWithData(nil, data, data.count * sizeof(PixelData), nil)

并且可以通过使用缓冲区的副本来解决问题,如下所示:

    let providerData    = NSData(bytes: data, length: data.count * sizeof(PixelData))
    let provider        = CGDataProviderCreateWithCFData(providerData)

关于ios - 为什么我的 CGImage 在 setNeedsDisplay 后无法正确显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37773844/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap