码迷,mamicode.com
首页 > 移动开发 > 详细

iOS中如何添加自定义的字体

时间:2015-06-06 10:36:20      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:ios   font   

      苹果对于开发,确实在细节方面下了很大的功夫,不过无论一个平台下多大的功夫,仍然会有些需求是无法涵盖的,比如字体吧。我们的应用为了能更加个性化,会需要不同的字体,有时候有些字体是非常特殊的,甚至是购买的,那么这些字体如何加到项目中去呢?

      字体有相应的字体文件,一般是以ttf或者otf为后缀,我们可以去一些第三方网站去下载(也有人专门做了字体出售),Google Fonts是个比较好的网站,可以去找找看。我们就用Open Sans这个字体来做例子吧。首先当然是去下载字体文件,下载后发现是10个ttf文件,没错,这是一个系列的字体,有粗体,有斜体,还有不同的大小,方便用户在不同的场景下使用。

      技术分享

          技术分享


      在准备好了字库文件后,就可以加到项目中了,是把ttf文件加入到项目中,这里需要注意的是要把这些ttf加入到bundle中,也就是说,最后的ipa文件中必须包含有这些ttf(否则应用中到哪里去找字库呢?)

      技术分享

      在加入后,我们可以分别在FileExplore和Build Phase里面看到这些内容,如下图所示:

      技术分享

      设置到这里还有最后一步,就是在info.plist文件中加入相应信息,这一步实际上实在项目的Info页里面增加Fonts provided by application项,并设置相应的ttf文件进去,这样就告诉了应用,我要加入新的字体了,对应的字体文件是哪些。

      技术分享

      到这里,字库文件应该是准备好了,下面我们需要确认一下字库的名字,因为代码中需要用名字来指定字体。通常来说,这个名字和文件名是相同的,但也有不同的时候,所以这一步一定不要忽略。

      字库的名字这里是通过NSLog这个打印语句来获得,我们看一下代码:

      

    for (NSString *fontFamilyName in [UIFont familyNames]) {
        NSLog(@"--- %@ ---", fontFamilyName);
        for (NSString *fontName in [UIFont fontNamesForFamilyName:fontFamilyName]) {
            NSLog(@"  %@", fontName);
        }
        
        NSLog(@"   ");
    }

      这段代码我们逐个读入字体族的名字,然后每个族中读取每种字体的名字。从代码中我们可以知道,实际上我们打印了所有的字体,全部列出实在太长了,所以截了一部分列出来,我们的Open Sans也在其中。

      技术分享

      我们看一下,里面有些字体名字和文件名相同,如OpenSans-Bold;有些字体名字和文件名不同,如OpenSansLight-Italic。至此,准备工作终于全部完成了。

      准备工作相当的繁琐,每一步都不能省,但下面正式使用就非常简单了,我做了三个label,分别放入了三种字体,为了向大师致敬,都显示Hello World!的字样。

      代码是这样的:

      

    self.label1.font = [UIFont fontWithName:@"OpenSans-Bold" size:20.0];
    self.label1.text = @"Hello World!";
    self.label2.font = [UIFont fontWithName:@"OpenSans-BoldITalic" size:20.0];
    self.label2.text = @"Hello World!";
    self.label3.font = [UIFont fontWithName:@"OpenSans-Light" size:20.0];
    self.label3.text = @"Hello World!";

      效果是这样的:

      技术分享

      这样,我们就在应用中完美的加入了自定义字库,应用会显得更加的个性化,让人眼前一亮,脱颖而出!


iOS中如何添加自定义的字体

标签:ios   font   

原文地址:http://blog.csdn.net/sakulafly/article/details/46368173

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!