NetNewsWire/iOS/IconView.swift

129 lines
3.2 KiB
Swift
Raw Normal View History

2019-09-18 00:00:23 +02:00
//
// IconView.swift
2019-09-18 00:00:23 +02:00
// NetNewsWire-iOS
//
// Created by Maurice Parker on 9/17/19.
// Copyright © 2019 Ranchero Software. All rights reserved.
//
import UIKit
final class IconView: UIView {
2019-09-18 00:00:23 +02:00
var iconImage: IconImage? = nil {
2019-09-18 00:00:23 +02:00
didSet {
if iconImage !== oldValue {
imageView.image = iconImage?.image
if self.traitCollection.userInterfaceStyle == .dark {
2020-03-13 14:21:38 +01:00
if self.iconImage?.isDark ?? false {
self.isDisconcernable = false
self.setNeedsLayout()
} else {
self.isDisconcernable = true
self.setNeedsLayout()
}
} else {
2020-03-13 14:21:38 +01:00
if self.iconImage?.isBright ?? false {
self.isDisconcernable = false
self.setNeedsLayout()
} else {
self.isDisconcernable = true
self.setNeedsLayout()
}
}
self.setNeedsLayout()
2019-09-18 00:00:23 +02:00
}
}
}
private var isDisconcernable = true
2019-09-18 00:00:23 +02:00
private let imageView: UIImageView = {
let imageView = NonIntrinsicImageView(image: AppAssets.faviconTemplateImage)
2019-09-18 00:00:23 +02:00
imageView.contentMode = .scaleAspectFit
imageView.clipsToBounds = true
imageView.layer.cornerRadius = 2.0
2019-09-18 00:00:23 +02:00
return imageView
}()
private var isVerticalBackgroundExposed: Bool {
2019-09-18 00:00:23 +02:00
return imageView.frame.size.height < bounds.size.height
}
private var isSymbolImage: Bool {
return iconImage?.isSymbol ?? false
}
private var isBackgroundSuppressed: Bool {
return iconImage?.isBackgroundSupressed ?? false
}
2019-09-18 00:00:23 +02:00
override init(frame: CGRect) {
super.init(frame: frame)
commonInit()
}
required init?(coder: NSCoder) {
super.init(coder: coder)
commonInit()
}
convenience init() {
self.init(frame: .zero)
}
override func didMoveToSuperview() {
setNeedsLayout()
}
override func layoutSubviews() {
imageView.setFrameIfNotEqual(rectForImageView())
if !isBackgroundSuppressed && ((iconImage != nil && isVerticalBackgroundExposed) || !isDisconcernable) {
backgroundColor = AppAssets.iconBackgroundColor
2019-09-18 00:00:23 +02:00
} else {
2019-09-19 20:41:07 +02:00
backgroundColor = nil
2019-09-18 00:00:23 +02:00
}
}
2019-09-19 20:41:07 +02:00
2019-09-18 00:00:23 +02:00
}
private extension IconView {
2019-09-18 00:00:23 +02:00
func commonInit() {
layer.cornerRadius = MasterTimelineDefaultCellLayout.iconCornerRadius
2019-10-29 02:01:15 +01:00
clipsToBounds = true
2019-09-18 00:00:23 +02:00
addSubview(imageView)
}
func rectForImageView() -> CGRect {
guard let image = iconImage?.image else {
2019-09-18 00:00:23 +02:00
return CGRect.zero
}
let imageSize = image.size
let viewSize = bounds.size
if imageSize.height == imageSize.width {
if imageSize.height >= viewSize.height * 0.75 {
// Close enough to viewSize to scale up the image.
return CGRect(x: 0.0, y: 0.0, width: viewSize.width, height: viewSize.height)
}
let offset = floor((viewSize.height - imageSize.height) / 2.0)
return CGRect(x: offset, y: offset, width: imageSize.width, height: imageSize.height)
}
else if imageSize.height > imageSize.width {
let factor = viewSize.height / imageSize.height
let width = imageSize.width * factor
let originX = floor((viewSize.width - width) / 2.0)
return CGRect(x: originX, y: 0.0, width: width, height: viewSize.height)
}
// Wider than tall: imageSize.width > imageSize.height
let factor = viewSize.width / imageSize.width
let height = imageSize.height * factor
let originY = floor((viewSize.height - height) / 2.0)
return CGRect(x: 0.0, y: originY, width: viewSize.width, height: height)
}
}