1、主要作用
自动触发控件的点击事件
2、界面的布局文件 activity_main.xml
<RelativeLayout 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/bt" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="点击一下" /> <Button android:id="@+id/bt2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@id/bt" android:text="@string/hello_world" /> </RelativeLayout>
3、MainActivity 代码
package com.android; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.Toast; public class MainActivity extends Activity { Button button1 ; Button button2 ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main ); button1 = (Button) findViewById( R.id.bt ) ; button1.setOnClickListener( new OnClickListener() { @Override public void onClick(View v) { button2.performClick(); //调用 button2的点击事件 } }); button2 = (Button) findViewById( R.id.bt2 ) ; button2.setOnClickListener( new OnClickListener() { @Override public void onClick(View v) { Toast.makeText( MainActivity.this , "点击了", Toast.LENGTH_SHORT).show(); } }); } }
4、注意事项
如果同时使用了view.setOnTouchListener()方法,则有可能存在拦截view.performClick()的响应事件,
因为当view.OnTouchEvent()在event.getAction() == MotionEvent.ACTION_DOWN时返回false,
系统会认为view不需要处理Touch事件,则后续的Touch事件(move、up、click)就不会被传进来 。
所以也不会触发view.performClick(),而view.setOnTouchListener()相当于是重写了view.OnTouchEvent(),
所以在写view的TouchListener处理时,需要留意view是否存在点击事件监听,如果有,则在适当的位置使用view.performClick()触发点击事件。
时间: 2024-12-28 16:32:03