(轉)iOS—添加文字水印(swift版)

原文鏈接(iOS—添加文字水印)
最近有個寫水印需求,搜到了上面的文章,修復了一些小問題,改成swift實現(xiàn),如下:

import Foundation
import UIKit

fileprivate let HORIZONTAL_SPACEING: CGFloat = 30 //水平間距
fileprivate let VERTICAL_SPACEING: CGFloat = 50 //豎直間距
fileprivate let CG_TRANSFORM_ROTATING = CGFloat(-Double.pi / 6) //旋轉角度(正旋45度 || 反旋45度)

class WaterMarkView: UIView {
    public private(set) lazy var waterMarkImgV: UIImageView = {
        let imgV = UIImageView(frame: self.bounds)
        imgV.image = UIImage(named: "")
        return imgV
    }()
    
    private static let shared = WaterMarkView(frame: UIScreen.main.bounds)
    /// 水印文字
    public private(set) var markText: NSString = "默認水印文字"

    override init(frame: CGRect) {
        super.init(frame: frame)

        self.addSubview(waterMarkImgV)
        waterMarkImgV.frame = frame
    }

    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    /// 顯示水印
    public static func show(view: UIView, text: String = "默認水印文字") {
        let markText = text as NSString
        let image = waterImage(size: view.bounds.size, text: markText)
        let shared =  WaterMarkView.shared
        shared.markText = markText
        shared.waterMarkImgV.image = image
        
        view.addSubview(shared)
    }
    
    /// 隱藏水印
    public static func hide() {
        let shared =  WaterMarkView.shared
        shared.removeFromSuperview()
    }

    /// 水印圖片
    private static func waterImage(size: CGSize, text: NSString, font: UIFont = UIFont.systemFont(ofSize: 17), textColor: UIColor = .black) -> UIImage? {
        let imgW: CGFloat = size.width
        let imgH: CGFloat = size.height
        // 1.開啟上下文
        UIGraphicsBeginImageContextWithOptions(size, false, 0)

        // 2.繪制圖片
        //屬性字符串
        let attr: [NSAttributedString.Key: Any] = [.font: font, .foregroundColor: textColor]
        let attrStr = NSMutableAttributedString(string: text as String, attributes: attr)

        //文字寬高
        let strW: CGFloat = attrStr.size().width
        let strH: CGFloat = attrStr.size().height

        //獲取當前上下文
        guard let context = UIGraphicsGetCurrentContext() else { return nil }

        //調(diào)整矩陣錨點到中心
        context.concatenate(CGAffineTransform(translationX: imgW * 0.5, y: imgH * 0.5))
        //旋轉矩陣
        context.concatenate(CGAffineTransform(rotationAngle: CG_TRANSFORM_ROTATING))
        //恢復錨點位置到左上角
        context.concatenate(CGAffineTransform(translationX: -imgW * 0.5, y: -imgH * 0.5))

        //對角線長度(實際繪制范圍是對角線長度的正方形)
        let sqrtLength: CGFloat = sqrt(pow(imgW, 2) + pow(imgH, 2))

        //繪制的行數(shù)和列數(shù)
        let countHor = Int(sqrtLength / (strW + HORIZONTAL_SPACEING)) + 1
        let countVer = Int(sqrtLength / (strH + VERTICAL_SPACEING)) + 1

        //畫布起點
        let orginX: CGFloat = -(sqrtLength - imgW) * 0.5
        let orginY: CGFloat = -(sqrtLength - imgH) * 0.5

        //雙循環(huán)實現(xiàn)
        var i = 0
        var j = 0
        while i < countVer {
            j = 0
            let overlayOriginY = orginY + CGFloat(i) * (strH + VERTICAL_SPACEING)
            while j < countHor {
                let overlayOrginX = orginX + CGFloat(j) * (strW + HORIZONTAL_SPACEING)
                //繪制單個文字水印
                let drawRect = CGRect(x: overlayOrginX, y: overlayOriginY, width: strW, height: strH)
                text.draw(in: drawRect, withAttributes: attr)
                j += 1
            }
            i += 1
        }

        //3.上下文獲取新圖片
        let newImage = UIGraphicsGetImageFromCurrentImageContext()

        //4.關閉上下文
        UIGraphicsEndImageContext()
        context.restoreGState()

        return newImage
    }
    
    override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
        return nil
    }

}

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 一、背景 在iOS平臺下,使用FFmpeg tools(命令行)開發(fā)添加文字水印功能需要添加libfreetype...
    小影X閱讀 2,889評論 2 1
  • 水印是一個很神奇的東西,沒有ps是不能將它擦拭掉的,很多人會將自己做的的滿意的做平放到網(wǎng)上供網(wǎng)友欣賞可是又怕自己的...
    霖尤_9076閱讀 1,127評論 1 1
  • 加水印的方式有很多,比如給圖片添加圖片水印、文字水印,或者給視頻添加圖片水印、文字水印。本文首先講解如何給圖片添加...
    金絲楠閱讀 22,542評論 9 20
  • 功能需求 在圖片的給定位置上添加文字水印 水印可以旋轉和設置透明度 先說說自己的實現(xiàn)思路: 先創(chuàng)建具有透明背景色的...
    雪飛鴻閱讀 2,412評論 2 15
  • 廢話不多說了,添加文字水印的步驟如下:1、創(chuàng)建一個UIImageView 2、創(chuàng)建類文件設置水印效果 Waterm...
    Cy_Star閱讀 8,277評論 8 13

友情鏈接更多精彩內(nèi)容