クリック/タップ機能の作成
コード activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
>
<TextView
android:id="@+id/testText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="ボタンを押してください"
android:textAlignment="center"
android:textSize="18dp"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp"
/>
<Button
android:id="@+id/testButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="ボタン"
/>
</LinearLayout>
クリック/タップ検知時の処理を追加
まずはMaineActivity.java へクラスとメソッドの追加
追加する場所
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
/*+++++++++++
ここに追加
+++++++++++*/
}
処理を入れていく
更新後
//クリックした際の処理
class TextListener implements View.OnClickListener{
@Override
public void onClick(View view){
TextView tv = findViewById(R.id.testText);
tv.setText("押されました");
}
}
クリック/タップ検知判定を作る
MaineActivity.java へ処理を追加する
追加する場所
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
/*+++++++++++
ここに追加
+++++++++++*/
}
class TextListener implements View.OnClickListener{
@Override
public void onClick(View view){
TextView tv = findViewById(R.id.testText)
tv.setText("押されました")
}
}
}
インスタンス生成
クリック後の処理を記述したクラスのインスタンスを生成する
TextListenerという名前でクラスを作っているので
TextListener testlistener = new TextListener(); とする。
さっき作ったクリック後の処理を記述したクラス
class TextListener implements View.OnClickListener{
@Override
public void onClick(View view){
TextView tv = findViewById(R.id.testText)
tv.setText("押されました")
}
}
インスタンス生成 |
---|
クラス名 変数名 = new クラス名(); |
追加後の全体図 MainActivity.java
package com.wabsarva.wings.android.testapplication;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.graphics.Insets;
import androidx.core.view.ViewCompat;
import androidx.core.view.WindowInsetsCompat;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
EdgeToEdge.enable(this);
setContentView(R.layout.activity_main);
//今回追加した3行 ↓
Button bt = findViewById(R.id.testButton);
TextListener testlistener = new TextListener();
bt.setOnClickListener(testlistener);
}
class TextListener implements View.OnClickListener{
@Override
public void onClick(View view){
TextView tv = findViewById(R.id.testText);
tv.setText("押されました");
}
}
}
//インポートの中にいらんもの混じってるけど気にしない
これで
ボタンが押された→テキストの内容が変更する処理が完了
挙動を確認してみる
ちゃんとできているみたい、やったね。