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

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

ただいまの
回答率

90.51%

  • Kotlin

    333questions

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

  • Realm

    197questions

    RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。

アプリ終了:Logcat → FATAL EXCEPTION: main、java.lang.RuntimeException

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 136

akawo

score 13

androidstudio、kotlinでスケジュールアプリを作っているところです。
listviewの要素をタップするとアプリが終了してしまいます。その際のLogcatが下記のとおりです。

06-26 21:31:42.525 10969-10969/com.example.user1.myapplication5 E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.user1.myapplication5, PID: 10969
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.user1.myapplication5/com.example.user1.myapplication5.EditActivity}: android.content.res.Resources$NotFoundException: String resource ID #0x3

EditActivity.kt

package com.example.user1.myapplication5

import android.annotation.SuppressLint
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import io.realm.Realm
import io.realm.kotlin.createObject
import io.realm.kotlin.where
import kotlinx.android.synthetic.main.activity_edit.*
import org.jetbrains.anko.alert
import org.jetbrains.anko.startActivity
import org.jetbrains.anko.yesButton
import java.text.ParseException
import java.text.SimpleDateFormat
import java.util.*

class EditActivity : AppCompatActivity() {
    private lateinit var realm: Realm

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_edit)
        realm = Realm.getDefaultInstance()

        RETURN.setOnClickListener { view ->
            startActivity<MainActivity>()
        }

        val resultId = intent?.getLongExtra("result_id", -1L)

        if (resultId != -1L){
            val result = realm.where<Result>().equalTo("id",resultId).findFirst()
            DateEdit.setText(android.text.format.DateFormat.format("yyyy/MM/dd",result?.title))
            MyResultEdit.setText(result?.MyResult)
            YourResultEdit.setText(result?.YourResult)
            MyNameEdit.setText(result?.MyName)
            YourNameEdit.setText(result?.YourName)
            MySetEdit.setText(result?.MySet.toString().toInt())
            YourSetEdit.setText(result?.YourSet.toString().toInt())
        }



        save.setOnClickListener {
            when(resultId) {
                -1L -> {


                    realm.executeTransaction {
                        val maxId = realm.where<Result>().max("id")
                        val nextId = (maxId?.toLong() ?: 0L) + 1
                        val result = realm.createObject<Result>(nextId)
                        DateEdit.text.toString().toDate("yyyy/MM/dd")?.let {
                            result.title = it
                        }

                        result.MyResult = MyResultEdit.text.toString()
                        result.YourResult = YourResultEdit.text.toString()
                        result.MyName = MyNameEdit.text.toString()
                        result.YourName = YourNameEdit.text.toString()
                        result.MySet = MySetEdit.text.toString().toInt()
                        result.YourSet = YourSetEdit.text.toString().toInt()

                    }

                    alert("追加しました") {
                        yesButton { finish() }
                    }.show()

                }

                else -> {
                    realm.executeTransaction{
                        val result = realm.where<Result>().equalTo("id", resultId).findFirst()
                        DateEdit.text.toString().toDate("yyyy/MM/dd")?.let {
                            result?.title = it
                        }
                        result?.MyResult = MyResultEdit.text.toString()
                        result?.YourResult = YourResultEdit.text.toString()
                        result?.MyName = MyNameEdit.text.toString()
                        result?.YourName = YourNameEdit.text.toString()
                        result?.MySet = MySetEdit.text.toString().toInt()
                        result?.YourSet = YourSetEdit.text.toString().toInt()


                    }
                    alert ("追加しました"){
                        yesButton { finish() }
                    }.show()
                }
            }
        }
    }

    override fun onDestroy() {
        super.onDestroy()
        realm.close()
    }

    @SuppressLint("SimpleDateFormat")
    private fun String.toDate(pattern: String = "yyyy/MM/dd HH:mm") : Date?{
        val rtFormat = try {
            SimpleDateFormat(pattern)
        } catch (e: IllegalArgumentException){
            null
        }

        val date = rtFormat?.let {
            try {
                it.parse(this)

        } catch (e: ParseException){
                null
            }

        }
        return date

    }


}

どうすればうまくいくでしょうか?
なにとぞ、なにとぞ、、、よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

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

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

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

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

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

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kakajika

    2018/06/26 22:03

    Resultというクラスのコードを貼っていただくことはできますか?

    キャンセル

回答 1

check解決した方法

0

TextView.setText() にintの値を渡していたから問題発生していたことがわかりました!

MySetEdit.setText(result?.MySet.toString().toInt())

MySetEdit.setText(result?.MySet.toString())

int型、float型の値をstringにするには、3つ方法があるらしいです。
https://www.javadrive.jp/start/wrapper_class/index4.html

お騒がせいたしました!ありがとうございました!

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.51%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    インスタンス化しないようにする[kotlin]

    前提・実現したいこと javaのようにユーティリティクラスを書くには? 結論 object(Singleton)であれcompanion objectであれ参照が渡される

  • 受付中

    Realm for Javaの一対多の取得クエリについて

    前提・実現したいこと AndroidでRealmを利用したデータベース設計を考えています。 以下のような設計をしています。 open class CompanyData(

  • 受付中

    kotlinでparcelable

    ArrayList<Any>にparcelableを実装する方法が分かりません。 作成したリストの中にはString型と独自に作成したクラス(UploadedItem)が入っていま

  • 受付中

    kotlinの待機処理について

    KotlinでAndroidアプリを作っているのですが、待機処理について教えていただきたいです。 一定時間処理を停止しTextViewを更新を3回ほど繰り返した後、画面遷移したいの

  • 解決済

    スレッドセーフで高速なLRUキャッシュ

    いつもありがとうございます。 Kotlin、もしくはJavaで以下の要件を満たすプログラムを考えています。  ■要件 1.与えられたキーに対して処理を行い結果を返す。 2.一度

  • 解決済

    RxPropertyでイベントの発生順を制御したい

    前提・実現したいこと RxProperty for Android の初心者です。KotlinでAndroidアプリを開発しています。 AndroidのDatePickerとT

  • 解決済

    Android/KotlinでRealmObjectのコンパイルが通らない

    Android/KotlinでRealmのRealmObjectを作ろうとしたところ、以下のコンパイルエラーが出てコンパイルできませんでした。どのようにすればコンパイルできるように

  • 解決済

    RuntimeException: Unable to resume activity、 Failu...

    【目標】 ncmb(nifty cloud mobile backend)とkotlinでログイン機能の実装 【経緯】 githubにあるjavaファイルをkotlinに変更し

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

  • Kotlin

    333questions

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

  • Realm

    197questions

    RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。