Android Kotlin画面遷移方法について調べてみた。
###Manifestへの追加
AndroidManifest.xml
<activity android:name=".MoveApp" android:label="Move" ></activity>
###xml画面作成
デザインモードで作成した物をコード化すると以下になる。
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">
<Button
android:id="@+id/moveButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="移動する"
tools:layout_editor_absoluteX="154dp"
tools:layout_editor_absoluteY="426dp" />
</androidx.constraintlayout.widget.ConstraintLayout>
app_move.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/returnButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Return"
tools:layout_editor_absoluteX="148dp"
tools:layout_editor_absoluteY="266dp" />
</androidx.constraintlayout.widget.ConstraintLayout>
###画面遷移コード
Intentが画面遷移を行うコードとなる。
MainActivity.kt
package com.example.moveapp
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.content.Intent
import kotlinx.android.synthetic.main.activity_main.*
class MainActivity:AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
setScreenMoveApp()
}
private fun setScreenMoveApp(){
setContentView(R.layout.activity_main)
setScreenMain()
}
private fun setScreenMain() {
setContentView(R.layout.activity_main)
moveButton.setOnClickListener{
val intent = Intent(application, MoveApp::class.java)
startActivity(intent)
}
}
}
MoveApp.kt
package com.example.moveapp
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.app_move.*
class MoveApp:AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.app_move)
setScreenMoveApp()
}
private fun setScreenMoveApp(){
setContentView(R.layout.app_move)
setScreenMain()
}
private fun setScreenMain(){
setContentView(R.layout.app_move)
returnButton.setOnClickListener{
val intent = Intent(application, MainActivity::class.java)
startActivity(intent)
}
}
}