UIGraphicsImageRenderer не возвращает изображение в цикле
Я пытаюсь понять, почему UIGraphicsImageRender не возвращает изображение. Мы зациклим список вызовов, чтобы преобразовать вызывающий объект в uiimage, а затем сохраним uiimage в списке. Это происходит с индексом 91. Я использую этот процесс из калейеров в изображения, а затем конвертирую изображения в видеофайл. Я пробовал почти все - autoreleasepool, используя DispatchQueue, CG_CONTEXT_SHOW_BACKTRACE ничего не показывает. Я выдергиваю волосы на этом.
DispatchQueue(label: "imageQueue", qos: .utility, autoreleaseFrequency: .workItem).async {
var index = 0
while index < drawAnimationObjectsByIndex.count {
if let object = drawAnimationObjectsByIndex[index] {
let image = self.generateImage(layer: object.parent)
if image.cgImage != nil {
//os_log("the image is generated at %d.", log: self.tag, type: .debug, index)
images.append(image)
drawAnimationObjectsByIndex[index] = nil
index += 1
}
else {
//os_log("the image is not generated at %d.", log: self.tag, type: .debug, index)
}
}
}
completion(images)
}
private func generateImage(layer : CALayer) -> UIImage {
let renderer = UIGraphicsImageRenderer(size: settings.size)
let img = renderer.image {
ctx in
if ctx.cgContext != nil {
layer.render(in: ctx.cgContext)
}
else {
fatalError()
}
}
return img
}
Он возвращает эти сообщения об ошибках случайным образом (непоследовательно) -
021-05-18 09:53:56.782550-0500 apate[12603:7001594] [Unknown process name] CGBitmapContextInfoCreate: unable to allocate 74649600 bytes for bitmap data
2021-05-18 09:53:56.782663-0500 apate[12603:7001594] [Unknown process name] CGDisplayListDrawInContext: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable.
2021-05-18 09:53:56.782757-0500 apate[12603:7001594] [Unknown process name] CGBitmapContextCreateImage: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable.
2021-05-18 10:19:25.856682-0500 apate[12628:7070390] [DrawingRender] the image is generated at 89.
2021-05-18 10:19:25.895884-0500 apate[12628:7070390] [DrawingRender] the image is generated at 90.
2021-05-18 10:19:25.929803-0500 apate[12628:7070390] [DrawingRender] the image is not generated at 91.
2021-05-18 10:19:25.958797-0500 apate[12628:7070390] [DrawingRender] the image is not generated at 91.