CGPointZero и CGContextDrawImage недоступны

Я не смог преобразовать CGContextDrawImage для swift 3, я попробовал context.draw, но это не сработало. есть ли кто-нибудь, кто может дать мне отзыв

Снимок экрана с ошибкой

Код:

import UIKit

public struct Pixel {
public var value: UInt32

public var red: UInt8 {
    get {
        return UInt8(value & 0xFF)
    }
    set {
        value = UInt32(newValue) | (value & 0xFFFFFF00)
    }
}

public var green: UInt8 {
    get {
        return UInt8((value >> 8) & 0xFF)
    }
    set {
        value = (UInt32(newValue) << 8) | (value & 0xFFFF00FF)
    }
}

public var blue: UInt8 {
    get {
        return UInt8((value >> 16) & 0xFF)
    }
    set {
        value = (UInt32(newValue) << 16) | (value & 0xFF00FFFF)
    }
}

public var alpha: UInt8 {
    get {
        return UInt8((value >> 24) & 0xFF)
    }
    set {
        value = (UInt32(newValue) << 24) | (value & 0x00FFFFFF)
    }
}

public struct RGBAImage {
public var pixels: [Pixel]

public var width: Int
public var height: Int

public init?(image: UIImage) {
    guard let cgImage = image.cgImage else { return nil }

    // Redraw image for correct pixel format
    let colorSpace = CGColorSpaceCreateDeviceRGB()

    var bitmapInfo: UInt32 = CGBitmapInfo.byteOrder32Big.rawValue
    bitmapInfo |= CGImageAlphaInfo.premultipliedLast.rawValue & CGBitmapInfo.alphaInfoMask.rawValue

    width = Int(image.size.width)
    height = Int(image.size.height)
    let bytesPerRow = width * 4

    let imageData = UnsafeMutablePointer<Pixel>.allocate(capacity: width * height)

    guard let imageContext = CGContext(data: imageData, width: width, height: height, bitsPerComponent: 8, bytesPerRow: bytesPerRow, space: colorSpace, bitmapInfo: bitmapInfo) else { return nil }
    CGContextDrawImage(imageContext, CGRect(origin: CGPointZero, size: image.size), cgImage)

    let bufferPointer = UnsafeMutableBufferPointer<Pixel>(start: imageData, count: width * height)
    pixels = Array(bufferPointer)

    imageData.deinitialize()
    imageData.deallocate(capacity: width * height)
}

public func toUIImage() -> UIImage? {
    let colorSpace = CGColorSpaceCreateDeviceRGB()
    var bitmapInfo: UInt32 = CGBitmapInfo.byteOrder32Big.rawValue
    bitmapInfo |= CGImageAlphaInfo.premultipliedLast.rawValue & CGBitmapInfo.alphaInfoMask.rawValue

    let bytesPerRow = width * 4

    let imageDataReference = UnsafeMutablePointer<Pixel>(mutating: pixels)
    defer {
        imageDataReference.deinitialize()
    }
    let imageContext = CGContext(data: imageDataReference, width: width, height: height, bitsPerComponent: 8, bytesPerRow: bytesPerRow, space: colorSpace, bitmapInfo: bitmapInfo, releaseCallback: nil, releaseInfo: nil)

    guard let cgImage = imageContext!.makeImage() else {return nil}
    let image = UIImage(cgImage: cgImage)

    return image
}

person Alperen Veli Sezer    schedule 18.10.2016    source источник
comment
Вы можете найти некоторые в SO, например это или это. И я не могу найти в вашем коде, что вы пробовали context.draw.   -  person OOPer    schedule 18.10.2016
comment
Чтобы отформатировать код, не добавляйте кавычки, а выберите код и нажмите CMD+K. Я сделал это один раз, а вы испортили его с последующим редактированием - пожалуйста, переформатируйте. Спасибо.   -  person Eric Aya    schedule 18.10.2016
comment
В Swift 3 это CGPoint.zero и context.draw(...).   -  person Codo    schedule 18.10.2016
comment
CGSizeZero и CGSizeMake доступны в Swift 2.0, а в Swift 3.0 вы можете использовать их с CGSize и CGRect.   -  person Himanshu Moradiya    schedule 18.10.2016
comment
@Alperen: вам лучше привести пример неработающего context.draw вместо функции CGContextDrawImage.   -  person alexburtnik    schedule 18.10.2016


Ответы (1)


Все функции CoreGraphics C были переработаны, чтобы лучше соответствовать стилю Swift:

Свифт 2:

CGContextDrawImage(imageContext, CGRect(origin: CGPointZero, size: image.size), cgImage)

Свифт 3:

imageContext.draw(cgImage, in: CGRect(origin: .zero, size: image.size))

P.S. .zero можно использовать вместо CGPoint.zero, потому что его тип выводится неявно.

person alexburtnik    schedule 18.10.2016