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.

0 ответов

Другие вопросы по тегам