Отображение UIImage в SwitfUI темно - Apple Watch - PullRequest
2 голосов
/ 13 февраля 2020

Я не понимаю, почему изображение автомобиля systemName не появляется в Apple Watch Simulator. (черный)

import SwiftUI
struct ContentView: View {
    var body: some View {
        Image(uiImage: UIImage(systemName: "car")!)
    }
}

struct preview : PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

Нажмите здесь, чтобы посмотреть, как он выглядит (экран полностью черный, как будто ничего не было добавлено к виду)

Ответы [ 2 ]

3 голосов
/ 13 февраля 2020

Полагаю, это должно быть

enter image description here

struct ContentView: View {
    var body: some View {
        Image(systemName: "car") // < Native SwiftUI
    }
}

или ... если вам нравится UIImage, тот же результат с

Image(uiImage: UIImage(systemName: "car")!).colorInvert()
0 голосов
/ 14 февраля 2020

Решением было бы установить цвет UIImage на белый, например, он будет виден

Image(uiImage: UIImage(systemName: "car")!.maskWithColor(color: .white)!)

, где maskWithColor происходит от { ссылка }

extension UIImage {

    func maskWithColor(color: UIColor) -> UIImage? {
        let maskImage = cgImage!

        let width = size.width
        let height = size.height
        let bounds = CGRect(x: 0, y: 0, width: width, height: height)

        let colorSpace = CGColorSpaceCreateDeviceRGB()
        let bitmapInfo = CGBitmapInfo(rawValue: CGImageAlphaInfo.premultipliedLast.rawValue)
        let context = CGContext(data: nil, width: Int(width), height: Int(height), bitsPerComponent: 8, bytesPerRow: 0, space: colorSpace, bitmapInfo: bitmapInfo.rawValue)!

        context.clip(to: bounds, mask: maskImage)
        context.setFillColor(color.cgColor)
        context.fill(bounds)

        if let cgImage = context.makeImage() {
            let coloredImage = UIImage(cgImage: cgImage)
            return coloredImage
        } else {
            return nil
        }
    }

}
...