Skip to content
This repository has been archived by the owner on Jun 20, 2023. It is now read-only.

6.4 NSURLConnectionを使った演習

ginrou edited this page May 9, 2013 · 7 revisions

ネットワーク通信を行ったサンプルを作ってみましょう

概要

この演習では、適当なAPIから画像のURLを含むjsonを受け取り、その画像をtableviewに表示するサンプルを作ります。

APIはflickrのAPI

youtubeのAPI

が認証なしで使うことができます。

https://raw.github.com/mixi-inc/iOSTraining/master/Doc/Images/6.4/sample.png

設計方針

  • 上記APIから取得できるjsonを一度パースします
  • その中に含まれている画像のurlを抜き出して、urlから画像を取得します。
NSData *data = [NSData dataWithContentsOfURL:<画像のURL>];
UIImage *image = [UIImage imageWithData:data];

とすることで、URLから画像データを取得し、UIImageに変換することができます。

  • プロパティとしてNSMutableArrayを持っておきます。取得した画像はこのArrayに順次代入していきます。
  • [self.tableView reloadData];でテーブルビューを再描画します
  • 各cellの描画する箇所で、画像をセットします
    • cell.imageView.image = <UIImageのインスタンス>とすることでセットできます

注意する点

  • APIを叩く箇所や画像を取得する箇所はsendAsynchronousRequestで非同期で実行してください
  • このメソッドの実行ブロックは別スレッドで動いているので、再描画を促すときはメインスレッドで実行します
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
    [self.tableView reloadData];
}];

ヒント、TIPS

プロジェクトのテンプレートからUITableViewControllerを最初の画面に出来てない時があります。UITableViewControllerをサブクラス化したい場合は、

  1. New File から UITableViewControllerのサブクラスを作ります
  2. appDelegate.mのapplication:didFinishLaunchingWithOptions:内で
self.viewController = [MixiTableViewController new];

とすることで、1.で作ったクラスを利用することができます。

困ったときは、こちらのソースを参考にしてください https://github.com/mixi-inc/iOSTraining/tree/master/SampleProjects/6.4

はじめに

  1. iOSについて

  2. Xcode最初のステッフ

  3. 導入

  4. Objective C の基礎

  5. メモリ管理

  6. 1.3 UIViewController1 UIViewController のカスタマイズ(xib, autoresizing)

  7. 1.3 UIViewController1 UIViewController のカスタマイズ(storyboard)

  8. UIViewController2 - ModalViewController

  9. UIViewController2 - ModalViewController(storyboard)

  10. UIViewController3 - ライフサイクル

  11. HomeWork 1 Objective C の基本文法

  12. HomeWork 2 UIViewControllerとModalViewController

  13. HomeWork 3 UIViewController + Animation

  14. UIKit 1 - container, rotate-

  15. UINavigationController

  16. UITabController

  17. Custom Container View Controller

  18. Supporting Multiple Interface Orientations

  19. HomeWork 1 - タブバーからモーダルビューを表示する

  20. HomeWork 2 - NavigationController

  21. HomeWork 2.3 デバイスことに回転対応

  22. UIKit 2- UIView -

  23. UIView

  24. UIView のカスタマイズ

  25. UIView Animation

  26. HomeWork 1 - UIScrollView

  27. UIKit 3 - table view -

  28. UITableView について

  29. UITableViewとNavigationController

  30. custom UITableViewCell の作成

  31. UITableViewのその他のオプション、カスタマイズ

  32. HomeWork 1 - Dynamic height with a custom uitableviewcell

  33. UIKit 4 - image and text -

  34. UIImagePickerController

  35. Assets Library

  36. UITextFiled, UITextView

  37. KeyboardNotification

  38. Homework 1 - フォトの複数枚選択

  39. ネットワーク処理

  40. NSURLConnection

  41. JSONのシリアライズとデシリアライズ

  42. UIWebView

  43. ローカルキャッシュと通知

  44. NSUserDefaults, Settings Bundle

  45. NSFileManager

  46. Key Value Observing

  47. NSNotification、NSNotificationCenter を用いた通知

  48. UILocalNotification

  49. Blocks, GCD

  50. Blocks

  51. GCD

  52. 【演習】GCD,-Blocksを用いたHTTPリクエストマネージャの作成

  53. 設計とデザインパターン

  54. クラス設計 1

  55. クラス設計 2

  56. [クラス設計演習] (https://github.com/mixi-inc/iOSTraining/wiki/9.3-%E3%82%AF%E3%83%A9%E3%82%B9%E8%A8%AD%E8%A8%88%E6%BC%94%E7%BF%92)

  57. 開発ツール

  58. Instruments, デバッガ

  59. CocoaPods

  60. テスト

  61. iOS開発におけるテスト

  62. GHUnit

  63. Kiwi

  64. KIF

  65. In-App Purchase

  66. In-App Purchase

  67. 付録

  68. Tips of Xcode

  69. Auto Layout 入門

  70. Auto Layout ドリル

Edit sidebar

Clone this wiki locally