以前紹介した、
【はじめてのKotlinプログラミング(3)】20分で作る計算アプリ
【はじめてのKotlinプログラミング(4)】続・計算アプリ
ですが、微妙に直したいコードがあるので(ktの方)、一応書き直したのを下記。
【ポイントは】
1)var⇒valにした
基本に忠実に「val」で宣言に修正
2)kt-41行目 "合計は" + sum ⇒"合計は $sum"
変数と文字をくっつけたりする場合は、変数に$(ダラーマーク)を付ける方が推奨されているので、そっちに変更
3)kt-27行目 空文字判定の .equals("") をやめて ==("")
文字でも数字でも、等しい場合は「==」でOK(むしろこっちを推奨)なので、こっちに変更
書き直したコード
▼activity_main.xml(こっちは変更なし)
<?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">
<EditText
android:id="@+id/et1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:ems="10"
android:hint="数字を入力(1)"
android:inputType="number"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<EditText
android:id="@+id/et2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:ems="10"
android:hint="数字を入力(2)"
android:inputType="number"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/et1" />
<Button
android:id="@+id/btnAdd"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="クリック"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/et2" />
<TextView
android:id="@+id/tvAns"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:text="答え"
android:textSize="36sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btnAdd" />
<Button
android:id="@+id/btnClear"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="32dp"
android:text="clear"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
▼MainActivity.kt
package com.example.addapp
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button
import android.widget.EditText
import android.widget.TextView
import android.widget.Toast
import androidx.appcompat.app.AlertDialog
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
//1)Viewの取得(idで)
val et1:EditText = findViewById(R.id.et1)
val et2:EditText = findViewById(R.id.et2)
val btnAdd :Button = findViewById(R.id.btnAdd)
val tvAns :TextView = findViewById(R.id.tvAns)
val btnClear:Button =findViewById(R.id.btnClear)
//2)クリック処理(足し算)
btnAdd.setOnClickListener {
//4)条件分岐
if(et1.text.toString()==("") || et2.text.toString()==("")){
//(4-1)エラー処理:トースト
Toast.makeText(this,"数字を入力してください",Toast.LENGTH_LONG).show()
//(4-2)エラー処理:アラートダイアログ
// AlertDialog.Builder(this)
// .setTitle("ERROR!")
// .setMessage("数字を入力してください")
// .setPositiveButton("OK",null)
// .show()
} else {
//Edit(編集型) ⇒ String(文字)型 ⇒ int型
val sum =et1.text.toString().toInt() + et2.text.toString().toInt()
tvAns.text = "合計は $sum"
}
}
//3)クリア処理
btnClear.setOnClickListener {
et1.text.clear()
et2.text.clear()
tvAns.text ="答え"
}
}
}