前提・実現したいこと
AndroidStudioを使用しています。言語はKotlinです。
問題文、答えの二つをEditTextに入力し、「作成する」Buttonを押すことでそのデータをデータベースに格納するという処理をするためにSQLiteを使用しています。ですが、問題文、答えの両方を記述し、「作成する」Buttonを押すとホーム画面に戻ってしまいます。
「作成する」Buttonを押すと「問題が作成されました」というToastが表示され、データが格納されるようにしたいです。
参考書籍 Androidアプリ開発の教科書 なんちゃって開発者にならないための実践ハンズオン 第10章 データベースアクセス
https://wings.msn.to/index.php/-/A-03/978-4-7981-6044-3/
発生している問題・エラーメッセージ
CreateActivity このActivityにおけるButtonの処理が上手くいきません。
class CreateActivity : AppCompatActivity() { private val _questionId = 0 private val _helper = DatabaseHelper(this@CreateActivity) override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_create) val createcreateBt = findViewById<Button>(R.id.create_create_bt) supportActionBar?.setDisplayHomeAsUpEnabled(true) } override fun onOptionsItemSelected(item: MenuItem): Boolean { if (item.itemId == android.R.id.home) { finish() } return super.onOptionsItemSelected(item) } override fun onDestroy() { _helper.close() super.onDestroy() } fun onSaveButtonClick(view: View) { val createmondaibun = findViewById<EditText>(R.id.create_mondaibun_edit) val createkotae = findViewById<EditText>(R.id.create_kotae_edit) if (TextUtils.isEmpty(createmondaibun.text.toString()) && TextUtils.isEmpty(createkotae.text.toString())) { Toast.makeText(applicationContext, "問題文と答えが空欄です", Toast.LENGTH_LONG).show() } else if (TextUtils.isEmpty(createmondaibun.text.toString())) { Toast.makeText(applicationContext, "問題文が空欄です", Toast.LENGTH_LONG).show() } else if (TextUtils.isEmpty(createkotae.text.toString())) { Toast.makeText(applicationContext, "答えが空欄です", Toast.LENGTH_LONG).show() } else { val mondaibunnote = createmondaibun.text.toString() val kotaenote = createkotae.text.toString() val db = _helper.writableDatabase val sqlInsert = "INSERT INTO mondai (_id, mondaibunnote, kotaenote) VALUES (?,?,?)" val stmt = db.compileStatement(sqlInsert) stmt.bindLong(1, _questionId.toLong()) stmt.bindString(2, mondaibunnote) stmt.bindString(3, kotaenote) stmt.executeInsert() Toast.makeText(applicationContext, "問題を作成しました", Toast.LENGTH_LONG).show() _questionId + 1 createmondaibun.setText("") createkotae.setText("") } } }
DatabaseHelper
class DatabaseHelper (context: Context): SQLiteOpenHelper(context, DATABASE_NAME,null, DATABASE_VERSION) { companion object { private const val DATABASE_NAME = "mondai.db" private const val DATABASE_VERSION = 1 } override fun onCreate(db: SQLiteDatabase) { val sb = StringBuilder() sb.append("CREATE TABLE mondai(") sb.append("_id INTEGER PRIMARY KEY,") sb.append("mondaibunnote TEXT") sb.append("kotaenote TEXT") sb.append(");") val sql = sb.toString() db.execSQL(sql) } override fun onUpgrade(db: SQLiteDatabase, oldVersion: Int, newVersion: Int) {} }
MainActivity 「作成する」Buttonを押すとこの画面に戻ってしまいます。
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val createBt = findViewById<Button>(R.id.create_bt) createBt.setOnClickListener { val intent = Intent(applicationContext, CreateActivity::class.java) startActivity(intent) } } }
activity_create 画面構成です。こちらでの処理に問題は無いと思いますが、念のため。
<?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/scrollView" android:layout_width="match_parent" android:layout_height="match_parent" android:isScrollContainer="false" > <androidx.constraintlayout.widget.ConstraintLayout android:layout_width="match_parent" android:layout_height="wrap_content" tools:context=".MainActivity"> <Button android:id="@+id/create_create_bt" android:layout_width="0dp" android:layout_height="wrap_content" android:text="@string/sakuseisuru" android:onClick="onSaveButtonClick" app:backgroundTint="@android:color/holo_orange_dark" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintHorizontal_bias="0.0" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" /> <TextView android:id="@+id/create_mondaibun_text" android:layout_width="162dp" android:layout_height="30dp" android:text="@string/mondai" android:textSize="25sp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@+id/create_create_bt" /> <EditText android:id="@+id/create_mondaibun_edit" android:layout_width="match_parent" android:layout_height="100dp" android:inputType="textMultiLine" app:layout_constraintTop_toBottomOf="@+id/create_mondaibun_text" tools:ignore="MissingConstraints" tools:layout_editor_absoluteX="0dp" /> <TextView android:id="@+id/create_kotae_text" android:layout_width="162dp" android:layout_height="30dp" android:text="@string/kotae" android:textSize="25sp" app:layout_constraintTop_toBottomOf="@+id/create_mondaibun_edit" tools:ignore="MissingConstraints" tools:layout_editor_absoluteX="0dp" /> <EditText android:id="@+id/create_kotae_edit" android:layout_width="match_parent" android:layout_height="100dp" android:inputType="textMultiLine" app:layout_constraintTop_toBottomOf="@+id/create_kotae_text" tools:layout_editor_absoluteX="162dp" /> </androidx.constraintlayout.widget.ConstraintLayout> </ScrollView>
activity_main ホーム画面の構成です。こちらも問題は無いと思いますが念のため。
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <Button android:id="@+id/study_bt" android:layout_width="236dp" android:layout_height="80dp" android:layout_gravity="center_horizontal" android:text="@string/study" android:textSize="25dp" app:backgroundTint="@android:color/holo_orange_dark" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" tools:ignore="MissingConstraints,OnClick" /> <Button android:id="@+id/create_bt" android:layout_width="236dp" android:layout_height="80dp" android:layout_gravity="center_horizontal" android:layout_marginTop="30dp" android:text="@string/create" android:textSize="25dp" app:backgroundTint="@android:color/holo_orange_dark" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintHorizontal_bias="0.502" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@+id/study_bt" /> </androidx.constraintlayout.widget.ConstraintLayout>
試したこと
・アプリのアンインストール
・_questionIdに関する処理の削除、数値の変更
回答1件
あなたの回答
tips
プレビュー