话不多说,直接上代码
新建了一个UIImage的类目,在.h中声明
?
1
|
+ (UIImage *)imageWithimage:(UIImage *)image content:(NSString *)content frame:(CGRect)frame;
|
.m如下
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
+ (UIImage *)imageWithimage:(UIImage *)image content:(NSString *)content frame:(CGRect)frame {
// 开启图形'上下文'
UIGraphicsBeginImageContextWithOptions(image.size, NO, 0);
// 绘制原生图片
[image drawAtPoint:CGPointZero];
// 在原生图上绘制文字
NSString *str = content;
// 创建文字属性字典
NSDictionary *dictionary = @{NSForegroundColorAttributeName: [UIColor blackColor], NSFontAttributeName: [UIFont systemFontOfSize:20]};
// 绘制文字属性
[str drawInRect:frame withAttributes:dictionary];
// 从当前上下文获取修改后的图片
UIImage *imageNew = UIGraphicsGetImageFromCurrentImageContext();
// 结束图形上下文
UIGraphicsEndImageContext();
return imageNew;
}
|
但是需要注意的是 drawInRect: withAttributes:
方法在iOS7.0以后才能使用, 使用该方法的时候需要先看系统是否合适,也可以在方法中加上判断.
?
1
2
3
4
|
double device = [[UIDevice currentDevice].systemVersion doubleValue];
if (device >= 7.0f) {
// do something
}
|
之后在VC中导入头文件, 创建一个imageView
?
1
2
3
4
5
|
// 调用方法传入一个image对象,想要添加的文字和文字所在位置
UIImage *image = [UIImage imageWithimage:[UIImage imageNamed:@ "3" ] content:@ "伊利丹" frame: CGRectMake(20, 500, 100, 100)];
UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, kScreenWidth, kScreenHeight)];
imageView.image = image;
[self.view addSubview:imageView];
|
效果如下图,简单的实现了在图片上加水印的功能,如果想要改变文字的大小和颜色可以在方法中修改.或者给方法添加一个文字属性的字典参数.
以上就是在iOS给图片加水印的全部内容,本文给出了实例代码,相信对大家理解更有帮助,希望能对大家开发IOS有所帮助。
相关文章
猜你喜欢
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
2025-05-27 25
-
2025-05-25 13
-
2025-05-27 62
-
2025-05-29 67
-
2025-05-27 42
热门评论