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

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

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

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

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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

Q&A

解決済

1回答

1824閲覧

xcode上でビルドができない

HayateTabata

総合スコア12

Firebase

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

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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

0グッド

0クリップ

投稿2017/02/13 01:58

###前提・実現したいこと
・Firebaseを活用したリアルタイムチャット機能の実装
・Storyboardは使用せず、コードでの実装になります。
・JSQMessageViewControllerを使用しています。

###発生している問題・エラーメッセージ
コードを書き終え、ビルドしてエミュレーターを起動しようとしたところ、
次のようなエラーが発生しました。

libc++abi.dylib: terminating with uncaught exception of type NSException

おそらくJSQMessageViewで作成したパーツがうまくViewControllerに接続されていないことが原因かと思われるのですが、
コードでの実装を基本的にしたことがなく、どこが原因となっているのかが不明です。

ソースコードは1つのswiftファイルで完結されているため、こちらを確認していただければと思います。

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

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

swift

1// 2// ViewController.swift 3// RealTimeChat 4// 5// Created by 田畑颯 on 2017/02/12. 6// Copyright © 2017年 田畑颯. All rights reserved. 7// 8 9import UIKit 10import JSQMessagesViewController 11import Firebase 12 13class ViewController: JSQMessagesViewController { 14 15 var messages:[JSQMessage]! 16 var incomingBubble:JSQMessagesBubbleImage! 17 var outgoingBubble:JSQMessagesBubbleImage! 18 var incomingAvatar:JSQMessagesAvatarImage! 19 var outgoingAvatar:JSQMessagesAvatarImage! 20 21 22 override func viewDidLoad() { 23 super.viewDidLoad() 24 25 inputToolbar!.contentView!.leftBarButtonItem = nil 26 automaticallyScrollsToMostRecentMessage = true 27 28 //自分のsenderId,senderDisplayNameを設定 29 self.senderId = "user1" 30 self.senderDisplayName = "tbtit" 31 32 //吹き出しの設定 33 let bubbleFactory = JSQMessagesBubbleImageFactory() 34 self.incomingBubble = bubbleFactory?.incomingMessagesBubbleImage(with: UIColor.jsq_messageBubbleLightGray()) 35 self.outgoingBubble = bubbleFactory?.outgoingMessagesBubbleImage(with: UIColor.jsq_messageBubbleBlue()) 36 37 //アバターの設定 38 self.incomingAvatar = JSQMessagesAvatarImageFactory.avatarImage(with: UIImage(named:"Swift-Logo"), diameter: 64) 39 self.outgoingAvatar = JSQMessagesAvatarImageFactory.avatarImage(with: UIImage(named:"Swift-Logo"), diameter: 64) 40 41 //メッセージデータの配列を初期化 42 self.messages = [] 43 //TODO writing following code 44 setupFirebase() 45 46 } 47 48 /* 49 * firebaseのセットアップを行う。 50 * setupFirebase() 51 */ 52 func setupFirebase() { 53 //Firebaseのセットアップ 54 let ref = FIRDatabase.database().reference() 55 56 //最新25件のデータを取得 57 ref.queryLimited(toLast: 25).observe(FIRDataEventType.childAdded, with: {(snapshot) in 58 if let value = snapshot.value as? [String: AnyObject] { 59 60 let text = value["text"] as! String 61 let sender = value["from"] as! String 62 let name = value["name"] as! String 63 64 let message = JSQMessage(senderId: sender, displayName: name, text: text) 65 self.messages?.append(message!) 66 self.finishSendingMessage() 67 68 } 69 }) 70 } 71 72 73 74 /* 75 * sendボタンが押された瞬間に呼び出されるメソッド 76 */ 77 override func didPressSend(_ button: UIButton!, withMessageText text: String!, senderId: String!, senderDisplayName: String!, date: Date!) { 78 79 //メッセージの送信を完了する。 80 self.finishReceivingMessage(animated: true) 81 82 //Firebaseに保存 83 let post1 = ["from": senderId, "name": senderDisplayName, "text": text] 84 let ref = FIRDatabase.database().reference() 85 let post1Ref = ref.childByAutoId() 86 post1Ref.setValue(post1) 87 } 88 89 90 91 override func didReceiveMemoryWarning() { 92 super.didReceiveMemoryWarning() 93 // Dispose of any resources that can be recreated. 94 } 95 96 /* 97 * ここから先は、JSQMessageの型を持っている変数に対して、 98 * 様々なアクションを行う。基本的に関数単位で処理を行います。 99 */ 100 101 //メッセージの実装 102 override func collectionView(_ collectionView: JSQMessagesCollectionView!, messageDataForItemAt indexPath: IndexPath!) -> JSQMessageData! { 103 return self.messages?[indexPath.item] 104 } 105 106 //messageBubble(背景)の実装 107 108 override func collectionView(_ collectionView: JSQMessagesCollectionView!, messageBubbleImageDataForItemAt indexPath: IndexPath!) -> JSQMessageBubbleImageDataSource! { 109 let message = self.messages?[indexPath.item] 110 if message?.senderId == self.senderId { 111 return self.outgoingBubble 112 } 113 return self.incomingBubble 114 } 115 116 //アイテムごとにアバターイメージを返す 117 override func collectionView(_ collectionView: JSQMessagesCollectionView!, avatarImageDataForItemAt indexPath: IndexPath!) -> JSQMessageAvatarImageDataSource! { 118 let message = self.messages?[indexPath.item] 119 if message?.senderId == self.senderId { 120 return self.outgoingAvatar 121 } 122 return self.incomingAvatar 123 } 124 125 //アイテムの総数を返す。 126 override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { 127 return (self.messages?.count)! 128 } 129}

###補足情報(言語/FW/ツール等のバージョンなど)
・swift3
・Firebase
・JSQMessageViewController

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

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

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

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

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

guest

回答1

0

ベストアンサー

「コードでの実装を基本的にしたことがない」というのは、Swiftでのアプリ開発が初めてということでしょうか??

「libc++abi.dylib: terminating with uncaught exception of type NSException」は、
『エラーが出てアプリが終了しました』という位の意味なので、何が起きているのか全く分かりません〜。

エラーのもう少し上の方の
「*** First throw call stack:」
の上あたりにもう少し詳しい内容が出ているので、そちらを読んでみてください。
たぶん「〇〇が定義されていないです」という風にエラー詳細内容が出てると思います。

投稿2017/02/13 14:14

kanemotos

総合スコア163

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

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

HayateTabata

2017/02/13 15:28

ありがとうございます! エラーの確認する部分が誤っていました。 エラー箇所を確認したところ、 invalid parameter not satisfying : image != nil と画像がそもそも入っていないのが問題だったため、 こちらを修正したところ、無事動かせました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問