여기에서 사용하는 onClick()은 public static final int onClick() 으로 R.asst에 속한 method 입니다.
다른 버튼에서 사용하는 onClick()은 public abstract void onClick (View v)으로 public static interface View.OnClickListener에 속해 있습니다.
android:onClick=”btnClick”의 형태로 layout 설정 xml에 추가 되어 View에서 클릭 되었을 때 정의된 이름의 함수를 호출하여 작동 합니다.
Activity에 public void btnClick(View v)으로 method를 선언 하지 않으면 오류가 발생 합니다.
Activity에 button을 생성하지 않고도 함수만 생성하여 호출 할 수 있습니다.
1. Layout에 이벤트 추가
activity_main.xml에 Layout을 구성 하면서 Button에 이벤트를 등록 합니다.
android:onClick="btnClick” 이런 형태로 btnClick이건 java에서 사용할 함수 명으로 하시면 됩니다.
버튼을 클릭 하면 해당하는 btnClick() 함수를 찾아 실행을 하게 됩니다.
<Button
android:id="@+id/btn_onclick1"
android:text="@string/btn_click1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:layout_marginTop="50dp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toTopOf="parent"
android:onClick="btnClick"/>
테스트를 위해 3개의 버튼을 만들고 3개 모두 동일한 android:onClick="btnClick” 이번트가 발생하도록 했습니다.
2. Activity에 기능 구현
버튼 클릭에 대한 함수를 구현 합니다.
public void btnClick(View view) { }
버튼 3개가 모두 동일한 btnClick() 함수를 호출 하도록 되어 있어 실제 어떤 버튼이 선택 되었는지는
getId()를 이용하여 ID를 확인 하고 그에 따라 작업을 분기 시킵니다.
if(view.getId() == R.id.btn_onclick1) { }
여기서는 Toast로 간단한 메시지를 보여 줍니다.
3. 결과
화면 버튼 구성이 좀 엉성하지만 3개의 버튼을 클릭하면 결과는 확인 가능 합니다.
4. Source Code
4.1 activity_main.xml
화면 구성 layout에 버튼 3개를 추가 합니다.
<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.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/btn_onclick1" android:text="@string/btn_click1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="10dp" android:layout_marginTop="50dp" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintTop_toTopOf="parent" android:onClick="btnClick"/> <Button android:id="@+id/btn_onclick2" android:text="@string/btn_click2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="100dp" android:layout_marginTop="50dp" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintTop_toTopOf="parent" android:onClick="btnClick"/> <Button android:id="@+id/btn_onclick3" android:text="@string/btn_click3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="200dp" android:layout_marginTop="50dp" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintTop_toTopOf="parent" android:onClick="btnClick"/> </android.support.constraint.ConstraintLayout>
4.2 strings.xml
layout button에 사용되는 text를 정의 합니다.
<resources> <string name="app_name">ButtonOnClick</string> <string name="btn_click1">onClick1</string> <string name="btn_click2">onClick2</string> <string name="btn_click3">onClick3</string> </resources>
4.3 MainActivity.java
Button Click시 호출 되는 함수를 기술 합니다.
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } // Layout 작성시 button 속성에 onClick 이벤트를 준 경우 public void btnClick(View view) { if(view.getId() == R.id.btn_onclick1) { // Buttoon의 ID를 찾아서 실행이 된다. Toast.makeText(this, "onClick Button1", Toast.LENGTH_SHORT).show(); } else if(view.getId() == R.id.btn_onclick2) { Toast.makeText(this, "onClick Button2", Toast.LENGTH_SHORT).show(); } else if(view.getId() == R.id.btn_onclick3) { Toast.makeText(this, "onClick Button3", Toast.LENGTH_SHORT).show(); } } }
다른 버튼 사용 관련 참조
[android] 안드로이드 버튼(2) 생성시 OnClickListener 구현 방법
[android] 안드로이드 버튼(3) OnClickListener 인터페이스 구현 방법
[android] 안드로이드 버튼(4) OnClickListener를 객체로 선언하여 구현하는 방법
[android] 안드로이드 버튼(5) 버튼 생성 모음 및 이미지 버튼
- copy coding -
'Android' 카테고리의 다른 글
[android] 안드로이드 버튼(3) OnClickListener 인터페이스 구현 방법 (0) | 2018.12.06 |
---|---|
[android] 안드로이드 버튼(2) 생성시 OnClickListener 구현 방법 (0) | 2018.12.06 |
[안드로이드] emulator: ERROR: x86 emulation currently requires hardware acceleration! (0) | 2018.12.04 |
[안드로이드] google map 테스트 (0) | 2018.12.03 |
[안드로이드] google map 사용을 위한 API 키 생성(2018.11) (0) | 2018.12.02 |