Diferencia entre revisiones de «CheckBox»

De MediaWiki
Ir a la navegación Ir a la búsqueda
Línea 119: Línea 119:
 
</syntaxhighlight>
 
</syntaxhighlight>
  
==Caso práctico 2==
 
 
* Neste caso imos xestionar o evento de cambio de estado do CheckBox implementando a interface correspondente na Activity.
 
: Lembrar que [https://wiki.cifprodolfoucha.es/index.php?title=PDM_Xesti%C3%B3n_de_Eventos xa vimos nesta Wiki] as diferentes formas de implementar as interfaces.
 
 
 
* Partimos que xa temos creado o proxecto inicial como [http://wiki.cifprodolfoucha.es/index.php?title=PDM_Creando_proxecto_base xa indicamos anteriormente].
 
: Se non o temos creado antes, crea un paquete de nome '''UI''' como un subpaquete do teu paquete principal.
 
: Dentro do paquete UI, crearemos un novo paquete de nome: '''Checkboxes'''.
 
 
 
<br />
 
* Dentro do paquete '''Checkboxes''' crear unha nova 'Empty Activity' de nome: '''UD02_02_CkeckBox''' de tipo Launcher.
 
: Modifica o arquivo '''AndroidManifiest.xml''' e engade unha label á activity como [http://wiki.cifprodolfoucha.es/index.php?title=PDM_Creando_proxecto_base xa vimos na creación do proxecto base].
 
 
 
* Imos xestionar o evento de Click sobre dúas Checkbox pero empregando a interface [https://developer.android.com/reference/android/widget/CompoundButton.OnCheckedChangeListener OnCheckedChangeListener].
 
 
<br />
 
===Layout XML===
 
'''Arquivo de Layout:'''
 
<syntaxhighlight lang="xml" line highlight="">
 
<?xml version="1.0" encoding="utf-8"?>
 
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
 
    xmlns:app="http://schemas.android.com/apk/res-auto"
 
    xmlns:tools="http://schemas.android.com/tools"
 
    android:layout_width="match_parent"
 
    android:layout_height="match_parent"
 
    tools:context=".UD2.UI.CheckBoxes.UD02_02_CkeckBox">
 
 
    <CheckBox
 
        android:id="@+id/chkbox2_UD02_01_Checkbox"
 
        android:layout_width="wrap_content"
 
        android:layout_height="wrap_content"
 
        android:layout_marginTop="8dp"
 
        android:layout_marginEnd="8dp"
 
        android:text="CheckBox 2"
 
        app:layout_constraintEnd_toEndOf="parent"
 
        app:layout_constraintTop_toTopOf="parent" />
 
 
    <CheckBox
 
        android:id="@+id/chkbox1_UD02_01_Checkbox"
 
        android:layout_width="wrap_content"
 
        android:layout_height="wrap_content"
 
        android:layout_marginStart="8dp"
 
        android:layout_marginTop="8dp"
 
        android:text="CheckBox 1"
 
        app:layout_constraintStart_toStartOf="parent"
 
        app:layout_constraintTop_toTopOf="parent" />
 
</android.support.constraint.ConstraintLayout>
 
</syntaxhighlight>
 
 
 
<br />
 
===Código Java===
 
'''Activity UD02_02_CkeckBox'''
 
<syntaxhighlight lang="java" line highlight="11,18,19,22-44">
 
 
package cifprodolfoucha.cursoandroid.aprendiendo.UD2.UI.CheckBoxes;
 
 
import android.support.v7.app.AppCompatActivity;
 
import android.os.Bundle;
 
import android.widget.CheckBox;
 
import android.widget.CompoundButton;
 
import android.widget.Toast;
 
 
import cifprodolfoucha.cursoandroid.aprendiendo.R;
 
 
public class UD02_02_CkeckBox extends AppCompatActivity implements CompoundButton.OnCheckedChangeListener {
 
 
    @Override
 
    protected void onCreate(Bundle savedInstanceState) {
 
        super.onCreate(savedInstanceState);
 
        setContentView(R.layout.activity_ud02_02__ckeck_box);
 
 
        ((CheckBox)findViewById(R.id.chkbox1_UD02_01_Checkbox)).setOnCheckedChangeListener(this);
 
        ((CheckBox)findViewById(R.id.chkbox2_UD02_01_Checkbox)).setOnCheckedChangeListener(this);
 
    }
 
 
    @Override
 
    public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
 
 
        switch (buttonView.getId()){
 
 
            case R.id.chkbox1_UD02_01_Checkbox:    // Aquí iría o código específico para o primeiro checkbox.
 
                if (isChecked){
 
                    Toast.makeText(this,"Se activou checkbox1" ,Toast.LENGTH_SHORT).show();
 
                }
 
                else{
 
                    Toast.makeText(this,"Se desactivou  checkbox1" ,Toast.LENGTH_SHORT).show();
 
                }
 
                break;
 
            case R.id.chkbox2_UD02_01_Checkbox:
 
                if (isChecked){
 
                    Toast.makeText(this,"Se activou  checkbox2" ,Toast.LENGTH_SHORT).show();
 
                }
 
                else{
 
                    Toast.makeText(this,"Se desactivou  checkbox2",Toast.LENGTH_SHORT).show();
 
                }
 
                break;
 
 
        }
 
 
    }
 
}
 
</syntaxhighlight>
 
 
 
<br />
 
 
==Métodos mínimos a coñecer no manexo dos CheckBox==
 
==Métodos mínimos a coñecer no manexo dos CheckBox==
  

Revisión del 16:56 15 nov 2020

Introdución

  • Un CheckBox permite ao usuario elixir unha ou máis opcións dentro dun conxunto.

00 checkboxes.png

  • Este control ao igual que ToggleButton e Switch herda da clase CompoundButton, quen, á súa vez, herda da clase Button.

00 Part of Android View Hierarchy.png



  • Por tanto, funcionan da mesma maneira:


  • Tamén podemos xestionar os eventos da mesma forma que nos botóns, coa interface OnClickListener.


  • Para usalo nun XML layout usar a etiqueta <CheckBox/>


Caso práctico 1

Se non o temos creado antes, crea un paquete de nome UI como un subpaquete do teu paquete principal.
Dentro do paquete UI, crearemos un novo paquete de nome: Checkboxes.



  • Dentro do paquete Checkboxes crear unha nova 'Empty Activity' de nome: UD02_01_CkeckBox de tipo Launcher.
Modifica o arquivo AndroidManifiest.xml e engade unha label á activity como xa vimos na creación do proxecto base.


  • Imos crear unha aplicación na que o usuario indique as súas afeccións ("Aficiones").
Como aínda non sabemos xestionar os eventos, no método onCreate faremos referencia aos tres checkbox e modificaremos varias propiedades.


Código do Layout:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="cifprodolfoucha.cursoandroid.aprendiendo.UI.Checkboxes.UD02_01_CkeckBox">

    <CheckBox
        android:id="@+id/chkInformatica"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:text="Informática"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <CheckBox
        android:id="@+id/chkLer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:text="Ler"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/chkInformatica" />

    <CheckBox
        android:id="@+id/chkDeporte"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:text="Deportes"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/chkLer" />
</androidx.constraintlayout.widget.ConstraintLayout>



Código da Activity:

public class UD02_01_CkeckBox extends AppCompatActivity {

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

        CheckBox checkLer = findViewById(R.id.chkLer);    // Obtemos unha referencia ao checbox ler.
        Toast.makeText(this,checkLer.getText().toString() + " " + String.valueOf(checkLer.isChecked()),Toast.LENGTH_SHORT).show();  // Amosamos unha mensaxe có seu texto e estado

        ((CheckBox)findViewById(R.id.chkInformatica)).setChecked(true); // Podemos non crear unha variable para gardar a referencia ao checkbox. Neste caso cambiamos o estado do checbox.

        CheckBox chkDeportes = findViewById(R.id.chkDeporte);
        chkDeportes.setBackgroundColor(Color.BLUE);  // Cambiamos outras propiedades. Podemos cambiar por programación calquera propiedade do deseñador.
        chkDeportes.setTextColor(Color.RED);
        chkDeportes.setText("NOVA AFICCION");
    }
}

Métodos mínimos a coñecer no manexo dos CheckBox

  • Referenciar a un CheckBox có método findViewById.
  • Recuperar o contido do texto asociado.
  • Cambiar o contido do texto, podendo empregar recursos gardados en /res/values.
  • Engadir novo texto a un existente.
  • Modificar propiedades básicas, como cor, tamaño, visibilidade,...
        CheckBox chk = findViewById(R.id.chk_Uno);                                                          // Referenciamos a un CheckBox que estea no Layout da Activity

        Toast.makeText(getApplicationContext(),chk.getText() + " " + String.valueOf(chk.isChecked()),Toast.LENGTH_LONG).show();   // Obtemos o texto e estado de check con isChecked()

        chk.setText("Novo texto Check");                                                                    // Cambiamos o texto do check

        chk.setChecked(true);                                                                               // Cambimos o estado de check (on/off) => Lanza o evento anterior por ter o setOnXXX antes




-- Ángel D. Fernández González e Carlos Carrión Álvarez -- (2015).