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

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

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

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

解決済

intentでオブジェクトを渡したい

eotw
eotw

総合スコア46

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

1回答

0評価

0クリップ

142閲覧

投稿2022/06/16 04:24

前提

Android kotlinでFirebaseのReal Time Databaseを使用して、簡易的なチャットアプリを作ってます。

実現したいこと

ユーザー間でのメッセージ送信

発生している問題・エラーメッセージ

原因としては、以下のChatLogActivityのuserがnullになっているためです。

ChatLogActivity

val user = intent.getParcelableExtra<User>(NewMessageActivity.USER_KEY) val toId = user?.uid

NewMessageActivityのfetchUsersメソッドにintentを実装し、オブジェクトを渡していますが、これが上手くいってないみたいで、これ以上の原因が分からずです。

NewMessageActivity

intent.putExtra(USER_KEY, holder.msgList.text)

以下はエラーメッセージです。

Log

java.lang.NullPointerException at com.ChatApp.ChatLogActivity.performSendMessage(ChatLogActivity.kt:64) at com.ChatApp.ChatLogActivity.onCreate$lambda-0(ChatLogActivity.kt:44)

該当のソースコード

ChatLogActivity

package com.ChatApp import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.util.Log import android.widget.Button import android.widget.EditText import androidx.appcompat.widget.Toolbar import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.RecyclerView import com.google.firebase.auth.FirebaseAuth import com.google.firebase.database.FirebaseDatabase import java.sql.Timestamp class ChatLogActivity : AppCompatActivity() { private lateinit var recyclerView: RecyclerView override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_chat_log) val toolbar = findViewById<Toolbar>(R.id.toolbar_chat_log) val user = intent.getParcelableExtra<User>(NewMessageActivity.USER_KEY) println("user1: $user") setSupportActionBar(toolbar) getSupportActionBar()?.setTitle(user?.uid) getSupportActionBar()?.setDisplayHomeAsUpEnabled(true) val textList = listOf( "Hello", "Hello", "Hello", "Hello" ) recyclerView = findViewById(R.id.chat_log_list) recyclerView.adapter = ChatFromRecyclerAdapter(textList) recyclerView.adapter = ChatToRecyclerAdapter(textList) recyclerView.layoutManager = LinearLayoutManager(this) findViewById<Button>(R.id.sendButton).setOnClickListener { Log.d("ChatLogActivity", "Send message...") performSendMessage() } } class ChatLog(val id: String, val text: String, val fromId: String, val toId: String, timestamp: Long) private fun performSendMessage() { val text = findViewById<EditText>(R.id.editSendText).text.toString() val fromId = FirebaseAuth.getInstance().uid val user = intent.getParcelableExtra<User>(NewMessageActivity.USER_KEY) val toId = user?.uid println("fromId: $fromId") println("toId: $toId") println("user2: $user") if (fromId == null) return val ref = FirebaseDatabase.getInstance().getReference("/messages").push() val chatMessage = ChatLog(ref.key!!, text, fromId, toId!!, System.currentTimeMillis() / 1000) ref.setValue(chatMessage) .addOnSuccessListener { Log.d("ChatLogActivity", "Saved our chatMessage: ${ref.key}") } } }

NewMessageActivity

package com.ChatApp import android.content.Intent import android.os.Bundle import android.util.Log import android.view.MenuItem import androidx.appcompat.app.AppCompatActivity import androidx.appcompat.widget.Toolbar import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.RecyclerView import com.google.firebase.database.* class NewMessageActivity : AppCompatActivity() { private lateinit var database: DatabaseReference private lateinit var recyclerView: RecyclerView var nameList = mutableListOf<String>( "テスト太郎" ) var adapter = NewMessageRecyclerAdapter(nameList) override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_new_message) val databaseRef: DatabaseReference = FirebaseDatabase.getInstance().reference val toolbar = findViewById<Toolbar>(R.id.toolbar_new_message) setSupportActionBar(toolbar) getSupportActionBar()?.setTitle("友達リスト") getSupportActionBar()?.setDisplayHomeAsUpEnabled(true) fetchUsers() } companion object { const val USER_KEY = "USER_KEY" } private fun fetchUsers(){ val ref = FirebaseDatabase.getInstance().getReference("/users") ref.addListenerForSingleValueEvent(object: ValueEventListener { override fun onDataChange(snapshot: DataSnapshot) { for(i in snapshot.children){ Log.d("NewMessageActivity",i.toString()) val userName = i.child("username").value if (userName != null){ nameList.add(userName as String) } } recyclerView = findViewById(R.id.new_message_list) recyclerView.layoutManager = LinearLayoutManager(this@NewMessageActivity) recyclerView.adapter = adapter adapter.itemClickListener = object: NewMessageRecyclerAdapter.OnItemClickListener { override fun onItemClick(holder: NewMessageViewHolderList) { val intent = Intent(this@NewMessageActivity, ChatLogActivity::class.java) intent.putExtra(USER_KEY, holder.msgList.text) startActivity(intent) } } } override fun onCancelled(p0: DatabaseError) { } }) println("fetchUsers called") } //オプションメニュー用 //override fun onCreateOptionsMenu(menu: Menu?): Boolean {} override fun onOptionsItemSelected(item: MenuItem): Boolean { //戻るボタンの処理 if (item.itemId == android.R.id.home) { finish() } if (item.itemId == R.id.action_new_message) { //toolbarのアイコンがタップされた時の処理 } return super.onOptionsItemSelected(item) } }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

hoshi-takanori

2022/06/16 08:37

Android OS の建前上、各 Activity は独立したメモリ空間で動くように作ることになっているため、Intent (とういか Bundle) の内容はシリアライズされるので、生きたオブジェクトは渡せません。 Intent では id などを渡して、それに基づいてオブジェクトを取得し直す必要があるかと。
jimbe

2022/06/16 17:38 編集

関係無いですが、 > recyclerView = findViewById(R.id.chat_log_list) > recyclerView.adapter = ChatFromRecyclerAdapter(textList) > recyclerView.adapter = ChatToRecyclerAdapter(textList) このようなことをしても RecyclerView が2つ表示される訳ではありません。 指定できるアダプタは1つだけで、この場合は後から指定した To のほうが表示されるでしょう。
eotw

2022/06/17 06:41

hoshi-takanori さん ありがとうございます。 今回の場合だとどのように書けば良いのかイメージがつかず。。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。