質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

553閲覧

Swift4でUIButtonのsetImage()がうまくいかない

退会済みユーザー

退会済みユーザー

総合スコア0

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2017/11/15 04:23

編集2017/11/15 04:51

###前提・実現したいこと
URLから画像ファイルを取ってきて、ボタンに設置しようとするところで、行き詰まっています。

###該当のソースコード

Swift

1 2 let cell = tableView.dequeueReusableCell(withIdentifier: "postCell", for: indexPath) as! CustomTableViewCell 3 4 let userProfileImage: UIImage = self.downloadProfileImage(from: hisData["userImage"]! as! String)! 5 cell.userImage.setImage(userProfileImage, for: UIControlState()) 6 7 8 9 // プロフィール画像(Button)を取得 10 func downloadProfileImage(from imgURL: String!) -> UIImage? { 11 let url = URLRequest(url: URL(string: imgURL)!) 12 var imageData = UIImage() 13 let task = URLSession.shared.dataTask(with: url) { 14 (data, response, error) in 15 if let error = error { 16 print(error.localizedDescription) 17 return 18 } 19 20 if let data = data { 21 DispatchQueue.main.async { 22 imageData = UIImage(data: data as Data)! 23 } 24 } 25 26 27 } 28 task.resume() 29 return imageData 30 31 } 32 33 34CustomTableViewCell.swift //identifier → postCell 35 36class CustomTableViewCell: UITableViewCell { 37 38 var delegate: UIViewController? 39 40 @IBOutlet weak var userImage: UIButton! 41 42} 43 44

###補足情報

hisData["userImage"]には画像のURLが入っていることをプリントして確認しました。
エラーなどは特に出ず、画像を入れようとしているボタンもきちんと動いています。
ただ、画像だけが表示されません...

よろしくお願いいたします。

不明点などは、ご指摘いただければ改善いたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

fuzzball

2017/11/15 04:29

処理は if let data = data {} の中に入っていますか?入っているなら print(UIImage(data: data as Data)!) の出力を教えて下さい。
退会済みユーザー

退会済みユーザー

2017/11/15 04:40

UIButtonにsetImageする処理はfunc tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {}の中に入っています。なのでif let data = data {}を記述すると、Use of unresolved identifier 'data'と出ます。downloadProfileImage(){}内のimageData = UIImage(data: data as Data)!の直後にprintすると<UIImage: 0x1c42aac20>, {746, 750}と出力されました。
fuzzball

2017/11/15 04:43 編集

(deleted)
fuzzball

2017/11/15 04:45

セルに乗せているボタンに画像をセットしているのであれば、その部分のコードを書いて下さい。
退会済みユーザー

退会済みユーザー

2017/11/15 04:52

カスタムセルを作成していて、最上部で指定しているcellの中のuserImageというoutletに値を入れようと試みました。
guest

回答1

0

ベストアンサー

セル生成時はリクエストをしているだけで画像データの受信は完了していませんので、downloadProfileImage(from:)の戻り値で画像データは返ってきません。

画像データの受信完了時にセットするようにして下さい。
現在のコードで言うと、

swift

1imageData = UIImage(data: data as Data)!

のところです。

画像データ受信中に、セルが画面外に出てしまったときの処理なども必要になってきます。
けっこう面倒くさいですよ。覚悟して取り組んで下さい。

投稿2017/11/15 05:08

fuzzball

総合スコア16731

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

fuzzball

2017/11/15 05:10

「swift セル 非同期」などで検索すると実例やトラブル例などが見つかると思います。
退会済みユーザー

退会済みユーザー

2017/11/15 06:12

ご丁寧にありがとうございます。調べてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問