Android 图像按钮ImageButton

╰+哭是因爲堅強的太久メ 2022-06-05 04:11 584阅读 0赞

ImageButton派生自ImageView,而不是Button,这一点当第一眼看到ImageButton的时候,我就下意识的认识它是Button的子类。所以ImageButton拥有ImageView的属性和方法,不过ImageView有默认的按钮外观。
从android文档中,我们可以很清楚看到ImageButton和ImageView之间的关系。
这里写图片描述

让我们在看下ImageButton和ImageView外观的区别。
这里写图片描述
可见ImageButotn拥有和一个普通Button一样的外观,有默认的边框背景,而ImageView则什么都没有。
这里为了让大家能清楚看出两者的不同,所以这里的图片是设计图片,不是程序运行时的图片。运行时,ImageView那块是空白的,没有背景色是看不出来的。

接下来我们说下ImageButton的一些特别的地方。

1.不同于Button既能显示文字又能显示图片,ImageButton是图像按钮,只能显示图像而不能显示文本。
2.ImageButton上的图像可以按照比例进行拉伸,而Button上的大图会拉伸变形
3.ImageButton可以同时设置背景图片和前景图片,实现两者图片叠加的效果。

  1. <ImageButton
  2. android:layout_width="wrap_content"
  3. android:layout_height="wrap_content"
  4. android:background="@drawable/ib_background"
  5. android:src="@drawable/search_press"/>

布局文件里只有一个ImageButton,设置一张背景图片,一张前景图片(search小图标),显示效果如下图:
这里写图片描述

这里我们对ImageButton的使用就不多做说明了,在使用过程中遇到我们在详细讲一下。
只写这么多就结束好像有点简单了,我们在加一点东西,实现ImageButton的touch效果,代码很简单,
实现触摸ImageButton显示search图片,当然这个只是演示,大家可以发散一下,比如点击的时候,背景改变,图像大小,透明度改变等等。。。

  1. private ImageButton ib_image;
  2. @Override
  3. protected void onCreate(Bundle savedInstanceState) {
  4. super.onCreate(savedInstanceState);
  5. setContentView(R.layout.activity_imagebutton);
  6. ib_image = findViewById(R.id.ib_image);
  7. ib_image.setOnTouchListener(new View.OnTouchListener() {
  8. @Override
  9. public boolean onTouch(View v, MotionEvent event) {
  10. if(event.getAction() == MotionEvent.ACTION_DOWN)
  11. {
  12. ib_image.setImageResource(R.drawable.search_press);
  13. }
  14. else
  15. {
  16. ib_image.setImageDrawable(null);
  17. }
  18. return false;
  19. }
  20. });
  21. }

布局文件和上边的差不多,只不过没有设置src属性。
这里写图片描述这里写图片描述

发表评论

表情:
评论列表 (有 0 条评论,584人围观)

还没有评论,来说两句吧...

相关阅读