iOS—添加文字水印

废话不多说了,添加文字水印的步骤如下:
1、创建一个UIImageView

 -(instancetype)initWithFrame:(CGRect)frame withText:(NSString *)text
  {
         if (self = [super initWithFrame:frame]) {
            self.alpha = 0.4;  //设置水印透明
            //添加水印 :  Watermark 类文件    WaterImageWithImage:水印图片 设置为 @""就是透明背景效果   text:传入自己想要的水印文字
            self.image = [Watermark view:self WaterImageWithImage:[UIImage imageNamed:@""] text:text];
    }
  return self;
}

2、创建类文件设置水印效果 Watermark

/ * 这三个属性 主要是让水印文字和水印文字之间间隔的效果,以及水印的文字的倾斜角度 ,不设置默认为平行角度*/
#define HORIZONTAL_SPACEING 30//水平间距
#define VERTICAL_SPACEING 50//竖直间距
#define CG_TRANSFORM_ROTATING (M_PI_2 / 3)//旋转角度(正旋45度 || 反旋45度)

@implementation Watermark

+(UIImage*)view:(UIImageView *)view WaterImageWithImage:(UIImage *)image text:(NSString *)text{

//设置水印大小,可以根据图片大小或者view大小
CGFloat  img_w = view.bounds.size.width;
CGFloat  img_h = view.bounds.size.height;

 //1.开启上下文
//    UIGraphicsBeginImageContext(CGSizeMake(img_w, img_h));
UIGraphicsBeginImageContextWithOptions(CGSizeMake(w, h), NO, 0.0);   
//2.绘制图片 水印图片
[image drawInRect:CGRectMake(0, 0, img_w, img_h)];

 /* --添加水印文字样式--*/
UIFont * font = [UIFont systemFontOfSize:23.0]; //水印文字大小
NSDictionary * attr = @{NSFontAttributeName:font,NSForegroundColorAttributeName:[UIColor orangeColor]}; 
NSMutableAttributedString * attr_str =[[NSMutableAttributedString alloc]initWithString:text attributes:attr];

//文字:字符串的宽、高
CGFloat str_w = attr_str.size.width;
CGFloat str_h = attr_str.size.height;

//根据中心开启旋转上下文矩阵,绘制水印文字
CGContextRef context = UIGraphicsGetCurrentContext();

//将绘制原点(0,0)调整到源image的中心
CGContextConcatCTM(context, CGAffineTransformMakeTranslation(img_w/2, img_h/2));
//以绘制原点为中心旋转
CGContextConcatCTM(context, CGAffineTransformMakeRotation(CG_TRANSFORM_ROTATING));

//将绘制原点恢复初始值,保证context中心点和image中心点处在一个点(当前context已经发生旋转,绘制出的任何layer都是倾斜的)
CGContextConcatCTM(context, CGAffineTransformMakeTranslation(-w/2, -h/2));

//sqrtLength:原始image对角线length。在水印旋转矩阵中只要矩阵的宽高是原始image的对角线长度,无论旋转多少度都不会有空白。
CGFloat sqrtLength = sqrt(img_w*img_w + img_h*img_h);


//计算需要绘制的列数和行数
int count_Hor = sqrtLength / (str_w + HORIZONTAL_SPACEING) + 1;
int count_Ver = sqrtLength / (str_h + VERTICAL_SPACEING) + 1;

//此处计算出需要绘制水印文字的起始点,由于水印区域要大于图片区域所以起点在原有基础上移
CGFloat orignX = -(sqrtLength-w)/2;
CGFloat orignY = -(sqrtLength-h)/2;

//在每列绘制时X坐标叠加
CGFloat overlayOrignX = orignX;
//在每行绘制时Y坐标叠加
CGFloat overlayOrignY = orignY;
for (int i = 0; i < count_Hor * count_Ver; i++) {
    //绘制图片
    [text drawInRect:CGRectMake(overlayOrignX, overlayOrignY, str_w, str_h) withAttributes:attr];
    if (i % count_Hor == 0 && i != 0) {
        overlayOrignX = orignX;
        overlayOrignY += (str_h + VERTICAL_SPACEING);
    }else{
        overlayOrignX += (str_w + HORIZONTAL_SPACEING);
    }
}

 //3.从上下文中获取新图片
 UIImage * newImage = UIGraphicsGetImageFromCurrentImageContext();

  [view.layer renderInContext:UIGraphicsGetCurrentContext()];

  //4.关闭图形上下文
  UIGraphicsEndImageContext();
  CGContextRestoreGState(context);


  return newImage;
}
@end

/

3.添加水印

Watermark_ImgView * wkImgView =[[Watermark_ImgView alloc]initWithFrame:CGRectMake(0, 0, Screen_Width, Screen_Height) withText:@"自己想要的水印文字"];
// 想要水印不被任何UI遮挡住,就在最后、最后、最后的时候添加
[self.view addSubview:wkImgView];  
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 225,132评论 6 523
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 96,457评论 3 404
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 172,411评论 0 368
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 61,147评论 1 301
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 70,145评论 6 400
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,611评论 1 315
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,962评论 3 429
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,948评论 0 279
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,479评论 1 324
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,514评论 3 347
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,640评论 1 355
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,228评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,973评论 3 340
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,402评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,551评论 1 277
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 50,210评论 3 381
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,714评论 2 366

推荐阅读更多精彩内容

  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,437评论 8 265
  • 孟圆的笔记阅读 2,402评论 0 0
  • 吃过晚饭后,我习惯性的拿起手机,一打开朋友圈,就看见闺蜜发了一条新消息,图片上是几碗米饭和几道普通的家常菜。上方配...
    五瓣紫丁香阅读 616评论 2 3
  • 多想 我在想你的时候 你刚好也想着我 灯光闪烁着 告诉你 这首歌刚好是我的心境 像鸟在空中扑腾翅膀 落下羽毛、灰尘...
    沛瑾阅读 166评论 0 0
  • 不知道怎么说好 昨天晚上应该是我们两个都最生气的一次了 我以为我理直气壮地没有他我也可以好好的 可是后来我发现我还...
    青衫不华阅读 170评论 0 0