Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube
JC Mouse Bolivia
Index / Android / Crea un Tabbed Activity desde cero

Crea un Tabbed Activity desde cero

Autor jc mouse viernes, mayo 19, 2017

Un Tabbed Activity te permite cambiar la vista entre  fragmentos desplazando el dedo  de izquierda a derecha o de derecha a izquierda, Android Studio cuenta con una plantilla para crear un proyecto base, sin embargo, si estas aprendiendo android es mejor conocer como se crea este Tabbed Activty desde cero.

Paso 1. EL Proyecto

Creamos un nuevo proyecto en Android Studio que se llamara “Tabbed Demo“, a continuación seleccionamos el SDK “Minimum SDK: API 16 Android 4.1” para tener mayor compatibilidad con dispositivos.

tab android

Presionamos siguiente y elegimos un Empty Activity, dejamos como esta el nombre de “MainActivity” y su layout “activity_main” que sale por defecto, presionamos finish para crear el proyecto.

example tabbed

Paso 2. Los Fragments

Un Tabbed Activity puede tener 2, 3, 4 o más fragments, dependiendo de las necesidades que se tenga. Android Studio tambien te permite crear Fragments (clase y su layout) automáticamente, pero como dijimos en un principio, si estamos aprendiendo, es mejor conocer como se crean las cosas desde codigo. A continuación los pasos pasos para crear Fragments.

Clic derecho sobre el proyecto “org.example.tabbeddemo”, new -> java class y agregamos  una nueva clase con el nombre de “JobsFragment“, a continuación clic derecho sobre la carpeta layout -> new -> Layout Resource File -> y colocamos en file name:fragment_jobs“, presionamos OK para crear el archivo.

Reemplazamos el código del layout con:

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="20dp"
    android:background="#d14115"
    tools:context="org.example.tabbeddemo.JobsFragment">

    <TextView
        android:textSize="32dp"
        android:textColor="#FFF"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="\u0022¿Por qué enrolarse en la marina si puedes ser un pirata?\u0022 - Steve Jobs" />

</FrameLayout>

donde en context, indicamos la ruta del archivo java al que corresponde este Fragment, en este caso la ruta es: org.example.tabbeddemo.JobsFragment. También le asignamos un color de fondo (android:background) rojo en este caso, y en  android:text colocamos una frase de Steve Jobs.

En vista diseño podremos ver algo como esto:

jobs frase

Ahora en la clase JobsFragment.java, reemplazamos el código por el código mínimo necesario para un fragment:

package org.example.tabbeddemo;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class JobsFragment extends Fragment {

    public static JobsFragment newInstance() {
        return new JobsFragment();
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        return inflater.inflate(R.layout.fragment_jobs , container, false);
    }

}

donde en inflate indicamos el layout que corresponde a la clase fragment, el layout que creamos más arriba “R.layout.fragment_jobs“.

Si quieres saber más sobre los Fragments, te invito a visitar “Introducción a Fragment“.

A continuación, agregaremos 2 clases más con sus respectivos layouts, estos son:

  • WozniakFragment.java y su layout fragment_wozniak
  • GatesFragment.java y su layout fragment_gates

El texto para Wozniak:

Mi padre me explicó que la educación y el conocimiento es lo que le permitirá a los niños mejorar el mundo – Steve Wozniak

El texto para Bill

Al mundo no le importará tu autoestima. El mundo esperará que logres algo, independientemente de que te sientas bien o no contigo mismo –  Bill Gates

Y realizaremos los mismos pasos que con JobsFragment.javafragment_jobs, al final debes tener algo como esto:

gates_wozniak

Paso 3.  activity_main

Abre el archivo activity_main y reemplaza el código por

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="0dp"
    tools:context="org.example.tabbeddemo.MainActivity">

    <android.support.v4.view.ViewPager
        android:id="@+id/container"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

</RelativeLayout>

A nuestro layout le agregamos un ViewPager en donde se cargaran los fragments, en vista diseño no veras ningún cambio. Continuemos.

Paso 4. MainActivity

Esta es la clase principal donde implementaremos los fragments y el ViewPager.

package org.example.tabbeddemo;

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

public class MainActivity extends AppCompatActivity {

    /**
     * para gestionar cada uno de los fragmentos
     * */
    private SectionsPagerAdapter mSectionsPagerAdapter;
    /**
     * Para alojar el contenido de cada fragment
     * */
    private ViewPager mViewPager;


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

        //inicializamos
        mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager());
        mViewPager = (ViewPager) findViewById(R.id.container);
        mViewPager.setAdapter(mSectionsPagerAdapter);
    }

    /**
     * Clase que devolvera un fragment segun la seccion donde se encuentre
     * */
    public class SectionsPagerAdapter extends FragmentPagerAdapter {
        public SectionsPagerAdapter(FragmentManager fm) {
            super(fm);
        }

        @Override
        public Fragment getItem(int position) {
            switch(position){
                case 0: return JobsFragment.newInstance();
                case 1: return WozniakFragment.newInstance();
                case 2: return GatesFragment.newInstance();
            }
            return null;
        }

        @Override
        public int getCount() {
            return 3;//tenemos tres fragment
        }

    }

}

Ya solo nos queda ejecutar el proyecto y probar

tabbed activity

enjoy!!!

Tags

Si te ha gustado podrías compartirlo o dejar un comentario. ¡Muchas gracias!
Autor: JC Mouse

Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.

Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye

Enjoy! :)

También Te Podría Interesar

Capturar webcam con VB.NET

Capturar webcam con VB.NET

¿Que haremos? Crearemos una aplicación en Visual Studio, la cual hará uso de una webcam para capturar el video en frames...

Primeros pasos en Jaspersoft Studio

Primeros pasos en Jaspersoft Studio

¿Que es Jaspersoft Studio? Jaspersoft Studio es el nuevo diseñador de informes basado en Eclipse para JasperReports y Ja...

Compartir imagen desde android – Share Image

Compartir imagen desde android – Share Image

En este post crearemos una aplicación android que nos permitirá compartir una imagen con Facebook, whatsapp, bluetooth,...

Crea patrón de desbloqueo para tus app java

Crea patrón de desbloqueo para tus app java

El patrón de desbloqueo es una medida de seguridad que tienen algunos teléfonos inteligentes para evitar el acceso al di...

Como hacer una factura en Java (Proyecto)

Como hacer una factura en Java (Proyecto)

Tiempo atras me pidieron un ejemplo de como realizar un reporte con iReport tipo factura, recibo o como le llamen, compl...

Métodos GET y POST en RestFul y JSON

Métodos GET y POST en RestFul y JSON

En este post veremos como enviar solicitudes GET y POST a un API RestFul  desde un dispositivo con android. Nuestra apli...

Comparte lo que sabes

Categorias

Últimas entradas

En este post, crearemos una tabla swing que implemente un control jcombobox en una columna de una tabla, llenaremos con...

En este post personalizaremos una tabla JTable Swing para pintar una imagen de fondo y darle un poco de estilo al encabe...

De las pocas herramientas disponibles entre librerías, frameworks, engines, etc para el desarrollo de videojuegos en len...

¿Quien no ha querido programar un juego? creo que la mayoría si no es que todos los que conocen de programación sin impo...

Android Bolivia

MAUS