如何调整正在打印在另一个图像上的图像的大小(swift3)

how to resize a image being printed over another image (swift3)

现在我的代码在红色框上保存了一个蓝色框。我需要将蓝色框的大小缩小 50%。这样所有的蓝色框周围都有一个红色边框。我有一个应该能够缩小图像的扩展文件,但我不知道将其放入我的代码的何处。

 extension UIImage {
func resized(withPercentage percentage: CGFloat) -> UIImage? {
    let canvasSize = CGSize(width: size.width * percentage, height: size.height * percentage)
    UIGraphicsBeginImageContextWithOptions(canvasSize, false, scale)
    defer { UIGraphicsEndImageContext() }
    draw(in: CGRect(origin: .zero, size: canvasSize))
    return UIGraphicsGetImageFromCurrentImageContext()
}
func resized(toWidth width: CGFloat) -> UIImage? {
    let canvasSize = CGSize(width: width, height: CGFloat(ceil(width/size.width * size.height)))
    UIGraphicsBeginImageContextWithOptions(canvasSize, false, scale)
    defer { UIGraphicsEndImageContext() }
    draw(in: CGRect(origin: .zero, size: canvasSize))
    return UIGraphicsGetImageFromCurrentImageContext()
}}

import UIKit
class ViewController: UIViewController {

var image1 = UIImage(named: "red")
var image2 = UIImage(named: "blue")




    func cropImageIntoQuarterSquare(image: UIImage) -> UIImage? {
        let originalImageSize: CGSize = image.size
        let smallImageSize = CGSize(width: (originalImageSize.width + 40), height: (originalImageSize.height + 40))


        UIGraphicsBeginImageContext(smallImageSize)
        image.draw(at: CGPoint.zero)
        let imageResult = UIGraphicsGetImageFromCurrentImageContext()
        UIGraphicsEndImageContext()

        return imageResult
    }



override func viewDidLoad() {
    super.viewDidLoad()}
    func saveImage(image1: UIImage, image2: UIImage) -> UIImage? {
        let size1 = image1.size
        let size2 = image2.size
        let origin = CGPoint(x: size1.width - size2.width, y: size1.height - size2.height)

        UIGraphicsBeginImageContext(size1)
        image1.draw(in: CGRect(origin: CGPoint.zero, size: size1))
        image2.draw(in: CGRect(origin: origin, size: size2))
        let combinedImage = UIGraphicsGetImageFromCurrentImageContext()
        UIGraphicsEndImageContext()

        return combinedImage
    }

    func image(_ image: UIImage, didFinishSavingWithError error: Error?, contextInfo: UnsafeRawPointer) {
        if let error = error {
            // we got back an error!
            let ac = UIAlertController(title: "Save error", message: error.localizedDescription, preferredStyle: .alert)
            ac.addAction(UIAlertAction(title: "OK", style: .default))
            present(ac, animated: true)
        } else {
            let ac = UIAlertController(title: "Saved!", message: "Your altered image has been saved to your photos.", preferredStyle: .alert)
            ac.addAction(UIAlertAction(title: "OK", style: .default))
            present(ac, animated: true)
        }
    }



@IBAction func d(_ sender: Any) {


    guard let croppedImage = cropImageIntoQuarterSquare(image: image2!),
        let combinedImage = saveImage(image1: image1!, image2: croppedImage) else {
            // handle the error
            return
    }

    UIImageWriteToSavedPhotosAlbum(combinedImage, self, #selector(image(_:didFinishSavingWithError:contextInfo:)), nil)
    }}

这个功能或许能帮到你。您可以根据自己的意愿编辑大小和原点值

func drawImage() -> UIImage {
    var bottomImage = UIImage(named: "red")
    //background image
    let image: UIImage = UIImage(named: "blue")
    //foreground image
    let newSize: CGSize = CGSize(width: 80, height: 80)
    UIGraphicsBeginImageContext(newSize)

    bottomImage.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height))

    image.draw(in: CGRect(x: 20, y: 20, width: 40, height: 40), blendMode: .normal, alpha: 1.0)
    let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()!
    UIGraphicsEndImageContext()

    return newImage
  }