[Android] 按钮单击事件的五种写法
在平时学习安卓的过程中,不论是看视频还是看博客,我发现每个人对代码的写法都有不同的偏好,比较明显的就是对控件响应事件的写法的不同。所以我想把这些写法总结一下,比较下各种写法的优劣,希望可以让自己可以灵活地选择编码方式。
原文地址请保留 http://www.cnblogs.com/rossoneri/p/3975468.html
xml文件
1 <Button 2 android:id="@+id/button1" 3 android:layout_width="wrap_content" 4 android:layout_height="wrap_content" 5 android:text="Button1" /> 6 7 <Button 8 android:id="@+id/button2" 9 android:layout_width="wrap_content" 10 android:layout_height="wrap_content" 11 android:text="Button2" />
四种方法:
- 匿名内部类
1 public class TestButtonActivity extends Activity { 2 3 Button btn1, btn2; 4 Toast tst; 5 6 @Override 7 protected void onCreate(Bundle savedInstanceState) { 8 super.onCreate(savedInstanceState); 9 setContentView(R.layout.activity_test_button); 10 11 btn1 = (Button) findViewById(R.id.button1); 12 btn2 = (Button) findViewById(R.id.button2); 13 14 btn1.setOnClickListener(new OnClickListener() { 15 16 @Override 17 public void onClick(View v) { 18 // TODO Auto-generated method stub 19 Toast tst = Toast.makeText(TestButtonActivity.this, "111111111", Toast.LENGTH_SHORT); 20 tst.show(); 21 22 } 23 }); 24 25 btn2.setOnClickListener(new OnClickListener() { 26 27 @Override 28 public void onClick(View v) { 29 // TODO Auto-generated method stub 30 Toast tst = Toast.makeText(TestButtonActivity.this, "222222222", Toast.LENGTH_SHORT); 31 tst.show(); 32 } 33 }); 34 } 35 36 }
- 自定义单击事件监听类
1 public class TestButtonActivity extends Activity { 2 3 Button btn1, btn2; 4 Toast tst; 5 6 class MyClickListener implements OnClickListener { 7 8 @Override 9 public void onClick(View v) { 10 // TODO Auto-generated method stub 11 switch (v.getId()) { 12 case R.id.button1: 13 tst = Toast.makeText(TestButtonActivity.this, "111111111", Toast.LENGTH_SHORT); 14 tst.show(); 15 break; 16 case R.id.button2: 17 tst = Toast.makeText(TestButtonActivity.this, "222222222", Toast.LENGTH_SHORT); 18 tst.show(); 19 break; 20 default: 21 break; 22 } 23 } 24 25 } 26 27 @Override 28 protected void onCreate(Bundle savedInstanceState) { 29 super.onCreate(savedInstanceState); 30 setContentView(R.layout.activity_test_button); 31 32 btn1 = (Button) findViewById(R.id.button1); 33 btn2 = (Button) findViewById(R.id.button2); 34 35 btn1.setOnClickListener(new MyClickListener()); 36 btn2.setOnClickListener(new MyClickListener()); 37 } 38 39 }
- Activity继承View.OnClickListener,由Activity实现OnClick(View view)方法,在OnClick(View view)方法中用switch-case对不同id代表的button进行相应的处理
1 public class TestButtonActivity extends Activity implements OnClickListener { 2 3 Button btn1, btn2; 4 Toast tst; 5 6 @Override 7 protected void onCreate(Bundle savedInstanceState) { 8 super.onCreate(savedInstanceState); 9 setContentView(R.layout.activity_test_button); 10 11 btn1 = (Button) findViewById(R.id.button1); 12 btn2 = (Button) findViewById(R.id.button2); 13 14 btn1.setOnClickListener(this); 15 btn2.setOnClickListener(this); 16 } 17 18 @Override 19 public void onClick(View v) { 20 // TODO Auto-generated method stub 21 switch (v.getId()) { 22 case R.id.button1: 23 tst = Toast.makeText(this, "111111111", Toast.LENGTH_SHORT); 24 tst.show(); 25 break; 26 case R.id.button2: 27 tst = Toast.makeText(this, "222222222", Toast.LENGTH_SHORT); 28 tst.show(); 29 break; 30 default: 31 break; 32 } 33 } 34 }
- 最后一种是我今天看到的一种写法,在XML文件中“显示指定按钮的onClick属性,这样点击按钮时会利用反射的方式调用对应Activity中的click()方法”[注1]
1 <Button 2 android:id="@+id/button1" 3 android:layout_width="wrap_content" 4 android:layout_height="wrap_content" 5 android:onClick="onClick" 6 android:text="Button1" /> 7 8 <Button 9 android:id="@+id/button2" 10 android:layout_width="wrap_content" 11 android:layout_height="wrap_content" 12 android:onClick="onClick" 13 android:text="Button2" />
这里在输完android:的时候按下 Alt+/ 会有 onClick 属性的提示, 但输入到 android:onClick=“ 的地方按下 Alt+/ 并没有提示 onClick 选项,让我突然觉得这里好像有点问题。
1 public class TestButtonActivity extends Activity { 2 3 Button btn1, btn2; 4 Toast tst; 5 6 @Override 7 protected void onCreate(Bundle savedInstanceState) { 8 super.onCreate(savedInstanceState); 9 setContentView(R.layout.activity_test_button); 10 } 11 12 // 注意 这里没有 @Override 标签 13 public void onClick(View v) { 14 // TODO Auto-generated method stub 15 switch (v.getId()) { 16 case R.id.button1: 17 tst = Toast.makeText(this, "111111111", Toast.LENGTH_SHORT); 18 tst.show(); 19 break; 20 case R.id.button2: 21 tst = Toast.makeText(this, "222222222", Toast.LENGTH_SHORT); 22 tst.show(); 23 break; 24 default: 25 break; 26 } 27 } 28 }
这种写法整个代码中都不用声明button就可以实现button的单击事件。
以上就是四种实现按钮单击事件的方法。
粗略总结一下,就是按钮少的时候用匿名内部类会比较快,比如写demo测试的时候或者登陆界面之类的。
按钮多的情况我还是选择第三种方法,方便。
关于第四种方法,我感觉最方便,但看了很多代码还是觉得写法挺小众,不知为什么,这一点还需要我多研究研究。
[注1]这段话引用自Android - Button(按钮)的响应点击事件的4种写法
其中他所说的
1 public void click(View v){ 2 ... 3 }
方法我试了下,运行时会报错。建议用我上面的示例代码。时间仓促,也没来得及细看出错原因,等有空再看一看。
2015.04.27 补:
可以在 xml 文件中为 <Button/> 增加 android:onclick="funcname" 属性,这个 funcname 就是在点击按钮后系统调用的 activity 里面的方法。比如:
<Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/button_send" android:onClick="sendMessage" />
在activity里加入方法:
/** Called when the user clicks the Send button */ public void sendMessage(View view) { // Do something in response to button }
即可。