Desenvolvimento do Android-Componentes comuns do Android-Botão de botão

4.3 Botão (botão)

  • O controle de Button herda de TextView e tem as propriedades de TextView.
  • Introdução ao StateListDrawable

StateListDrawable é um tipo de recurso Drawable, que pode definir diferentes efeitos de imagem de acordo com diferentes estados, o nó chave <seletor>, precisamos apenas definir o atributo de fundo de Button para este recurso drawable e, então, podemos facilmente perceber diferentes efeitos quando pressionando o botão Cor ou fundo do botão!

Nome do Atributo

ilustrar

desenhavel

O bitmap Drawable referenciado, podemos colocá-lo na frente, o que significa o estado normal do componente ~

focado no estado

Quer obter o foco

state_window_focused

Se deve obter o foco da janela

state_enabled

Se o controle está disponível

estado_verificável

Se o controle pode ser verificado

state_checked

Se o controle é verificado

estado_selecionado

Se o controle está selecionado, para o caso com uma roda de rolagem

estado_pressionado

Se o controle é pressionado

estado_ativo

Se o controle está ativo

estado_único

Quando o controle contém vários controles filho, determine se deve exibir apenas um controle filho

estado_primeiro

Quando o controle contém vários controles filho, determine se o primeiro controle filho é exibido

estado_meio

Quando o controle contém vários subcontroles, determine se o subcontrole do meio é exibido

estado_último

Quando o controle contém vários controles filho, determine se o último controle filho é exibido

 
 Exemplo:
Crie um novo arquivo xml btn_bg1.xml na pasta desenhável.

 

 btn_bg1.xml:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@color/dark_gray" android:state_pressed="true"/>  //控件被按下时变成深灰
    <item android:drawable="@color/lawn_green" android:state_enabled="false"/>    //控件不可用时变成绿色
    <item android:drawable="@color/purple_200"/>    //控件平常时显示浅紫色
</selector>

 

 Crie botton.xml na pasta de layout:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:background="#eeeeee"
    android:paddingTop="50dp">

    <Button
        android:id="@+id/btnOne"
        android:layout_width="match_parent"
        android:layout_height="64dp"
        android:background="@drawable/btn_bg1"
        android:text="按钮"
        android:textColor="@color/white"
        android:textSize="20sp"
        android:textStyle="bold"/>
    <Button
        android:id="@+id/btnTwo"
        android:layout_width="match_parent"
        android:layout_height="64dp"
        android:text="按钮不可用"
        android:textColor="@color/black"
        android:textSize="20sp"
        android:textStyle="bold"/>


</LinearLayout>

MainActivity.java:

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;


public class MainActivity extends AppCompatActivity {

    private Button btnOne,btnTwo;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.button);
        btnOne = (Button) findViewById(R.id.btnOne);
        btnTwo = (Button) findViewById(R.id.btnTwo);
        btnTwo.setOnClickListener(new View.OnClickListener(){   //按钮绑定事件
            @Override
            public void onClick(View v){
                if (btnTwo.getText().toString().equals("按钮不可用")){
                    btnOne.setEnabled(false);
                    btnTwo.setText("按钮可用");
                }else {
                    btnOne.setEnabled(true);
                    btnTwo.setText("按钮不可用");
                }
            }
        });

    }
}

 

Acho que você gosta

Origin blog.csdn.net/LYly_B/article/details/129828807
Recomendado
Clasificación