服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS实现文字转化成彩色文字图片

iOS实现文字转化成彩色文字图片

2021-01-12 15:31jiangamh IOS

这篇文章主要为大家详细介绍了iOS文字转化成彩色文字图片的实现方法,可以实现不同字体,渐变的效果,感兴趣的小伙伴们可以参考一下

本文写了个将文字转化为多彩图片的功能,输入文字将文字转化为彩色的文字图片,可选择不同的字体,渐变,先看看效果。

iOS实现文字转化成彩色文字图片

实现主要用cagradientlayer渐变,先看看上部展示实现代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
-(void)setupcontentview
{
 uiview *contentview = [[uiview alloc] initwithframe:cgrectmake(0, 44, screenwidth, screenhight - 44 -300)];
 [self.view addsubview:contentview];
 uitapgesturerecognizer *tapgesture = [[uitapgesturerecognizer alloc] initwithtarget:self action:@selector(tapgestureaction:)];
 [contentview addgesturerecognizer:tapgesture];
 self.topcontentview = contentview;
 self.topcontentview.backgroundcolor = [uicolor clearcolor];
 
 uilabel *label = [[uilabel alloc] init];
 label.numberoflines = 0;
 label.text = @"abc";
 label.frame = [self calculatecontextlabelframewithtitle:@"abc"];
 label.center = cgpointmake(contentview.bounds.size.width / 2, contentview.bounds.size.height / 2);
 label.font = [uifont fontwithname:self.fontnamearray[0] size:25];
 label.textalignment = nstextalignmentcenter;
 [contentview addsubview:label];
 label.backgroundcolor = [uicolor clearcolor];
 self.contentlabel = label;
 
 self.gradientlayer = [cagradientlayer layer];
 self.gradientlayer.frame = cgrectmake(label.frame.origin.x, label.frame.origin.y, label.frame.size.width, label.frame.size.height);
 self.gradientlayer.backgroundcolor = [uicolor clearcolor].cgcolor;
 self.gradientlayer.startpoint = cgpointmake(0,0.5);
 self.gradientlayer.endpoint = cgpointmake(1,0.5);
 self.gradientlayer.colors = self.grandentarr[0];
 [contentview.layer addsublayer:self.gradientlayer];
 self.gradientlayer.mask = self.contentlabel.layer;
 self.contentlabel.frame = self.gradientlayer.bounds;
}

当输入的文字改变时,重新计算 self.gradientlayer的frame

?
1
2
3
4
5
-(void)textfieldtextchange:(nsnotification*)notice
{
 self.contentlabel.text = self.textfield.text;
 [self recalculategradientlayerframe];
}

下部分的实现代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
-(void)setupbottomview
{
 uiview *bottomview =[[uiview alloc] initwithframe:cgrectmake(0, screenhight - 300, screenwidth, 300)];
 bottomview.backgroundcolor = jgcolor(222, 222, 222);
 [self.view addsubview:bottomview];
 self.bottomcontentview = bottomview;
 
 uiview *textcontentview = [[uiview alloc] init];
 textcontentview.frame = cgrectmake(0, 0, bottomview.bounds.size.width, 50);
 [bottomview addsubview:textcontentview];
 textcontentview.backgroundcolor = jgcolor(55, 44, 16);
 
 uitextfield *textfield = [[uitextfield alloc] init];
 textfield.borderstyle = uitextborderstyleroundedrect;
 textfield.frame = cgrectmake(10, 5, textcontentview.bounds.size.width - 20, textcontentview.bounds.size.height - 10);
 [textcontentview addsubview:textfield];
 self.textfield = textfield;
 
 cgfloat orgy = 60;
 cgfloat orgx = 10;
 cgfloat space = 10;
 cgfloat width = (screenwidth - orgx * 2 - 3 * space) / 4;
 cgfloat height = 35;
 
 for (int i = 0; i < 16; i++) {
  uiview *vw = [[uiview alloc] initwithframe:cgrectmake(orgx + (i % 4) * width + (i % 4) * space, orgy + (i / 4) * height + (i / 4) * space, width, height)];
  vw.backgroundcolor = [uicolor clearcolor];
  vw.tag = i + 1;
  [self.bottomcontentview addsubview:vw];
 
  uitapgesturerecognizer *tapgesture = [[uitapgesturerecognizer alloc] initwithtarget:self action:@selector(viewtap:)];
  [vw addgesturerecognizer:tapgesture];
 
  uilabel *label = [[uilabel alloc] initwithframe:vw.bounds
       ];
  label.textalignment = nstextalignmentcenter;
  label.text = @"abc";
  label.frame = vw.bounds;
  label.font = [uifont fontwithname:self.fontnamearray[i % 4] size:25];
  label.backgroundcolor = [uicolor clearcolor];
  [vw addsubview:label];
 
  cagradientlayer *grandient = [cagradientlayer layer];
  grandient.frame = cgrectmake(label.frame.origin.x, label.frame.origin.y, label.frame.size.width, label.frame.size.height);
  grandient.backgroundcolor = [uicolor clearcolor].cgcolor;
  grandient.startpoint = cgpointmake(0,0.5);
  grandient.endpoint = cgpointmake(1,0.5);
  grandient.colors = self.grandentarr[i / 4];
  [vw.layer addsublayer:grandient];
  grandient.mask = label.layer;
  label.frame = grandient.bounds;
 }
}

将文字转化为图片的代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
-(void)gettitleimg
{
 uigraphicsbeginimagecontext(self.topcontentview.frame.size);
 cgcontextref context = uigraphicsgetcurrentcontext();
 
 if ([[uidevice currentdevice].systemversion floatvalue] >= 7.0) {
  [self.topcontentview drawviewhierarchyinrect:self.topcontentview.frame afterscreenupdates:yes];
 }
 else
 {
  [self.topcontentview.layer renderincontext:context];
 }
 
 uiimage *img = uigraphicsgetimagefromcurrentimagecontext();
 uigraphicsendimagecontext();
 
 cgimageref newimgref = cgimagecreatewithimageinrect(img.cgimage, cgrectmake(self.gradientlayer.frame.origin.x, self.gradientlayer.frame.origin.y + 44, self.gradientlayer.frame.size.width, self.gradientlayer.frame.size.height));
 
 uigraphicsbeginimagecontextwithoptions(self.gradientlayer.frame.size, no, [uiscreen mainscreen].scale);
 context = uigraphicsgetcurrentcontext();
 
 cgcontexttranslatectm(context, 0, self.gradientlayer.frame.size.height);
 cgcontextscalectm(context, 1, -1);
 
 cgcontextdrawimage(context, cgrectmake(0, 0, self.gradientlayer.frame.size.width, self.gradientlayer.frame.size.height), newimgref);
 uiimage *newimg = uigraphicsgetimagefromcurrentimagecontext();
 uigraphicsendimagecontext();
 
 alassetslibrary *library = [[alassetslibrary alloc] init];
 [library toolwriteimagetosavedphotosalbum:newimg.cgimage metadata:nil completionblock:^(nsurl *asseturl, nserror *error) {
 
  if (error) {
   jglog(@"写入出错");
  }
 } groupname:@"相册名称"];
 
}

核心代码如上,主要运用到了cagradientlayer,截图,裁图的方法。
以上就是本文的全部内容,希望对大家的学习有所帮助。

延伸 · 阅读

精彩推荐
  • IOSiOS中滑动控制屏幕亮度和系统音量(附加AVAudioPlayer基本用法和Masonry简单使用)

    iOS中滑动控制屏幕亮度和系统音量(附加AVAudioPlayer基本用法和

    这篇文章主要介绍了iOS中滑动控制屏幕亮度和系统音量(附加AVAudioPlayer基本用法和Masonry简单使用)的相关资料,需要的朋友可以参考下...

    CodingFire13652021-02-26
  • IOSiOS中UILabel实现长按复制功能实例代码

    iOS中UILabel实现长按复制功能实例代码

    在iOS开发过程中,有时候会用到UILabel展示的内容,那么就设计到点击UILabel复制它上面展示的内容的功能,也就是Label长按复制功能,下面这篇文章主要给大...

    devilx12792021-04-02
  • IOS详解iOS中多个网络请求的同步问题总结

    详解iOS中多个网络请求的同步问题总结

    这篇文章主要介绍了详解iOS中多个网络请求的同步问题总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    liang199111302021-03-15
  • IOSiOS实现控制屏幕常亮不变暗的方法示例

    iOS实现控制屏幕常亮不变暗的方法示例

    最近在工作中遇到了要将iOS屏幕保持常亮的需求,所以下面这篇文章主要给大家介绍了关于利用iOS如何实现控制屏幕常亮不变暗的方法,文中给出了详细的...

    随风13332021-04-02
  • IOSiOS中MD5加密算法的介绍和使用

    iOS中MD5加密算法的介绍和使用

    MD5加密是最常用的加密方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码。对输入信息生成唯一的128位散列值(32个字符)。这篇文...

    LYSNote5432021-02-04
  • IOSiOS开发技巧之状态栏字体颜色的设置方法

    iOS开发技巧之状态栏字体颜色的设置方法

    有时候我们需要根据不同的背景修改状态栏字体的颜色,下面这篇文章主要给大家介绍了关于iOS开发技巧之状态栏字体颜色的设置方法,文中通过示例代码...

    梦想家-mxj8922021-05-10
  • IOSiOS开发之视图切换

    iOS开发之视图切换

    在iOS开发中视图的切换是很频繁的,独立的视图应用在实际开发过程中并不常见,除非你的应用足够简单。在iOS开发中常用的视图切换有三种,今天我们将...

    执着丶执念5272021-01-16
  • IOSiOS自定义UICollectionViewFlowLayout实现图片浏览效果

    iOS自定义UICollectionViewFlowLayout实现图片浏览效果

    这篇文章主要介绍了iOS自定义UICollectionViewFlowLayout实现图片浏览效果的相关资料,需要的朋友可以参考下...

    jiangamh8882021-01-11