Android中的Button控件

1.随按钮状态改变背景色或图片

1.1 纯色按钮

首先创建一个mybutton项目同时创建一个button控件
在这里插入图片描述
尝试修改按钮背景色为黑色,但是按钮并无有颜色变化
在这里插入图片描述
解决方法:
在这里插入图片描述

在values中的themes.xml中
在这里插入图片描述
这个语句最后加上一个Bridge即可正常显示颜色

1.2 按钮图片变化

为了完成按下按钮时的可视化变化,这里在res文件下的drawable下新建一个Drawable resource file,命名为btn_selector,然后导入图片(这里暂时先导入两个icon)
在这里插入图片描述
添加两个item
在这里插入图片描述
第一个是当按下时引入其中一张图片
第二个是直接引入另一张图片
(这里引号内的内容就是所添加图片的名称,在旁边路径下可以看到)

最后在设置背景图片
在这里插入图片描述

结果如图:
在这里插入图片描述

1.3 按钮颜色变化

在res中新建一个文件夹命名为color,在color中新建color resource file 命名为btn_color_selector,之后添加两个item
在这里插入图片描述
引入:
在这里插入图片描述
结果(脑补按下时的颜色变化):
在这里插入图片描述

2. Butotn事件处理

  • 点击
  • 长按
  • 触摸
    在这里插入图片描述
    在java文件中获取id
    在这里插入图片描述
    代码如下(当完成对应按钮状态时输出对应的字符串):
//MainActivity.java
package com.example.mybutton;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;

public class MainActivity extends AppCompatActivity {

    private static final String TAG = "leo";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        View btn = findViewById(R.id.btn);

        //点击事件
        btn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
            	//输出对应的信息
                Log.e(TAG, "onClick: " );
            }
        });

        //长按事件
        btn.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {
                Log.e(TAG, "onLongClick: " );
                return false;
            }
        });

        //触摸事件
        btn.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                Log.e(TAG, "onTouch: " );
                return false;
            }
        });
    }
}

触摸事件分为按下、按下移动、松开三种情况


版权声明:本文为qq_53388087原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。