HTML5   发布时间:2022-04-27  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了iOS-raywenderlich翻译-AFNetworking速成教程大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

注:本文由BeyondVincent(破船)翻译首发

        转载请注明出处:http://blog.csdn.net/beyondvincent

腾讯微博:beyondvincent

新浪微博:beyondvincent




18 MARCH 2013


iOS-raywenderlich翻译-AFNetworking速成教程

学习如何使用AFNetworking: iOS中使用起来非常方便的网络API!

本文是由 iOS Tutorial 小组成员 Scott Sherwood撰写,他是一个动态加载(Dynamically Loaded)(基于位置)软件公司(专业的混合定位)的共同创办人。 

网络 — 你的程序离开了它就不能生存下去!苹果Foundation framework中的NSURLConnection又非常难以理解,不过这里有一个可以使用的替代品:AFNetworking.

AFNetworking 非常受开发者欢迎 – 它赢得了我们读者的选择:2012年最佳的iOS Library奖(2012 Best iOS Library Award.) 所以现在我就写这篇文章来向你介绍如何在程序中有效的使用它。

AFNetworking 包括了所有你需要与在线资源交互的内容,从web services到文件下载。当你的程序在下载一个文件期间,AFNetworking还能确保你的UI是可以响应的。

本文将介绍AFNetworking框架主要的组成部分。一路上,你将使用World Weather Online提供的咨询(Feeds)来创建一个天气(Weather)程序。刚开始使用的天气数据是静态的,不过在学完本文内容之后,程序将连接到实时的天气咨询。

今日预计:一个很酷的开发者学习所有关于AFNetworking知识,并在他的程序中使用AFNetworking。我们开始忙活吧!

入门

首先来这里(here)下载本文的启动项目。这个工程提供了一个基本的UI — AFNetworking相关代码还没有添加

打开@H_581_26@mainStoryboard.storyboard文件,将看到3个view controller:


iOS-raywenderlich翻译-AFNetworking速成教程


从左到右,分别是:

  • 顶级(top-level)的导航控制器;
  • 用来显示天气的一个table view controller,每天一行;
  • 一个自定义的view controller (WeatherAnimationViewController) 当用户点击某个table view cell时,这个view controller将显示某一天的天气咨询。

生成并运行项目,你将看到相关的UI出现,但是什么都没有实现!因为程序需要从网络中获取到所需要的数据,而相关代码还没有添加。这也是本文中你将要实现的!

首先,你需要将AFNetworking 框架包含到工程中。如果你还没有AFNetworking的话,在这里下载最新的版本:GitHub.

当你解压出下载的文件后,你将看到其中有一个AFNetworking子文件夹,里面全是.h 和 .m 文件,如下高亮显示的:


iOS-raywenderlich翻译-AFNetworking速成教程


AFNetworking拖拽到Xcode工程中.


iOS-raywenderlich翻译-AFNetworking速成教程


当出现了添加文件的选项时,确保勾选上Copy items into desTination group’s folder (if needed) 和 Create groups for any added folders.

要完成相关配置,请在工程的SupporTing Files群组中打开预编译头文件Weather-Prefix.pch. 然后在别的import后面添加如下一行代码

#import "AFNetworking.h"

将AFNetworking添加到预编译头文件,意味着这个框架会被自动添加到工程的所有源代码文件中。

很容易,不是吗?现在你已经准备好“天气”程序代码了!

操作JSON

AFNetworking通过网络来加载和处理结构化的数据是非常智能的,普通的http请求也一样。尤其是它支持JSON,XML 和 Property Lists (plists).

你可以下载一些JSON数据,然后用自己的解析器来解析,但这何必呢?通过AFNetworking就可以完成这些操作!Y

iOS-raywenderlich翻译-AFNetworking速成教程

首先,你需要测试脚本(数据)所需的一个基本URL。将下面的这个静态NSString声明到WTTableViewController.m顶部,也就是所有#import下面:

static NSString *const BaseURLString = @@H_584_262@"http://www.raywenderlich.com/downloads/weather_sample/";

这个URL是一个非常简单的“web service”,在本文中我特意为你创建的。如果你想知道它看起来是什么样,可以来这里下载代码download the source.

这个web service以3种不同的格式(JSON,XML 和 PLIST)返回天气数据。你可以使用下面的这些URL来看看返回的数据:

一个数据格式使用的是JSON. JSON 是一种常见的JavaScript派生类对象格式。看起来如下:

@H_674_287@
{
    "data": {
        "current_condition": [
            {
                "cloudcover": "16","humidity": "59","observation_time": "09:09 PM",}
        ]
    }
}

注意: 如果你想要结更多关于JSON内容,请参Working with JSON in iOS 5 Tutorial.

用户点击程序中的JSON按钮时,你希望对从服务中获得的JSON数据进行加载并处理。在WTTableViewController.m中,找到jsonTapped: 方法 (现在应该是空的) ,并用下面的代码替换:

- (IBACtion)jsonTapped:(id)sender {
    // 1
    *
weatherUrl = [NSString StringWithFormat:"%@weather.PHP?format=json",BaseURLString]; NSURL *url [NSURL URLWithString:weatherUrl]; NSURLRequest *request [NSURLRequest requestWithURL:url];   // 2 AFJSONrequestOperation *operation = [AFJSONrequestOperation JSONrequestOperationWithrequest:request // 3 success:^(*request,NSHTTPURLResponse *response,id JSON) { self.weather (NSDictionary *)JSON; self.title "JSON Retrieved"; [self.tableView reloadData]; } // 4 failure:rgb(0,@L_772_90@ *error,0)">{ UIAlertView *av [[UIAlertView alloc] initWithtitle"Error Retrieving Weather" message"%@",error] delegate:nil cancelButtontitle"OK" otherButtontitlesnil]; [av show}// 5 [operation start]; }

这是你的一个AFNetworking代码!因此,这看起来是全新的,我将对这个方法代码进行介绍。

  1. 根据基本的URL构造出完整的一个URL。然后通过这个完整的URL获得一个NSURL对象,然后根据这个url获得一个NSURLrequest.
  2. AFJSONrequestOperation 是一个功能完整的类(all-in-one)— 整合了从网络中获取数据并对JSON进行解析。
  3. 当请求成功,则运行成功块(success block)。在本示例中,把解析出来的天气数据从JSON变量转换为一个字典(Dictionary),并将其存储在属性 weather 中.
  4. 如果运行出问题了,则运行失败块(failure block),比如网络不可用。如果failure block被调用了,将会通过提示显示错误信息。

如上所示,AFNetworking的使用非常简单。如果要用苹果提供的APIs(如NSURLConnection)来实现同样的功能(下载和解析JSON数据),则需要许多代码才能做到。

现在天气数据已经存在于self.weather中,你需要将其显示出来。找到tableView:numberOfRowsInSection: 方法,并用下面的代码替换:

(NSInteger)tableView(UITableView )tableView numberOfRowsInSection)section
// Return the number of rows in the section.
 
    if(!self.weather)
        return 0;
 
    switch (section{
        case 0{
            1;
        }
        1{
            NSArray *upcomingWeather [self.weather upcomingWeather];
            return [upcomingWeather countdefault:
            0;
    }
}

table view有两个section:第一个用来显示前天气,第二个用来显示未来的天气。

等一分钟,你可能正在思。这里的 [self.weather upcomingWeather]是什么? 如果self.weather是一个普通的NSDictionary,它是怎么知道 “upcomingWeather” 是什么呢?

为了更容易的解析数据,在starter工程中,有一对NSDictionary categories:

  • NSDictionary+weather.m
  • NSDictionary+weather_package.m

这些categories添加了一些方便方法,通过这些方法可以很方便的对字典中的数据元素进行访问。这样你就可以专注于网络部分,而不是NSDictionary中数据的访问。对吧?

回到 WTTableViewController.m,找到 tableView:cellForRowATindexPath: 方法,并用下面的实现替换:

@H_855_607@
(UITableViewCell )tableView cellForRowATindexPath(NSIndexPath )indexPath
{
    *CellIdentifier "WeatherCell";
    UITableViewCell *cell [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];
    *daysWeather;
 
    (indexPath.section{
            daysWeather [self.weather currentConditionbreak;
        ];
            daysWeather [upcomingWeather objectAtIndex:indexPath.rowbreak;
    }
 
    cell.textLabel.text [daysWeather weatherDescription// maybe some code will be added here later...
 
    return cell;
}

跟tableView:numberOfRowsInSection: 方法一样,在这里使用了便利的NSDictionary categories来获得数据。当前天的天气是一个字典,而未来几日的天气则存储在一个数组中。

生成并运行工程,然后点击JSON按钮. 这将会动态的获得一个AFJSONOperation对象,并看到如下画面内容:


iOS-raywenderlich翻译-AFNetworking速成教程


JSON 操作成功!

操作Property Lists(plists)

Property lists (或简称为 plists) 是以确定的格式(苹果定义的)构成的XML文件。苹果一般将plists用在用户设置中。看起来如下:

 
<Dict>
  <key>data</key>
  <Dict>
    <key>current_condition</key>
      <array>
      <Dict>
        <key>cloudcover</key>
        <String>16</String>
        <key>humidity</key>
        <String>59</String>

上面的意思是:

  • 一个字典中有一个名为“data”的key,这个key对应着另外一个字典。
  • 这个字典有一个名为 “current_condition” 的key,这个key对应着一个array.
  • 这个数组包含着一个字典,字典中有多个key和values。比如Cloudcover=16和humidity=59.

现在是时候加载plist版本的天气数据了!找到plistTapped: 方法,并用下面的实现替换:

注意到,上面的代码几乎与JSON版的一致,只不过将操作(operation)的类型从AFJSONOperation 修改为 AFPropertyListOperation. 这非常的整齐:你才程序只需要修改一丁点代码就可以接收JSON或plist格式的数据了!

生成并运行工程,然后点击PLIST按钮。将看到如下内容:


iOS-raywenderlich翻译-AFNetworking速成教程


如果你需要重置所有的内容,以重新开始操作,导航栏顶部的Clear按钮可以清除掉title和table view中的数据。


操作XML

AFNetworking处理JSON和plist的解析使用的是类似的方法,并不需要花费太多功夫,而处理XML则要稍微复杂一点。下面,就根据XML咨询构造一个天气字典(NSDictionary)。

iOS提供了一个帮助类:NSXMLParse (如果你想了解更多内容,请看这里的链接SAX parser).

还是在文件xmlTapped: 方法,并用下面的实现替换:

@H_403_706@
)xmlTapped"%@weather.PHP?format=xml",0)">];
 
    AFXMLrequestOperation [AFXMLrequestOperation XMLParserrequestOperationWithrequest:rgb(0,NSXMLParser *XMLParser{
            //self.xmlWeather = [NSMutableDictionary Dictionary];
            XMLParser.delegate = self;
            [XMLParser setShouldProcessNamespacesYES[XMLParser parse}

到现在为止,这看起来跟之前处理JSON和plist很类似。最大的改动就是在成功块(success block)中,在这里不会传递给你一个预处理好的NSDictionary对象. 而是AFXMLrequestOperation实例化的NSXMLParse对象,这个对象将用来处理繁重的XML解析任务。

NSXMLParse对象有一组delegate方法是你需要实现的 — 用来获得XML数据。注意,在上面的代码中我将XMLParser的delegate设置为self,因此WTTableViewController将用来处理XML的解析任务。

首先,更新一下WTTableViewController.h 并修改一下类声明,如下所示:

@interface WTTableViewController : UITableViewController<NSXMLParserDelegate>

上面代码的意思是这个类将实现(遵循)NSXMLParserDelegate协议. 下一步将下面的delegate方法声明添加到@implementation后面:

为了支持咨询的解析,还需要一些属性来存储相关的数据。将下面的代码添加到@implementatio后面:

@property(strong) NSMutableDictionary *xmlWeather; //package containing the complete response
*currentDictionary; //current section being parsed
) *previousElementName;
*elementName;
) NSMutableString *outString;

接着打开WTTableViewController.m,现在你需要一个一个的实现上面所说的几个delegate方法。将下面这个方法粘贴到实现文件中:

)attributeDict  {
    self.prevIoUSELER_528_11845@entName = self.elementName;
 
    if (qName{
        self.elementName = qName;
    }
 
    [qName isEqualToString"current_condition"]){
        self.currentDictionary [NSMutableDictionary Dictionary}
    else "weather""request"}
 
    self.outString [NSMutableString String}

当NSXMLParser发现了新的元素开始标签时,会调用上面这个方法在这方法中,在构造一个新字典用来存储赋值给currentDictionary属性之前,首先保存住上一个元素名称。还要将outString重置一下,这个字符串用来构造XML标签中的数据。

然后将下面这个方法粘贴到上一个方法的后面:

String !self.elementNamereturn;
    }
 
    [self.outString appendFormat}

如名字一样,当NSXMLParser一个XML标签发现了字符数据,会调用这个方法。该方法将字符数据追加到outString属性中,当XML标签结束的时候,这个outString会被处理。

继续,将下面这个方法粘贴到上一个方法的后面:

)qName {
 
    // 1
    ] ||
       {
        [self.xmlWeather setObject[NSArray arrayWithObject:self.currentDictionary] forKey:qName];
        self.currentDictionary = nil;
    }
    // 2
    {
 
        // Initalise the list of weather items if it dosnt exist
        NSMutableArray *array [self.xmlWeather objectForKey];
        !array)
            array [NSMutableArray array];
 
        [array addObject:array forKey];
 
        self.currentDictionary // 3
    "value"{
        //Ignore value tags they only appear in the two conditions below
    // 4
    "weatherDesc"] ||
            "weatherIconUrl"[self.currentDictionary setObject[NSDictionary DictionaryWithObject:self.outString forKey// 5
    else }
 
	self.elementName nil;
}

当检测到元素的结束标签时,会调用上面这个方法在这方法中,会查找一些标签

  1. urrent_condition 元素表示获得了一个今天的天气。会把今天的天气直接添加到xmlWeather字典中。
  2. weather 元素表示获得了随后一天的天气。今天的天气只有一个,而后续的天气有多个,所以在此,将后续天气添加一个数组中。
  3. value 标签出现在别的标签中,所以这里可以忽略掉这个标签
  4. weatherDesc 和 weatherIconUrl 元素的值在存储之前,需要需要被放入一个数组中 — 这里的结构是为了与JSON和plist版本天气咨询格式相匹配。
  5. 所有其它元素都是按照原样(as-is)进行存储的。

下面是最有一个delegate方法

)parser {
    self.weather :self.xmlWeather forKey"data"];
    self.title "XML Retrieved";
    }

NSXMLParser解析到document的尾部时,会调用这个方法。在此,xmlWeather字典已经构造完毕,table view可以重新加载了。

在上面代码中将xmlWeather添加一个字典中,看起来是冗余的,不过这样可以确保与JSON和plist版本的格式完全匹配。这样所有的3种数据格式(JSON,plist和XML)都能够用相同的代码显示

iOS-raywenderlich翻译-AFNetworking速成教程

现在所有的delegate方法属性都搞定了,找到xmlTapped: 方法,并取消注释成功块(success block)中的一行代码

{
    ...
    success// the line below used to be commented out
        self.xmlWeather ];
        XMLParser.delegate = self;
    ...
}

生成和运行工程,然后点击XML按钮,将看到如下内容


iOS-raywenderlich翻译-AFNetworking速成教程



未完待续 破船 2013-03-19 :]



一个小的天气程序

嗯,上面的这个程序看起来体验不太友好,有点像整周都是阴雨天。如何让table view中的天气信息体验更好点呢?

再仔细看看之前的JSON格式数据:JSON format from before,你会看到每个天气项里面都有一个图片URLs。 将这些天气图片显示到每个table view cell中,这样程序看起来会更有意思。

AFNetworking给UIImageView添加一个category,让图片能够异步加载,也就是说当图片后台下载的时候,程序的UI界面仍然能够响应。为了使@R_197_11392@功能,首先需要将这个category import到WTTableViewController.m文件的顶部:

#import "UIImageView+AFNetworking.h"

找到tableView:cellForRowATindexPath: 方法,并将下面的代码粘贴到最后的return cell; 代码上上面(这里应该有一个注释标记

 
__weak UITableViewCell *weakCell = cell;
 
[cell.imageView setImageWithURLrequestNSURLrequest alloc] initWithURL:daysWeather.weatherIconURL]
                      placeholderImage[UIImage imagenamed"placeholder.png"]
                               success:rgb(0,UIImage *image{
                                   weakCell.imageView.image = image;
 
                                   //only required if no placeholder is set to force the imageview on the cell to be laid out to house the new image.
                                   //if(weakCell.imageView.frame.size.height==0 || weakCell.imageView.frame.size.width==0 ){
                                   [weakCell setNeedsLayout];
                                   //}
                               }
                               failure*error{
 
                               ];

首先创建一个弱引用(weak)的cell,这样就可以在block中使@R_197_11392@cell。如果你直接访问cell变量,Xcode会提示一个关于retain循环和内存泄露的警告。

UIImageView+AFNetworking category定义了一个setImageWithURLrequest… 方法. 这个方法的参数包括一个指向图片URL的请求,一个占位符图片一个success block和一个failure block。

当cell首次被创建的时候,cell中的UIImageView将显示一个占位符图片,直到真正的图片被下载完成。在这里你需要确保占位符的图片与实际图片尺寸大小相同。

如果尺寸不相同的话,你可以在success block中调用cell的setNeedsLayout方法. 上面代码中对两行代码进行了注释,这是因为这里的占位符图片尺寸正好合适,留着注释,可能在别的程序中需要用到。

现在生成并运行工程,然后点击之前添加的3个操作中的任意一个,将看到如下内容


iOS-raywenderlich翻译-AFNetworking速成教程


很好! 异步加载图片从来没有这么简单过。

一个RESTful类

到现在你已经使用类似AFJSONrequestOperation这样的类创建了一次性的http请求。另外,较低级的AFhttpClient类是用来访问单个的web service终端。 对这个AFhttpClient一般是给它设置一个基本的URL,然后用AFhttpClient进行多个请求(而不是像之前的那样,每次请求的时候,都创建一个AFhttpClient

AFhttpClient同样为编码参数、处理multipart表单请求body的构造、管理请求操作和批次入队列操作提供了很强的灵活性,它还处理了整套RESTful (GET,POST,PUT,和 Delete),下面我们就来试试最常用的两个:GET 和 POST.

注意: 对REST,GET和POST不清楚?看看这里比较有趣的介绍 – 我如何给妻子解释REST(How I Explained REST to My Wife.)

WTTableViewController.h 顶部将类声明按照如下修改

: UITableViewController<NSXMLParserDelegate,CLLOCATIOnManagerDelegate,UIActionSheetDelegate>

在 httpClientTapped: 方法,并用下面的实现替换:

)httpClientTapped{
    UIActionSheet *actionSheet [UIActionSheet alloc"AFhttpClient" delegate:self cancelButtontitle"Cancel" destructiveButtontitlenil otherButtontitles"http POST","http GET",0)">[
actionSheet showFromBarButtonItem:sender animated}

上面的方法会弹出一个action sheet,用以选择GET和POST请求。粘贴如下代码以实现action sheet中按钮对应的操作:

上面的代码作用如下:

  1. 构建一个baseURL,以及一个参数字典,并将这两个变量传给AFhttpClient.
  2. 将AFJSONrequestOperation注册为http的操作,这样就可以跟之前的示例一样,可以获得解析好的JSON数据。
  3. 做了一个GET请求,这个请求有一对block:success和failure。
  4. POST请求跟GET一样。

在这里,将请求一个JSON回应,当然也可以使用之前讨论过的另外两种格式来代替JSON。

生成并运行工程,点击httpClient按钮,然后选择GET 或 POST按钮来初始化一个相关的请求。之后会看到如下内容:


iOS-raywenderlich翻译-AFNetworking速成教程


至此,你已经知道AFhttpClient最基本的使用方法。不过,这里还有更好的一种使用方法,它可以让代码更加干净整齐,下面我们就来学习一下吧。

连接到Live service

到现在为止,你已经在table view controller中直接调用了AFrequestOperations 和 AFhttpClient. 实际上,大多数时候不是这样的你的网络请求会跟某个web service或API相关。

AFhttpClient已经具备与web API通讯的所有内容AFhttpClient在代码中已经把网络通讯部分做了解耦处理,让网络通讯的代码在整个工程中都可以重用。

下面是两个关于AFhttpClient最佳实践的指导:

  1. 为每个web service创建一个子类。例如,如果你在写一个社交网络聚合器,那么可能就会有Twitter的一个子类,Facebook的一个子类,instragram的一个子类等等。
  2. AFhttpClient子类中,创建一个方法,用来返回一个共享的单例,这将会节约资源并省去必要的对象创建

当前,你的工程中还没有一个AFhttpClient的子类,下面就来创建一个吧。我们来处理一下,让代码清洁起来。

首先,在工程中创建一个新的文件:iOS\Cocoa Touch\Objective-C Class. 命名为WeatherhttpClient 并让其继承自AFhttpClient.

你希望这个类做3件事情:

A:执行http请求 

B:当有新的可用天气数据时,调用delegate

C:使用用户当前地理位置来获得准确的天气。

用下面的代码替换WeatherhttpClient.h:

#import "AFhttpClient.h"
 
@protocol WeatherhttpClientDelegate;
 
@interface WeatherhttpClient : AFhttpClient
 
(weak) id<WeatherhttpClientDelegate> delegate;
 
+ (WeatherhttpClient )sharedWeatherhttpClient;
)initWithBaseURL()url;
)updateWeatherAtLocation(CLLocation )location forNumberOfDaysint)number;
 
@end
 
@protocol WeatherHttpClientDelegate <NSObject>
)weatherHTTPClient)client didUpdateWithWeather)weather;
)client didFailWithError()error;
@end

在实现文件中,你将了解头文件中定义的更多相关内容。打开WeatherhttpClient.m 并将下面的代码添加到@implementation下面:

)sharedWeatherhttpClient
*urlStr "http://free.worldweatheronline.com/feed/";
 
    static dispatch_once_t pred;
    static WeatherhttpClient *_sharedWeatherhttpClient nil;
 
    dispatch_once&pred,^{ _sharedWeatherhttpClient [self alloc:urlStr]; );
    return _sharedWeatherhttpClient;
}
 
)url
{
    self [super initWithBaseURL];
    !selfreturn [self registerhttpOperationClass[self setDefaultHeader];
 
    return self;
}

sharedWeatherhttpClient 方法使用Grand Central Dispatch(GCD)来确保这个共享的单例对象只被初始化分配一次。这里用一个base URL来初始化对象,并将其设置为期望web service响应为JSON。

将下面的方法粘贴到上一个方法的下面:

这个方法调用World Weather Online接口,以获得具体位置的天气信息。

非常重要!本实例中的API key仅仅是为本文创建的。如果你创建了一个程序,请在World Weather Online创建一个账号,并获得你自己的API key!

一旦对象获得了天气数据,它需要一些方法通知对此感兴趣的对象:数据回来了。这里要感谢WeatherhttpClientDelegate 协议和它的delegate方法,在上面代码中的success 和 failure blocks可以通知一个controller:指定位置的天气已经更新了。这样,controller就可以对天气做更新显示

现在,我们需要把这些代码片段整合到一起!WeatherhttpClient希望接收一个位置信息,并且WeatherhttpClient定义了一个delegate协议,现在对WTTableViewControlle类做一下更新,以使用WeatherhttpClient.

打开WTTableViewController.h 添加一个import,并用下面的代码替换@interface声明:

#import "WeatherhttpClient.h"
 
: UITableViewController <NSXMLParserDelegate,UIActionSheetDelegate,WeatherhttpClientDelegate>

另外添加一个新的Core LOCATIOn manager 属性:

) CLLOCATIOnManager *@H_240_9@manager;

在 WTTableViewController.m中,将下面的代码添加viewDidLoad:底部

    self.manager [CLLOCATIOnManager alloc] init];
    self.manager.delegate = self;

上面这两行代码初始化了Core LOCATIOn manager,这样当view加载的时候,用来确定用户的当前位置。Core LOCATIOn然后会通过delegate回调以传回位置信息。将下面的方法添加到实现文件中:

)LOCATIOnManager(CLLOCATIOnManager )@H_240_9@manager didupdateToLOCATIOn)newLOCATIOn fromLOCATIOn)oldLOCATIOn//if the LOCATIOn is more than 5 minutes old ignore
    [newLOCATIOn.timestamp timeIntervalSinceNow]< 300[self.manager stopupdatingLOCATIOn];
 
        WeatherhttpClient [WeatherhttpClient sharedWeatherhttpClient];
        client.delegate = self;
        [client updateWeatherAtLOCATIOn:newLOCATIOn fornumberOfDays:5];  
    }

现在,当用户的位置有了变化时,你就可以使用WeatherhttpClient单例来请求当前位置的天气信息。

记住,WeatherhttpClient有两个delegate方法需要实现。将下面两个方法添加到实现文件中:

)aWeather= aWeather;
    self.title "API updated";
    )error{
    UIAlertView "Error Retrieving Weather"
                                                 message]
                                                delegatenil
                                       cancelButtontitle}

上面的两个方法,当WeatherhttpClient请求成功,你就可以更新天气数据并重新加载table view。如果网络错误,则显示一个错误信息。

找到apiTapped: 方法,并用下面的方法替换:

)apiTapped{
    [self.manager startupdatingLOCATIOn}

生成并运行程序,点击AP按钮以初始化一个WeatherhttpClient 请求,然后会看到如下画面:


iOS-raywenderlich翻译-AFNetworking速成教程


希望在这里你未来的天气跟我的一样:晴天!

我还没有死!

你可能注意到了,这里调用的外部web service需要花费一些时间才能返回数据。当在进行网络操作时,给用户提供一个信息反馈是非常重要的,这样用户才知道程序是在运行中或已奔溃了。

iOS-raywenderlich翻译-AFNetworking速成教程

很幸运的是,AFNetworking有一个便方法来提供信息反馈:AFNetworkActivityInDicatoRMANager.

在 WTAppDelegate.m中,找到application:didFinishLaunchingWithOptions: 方法,并用下面的方法替换:

BOOL)application(UIApplication )application didFinishLaunchingWithOptions)launchOptions
[AFNetworkActivityInDicatoRMANager sharedManager].enabled YES;
    YES;
}

让sharedManager可以自动显示出网络活动指示器( network activity inDicator)— 无论射门时候,只要有一个新的网络请求在后台运行着。 这样你就不需要每次请求的时候,都要单独进行管理。

生成并运行工程,无论什么时候,只要有网络请求,都可以在状态栏中看到一个小的网络风火轮:


iOS-raywenderlich翻译-AFNetworking速成教程


现在,即使你的程序在等待一个很慢的web service,用户都知道程序还在运行着。

下载图片

如果你在table view cell上点击,程序会切换到天气的详细画面,并且以动画的方式显示相应的天气情况。

这非常不错,但目前动画只有一个背景图片。除了通过网络来更新背景图片,还有更好的方法吗!

下面是本文关于介绍AFNetworking的最后内容了:AFImagerequestOperation. 跟AFJSONrequestOperation一样,AFImagerequestOperation封装了http请求:获取图片

WeatherAnimationViewController.m 中有两个方法需要实现. 找到updateBACkgroundImage: 方法,并用下面的代码替换:

这个方法初始化并下载一个新的背景图片。在结束时,它将返回请求到的完整图片。

在WeatherAnimationViewController.m中,你将看到两个辅助方法:imageWithFilename: 和 saveImage:withFilename:,通过这两个辅助方法,可以对下载下来的图片进行存储和加载。updateBACkgroundImage: 将通过辅助方法把下载的图片存储到磁盘中。

接下来找到deleteBACkgroundImage: 方法,并用下面的代码替换:

这个方法将删除已经下载的图片,这样在测试程序的时候,你可以再次下载图片。

最后一次:生成并运行工程,下载天气数据,并点击某个cell,以打开详细天气画面。在详细天气画面中,点击update BACkground 按钮. 如果你点击的是晴天cell,将会看到如下画面:


iOS-raywenderlich翻译-AFNetworking速成教程


何去何从?

你可以在这里下载到完整的工程:here.

你所想到的所有方法,都可以通过使AFNetworking来与外界通讯:

AFNetworking的威力可以帮助你进行网络开发!

如果你有任何相关问题,请访问我们的网站以获得帮助。我也很乐意看到你的回复

@H_419_1812@

本文是由 iOS Tutorial 小组成员 Scott Sherwood撰写,他是一个动态加载(Dynamically Loaded)(基于位置)软件公司(专业的混合定位)的共同创办人。


@H_262_2031@ iPhoneCategory:

Tags: iOSios6iPhonenetworkedsample codetutorial

发表评论(Leave a Comment)

很想听听你的想法(I'd love to hear your thoughts)!

@H_87_2058@本文翻译完毕!2013-03-20 破船 :]
本图文内容来源于网友网络收集整理提供,作为学习参使用,版权属于原作者。

猜你在找的iOS相关文章

目前,苹果开发者账号可分为三种类型:个人、公司、企业,且三者的费用以及权限等不尽相同。 1.个人账号 费用:99 美元/年 协作人数:仅限开发者自己 不需要填写公司的邓百氏编码( D-U-N-S Nu
Symbol Value meaning NULL (void *)0 literal null value for C pointers nil (id)0 literal null value for Objective-C objects nil:对象为空定义某一实例对象为空值。例如:NSObject* obj = nil;if (...
Android篇环境要求1 安装winrar,然后配置winrar的环境变量,要用到winrar指令2 配置java的bin目录到环境变量,要用到jarsigner指令重签名步骤说明:1 从母包复制一个子包2 删除子包的签名文件META-INFO3 根据需要修改子包的文件,比如渠道号文件之类4 重签名子包对应的python脚本import os...
转载注明出处:https://blog.csdn.net/joosonmao/article/details/21172835刚接触iOS开发的人难免会对苹果的各种证书、配置文件等不甚了解,可能你按照网上的教程一步一步的成功申请了真机调试,但是还是对其中的缘由一知半解。这篇文章就对Certificate、Provisioning Profile等做个总结。 1.概念介绍如果你拥有一个开...
转载注明出处:https://www.jianshu.com/p/567d3b730608iOS armv7, armv7s, arm64区别与应用32位、64位配置历程2015年2月1日不允许不支持arm64的应用的提交; iOS10发布后,如果你的应用中使用到了32位的类、库,没有相应支持64位机型的库,则首次启动后会弹窗式提示:“ xxx可能使iPhone变慢...”; iO...
iOS9以下的自己越狱后,通过PP助手备份到电脑或者直接通过pp助手直接下载 
转载注明出处:https://www.cnblogs.com/mtystar/p/6082363.html0x01 静态库与动态库的区别1.静态库和动态库的存在形式上的区别静态库 .a .framework 动态库 .dylib (在Xcode 8里面,看到后缀为.tbd的库,它的本质都是.dylib文件) .framework 2.静态库和动态库在使用上的区别...
终端中运行xcodebuild -showsdks

大佬总结

以上是大佬教程为你收集整理的iOS-raywenderlich翻译-AFNetworking速成教程全部内容,希望文章能够帮你解决iOS-raywenderlich翻译-AFNetworking速成教程所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。