, поэтому я использовал файл XIB и поместил представление изображения в этот файл XIB, я поместил представление (перспективный вид) и поместил представление изображения в этот вид, и я хочудля репликации вида в перспективе, так вот мои коды в файле UIView, который является классом файла xib
import UIKit
class perspectiveView: UIView {
@IBOutlet var contentView: UIView!
@IBOutlet weak var perspectiveTitle: UILabel!
@IBOutlet weak var perspectiveView: UIView!
@IBOutlet weak var perspectiveImage: UIImageView!
override init(frame: CGRect) {
super.init(frame: frame)
commonInit()
}
override func layoutSubviews() {
super.layoutSubviews()
let replicatorLayer = CAReplicatorLayer()
let coloredSquare = CALayer()
// coloredSquare.backgroundColor = UIColor.red.cgColor
coloredSquare.frame = perspectiveView.bounds
coloredSquare.contents = perspectiveView.asImage().cgImage
let instanceCount = 3
replicatorLayer.instanceCount = instanceCount
replicatorLayer.instanceTransform = CATransform3DMakeTranslation(5, -10, -1)
replicatorLayer.instanceAlphaOffset = -0.3
replicatorLayer.addSublayer(coloredSquare)
perspectiveView.layer.addSublayer(replicatorLayer)
}
required public init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
commonInit()
}
private func commonInit() {
Bundle.main.loadNibNamed("perspectiveView", owner: self, options: nil)
addSubview(contentView)
contentView.frame = self.bounds
contentView.autoresizingMask = [.flexibleHeight , .flexibleWidth]
}
}
extension UIView {
// Using a function since `var image` might conflict with an existing variable
// (like on `UIImageView`)
func asImage() -> UIImage {
let renderer = UIGraphicsImageRenderer(bounds: bounds)
return renderer.image { rendererContext in
layer.render(in: rendererContext.cgContext)
}
}
}
, так что это будет работать, но не так, как я ожидал