miércoles, 18 de mayo de 2022

46 - Componente ActionBar (Ocultarlo y mostrarlo)



La barra de acción se muestra en la parte superior para acceder a las opciones de nuestro programa, pero hay situaciones donde necesitemos ocultarla para tener más espacio. Para ocultar y mostrar el ActionBar disponemos de dos métodos:

  show()
hide()

Problema:

Confeccionar una aplicación (Proyecto051) que mediante dos botones se permita ocultar el ActionBar o mostrarlo. Disponer tres opciones en el menú desplegable del ActionBar.

El archivo menuopciones.xml debemos disponer:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android">

<item android:title="Opcion 1"
android:id="@+id/opcion1" />
<item android:title="Opcion 2"
android:id="@+id/opcion2" />
<item android:title="Opcion 3"
android:id="@+id/opcion3" />
</menu>

El código fuente de la aplicación java es:

package com.tutorialesprogramacionya.proyecto051;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

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

@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menuopciones, menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id==R.id.opcion1) {
Toast.makeText(this,"Se seleccionó la primer opción",Toast.LENGTH_LONG).show();
}
if (id==R.id.opcion2) {
Toast.makeText(this,"Se seleccionó la segunda opción",Toast.LENGTH_LONG).show();
}
if (id==R.id.opcion3) {
Toast.makeText(this,"Se seleccionó la tercer opción", Toast.LENGTH_LONG).show();
}
return super.onOptionsItemSelected(item);
}

public void ocultar(View v) {
getSupportActionBar().hide();
}

public void mostrar(View v) {
getSupportActionBar().show();
}
}

Luego cuando lo ejecutamos podemos observar según el botón que presionamos el ActionBar se hace visible o se oculta:

ActionBar

O aparece oculta:

ActionBar

Para poder ocultar el ActionBar debemos obtener la referencia del objeto mediante el método getSupportActionBar() que se trata de un método heredado de la clase ActionBarActivity:

    public void ocultar(View v) {
getSupportActionBar().hide();
}

Para volver a hacer visible el ActionBar llamamos al método show(), esto ocurre cuando presionamos el segundo botón:

    public void mostrar(View v) {
getSupportActionBar().show();
}

Este proyecto lo puede descargar en un zip desde este enlace: proyecto051.zip

No hay comentarios:

Publicar un comentario