Skip to content
No description, website, or topics provided.
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.idea
gradle/wrapper
library
sample
screenshots
.gitignore
LICENSE
MaterialTabLayout.iml
MaterialTabs.iml
README.md
build.gradle
gradle.properties
gradlew
gradlew.bat
settings.gradle

README.md

MaterialTabs

A simple way to implement Material Design Tabs.

INSTALL

Add this dependecy from jCenter:

compile 'com.gustavofao:MaterialTabs:1.3.1'

USAGE

To use this lib, you have to add the tab host and a ViewPager on your layout:

<com.gustavofao.materialtabs.SlidingTabLayout
        android:id="@+id/tab_host"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@+id/toolbar"
        android:background="?attr/colorPrimary"/>

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

On your Activity:

    tabLayout = (SlidingTabLayout) findViewById(R.id.tab_host);
    viewPager = (ViewPager) findViewById(R.id.view_pager);

    viewPager.setAdapter(new TabAdapter(getSupportFragmentManager(), this));
    tabLayout.setSelectedIndicatorColors(getResources().getColor(android.R.color.white));
    tabLayout.setViewPager(viewPager);

These are the basic to it work. It will use the active color as white and the innactive color 70% white. and text content To show the indicator, use setSelectedIndicatorColors(Color) with the color you want.

ADAPTER

The TabAdapter extends SlidingFragmentPagerAdapter that extends FragmentPagerAdapter. To use is the same way you use FragmentPagerAdapter when going to use text must implement getPageTitle(int position) and when you are going to use icon needs to override getPageDrawable(int Position). You can also integrate your support actionbar to change title with the tabs. If you have a fixed text on you actionbar, just don't set it or return always your title on getToolbarTitle(int position). Check the sample above.

public static class TabAdapter extends SlidingFragmentPagerAdapter {
  private String[] titles = {
    "Contacts",
    "Favorites",
    "Groups",
  };

  private int[] icons = {
    R.drawable.account,
    R.drawable.star,
    R.drawable.account_multiple
  };
  ...
  @Override
  public CharSequence getPageTitle(int position) {
    return titles[position];
  }

  @Override
  public Drawable getPageDrawable(int position) {
    return context.getResources().getDrawable(icons[position]);
  }

  @Override
  public String getToolbarTitle(int position) {
      return titles[position];
  }
  ...
}

CUSTOMIZATION

By now you can only change the active and inactive color using the following lines:

tabLayout.setSelectedIndicatorColors(Color); //Default White
tabLayout.setCustomFocusedColor(Color); //Default 70% White

To change the content:

tabLayout.setTabType(TabType.TEXT_ICON); // Text and icon
tabLayout.setTabType(TabType.ICON_ONLY); // Just the icon
tabLayout.setTabType(TabType.TEXT_ONLY); // Just the text

To add actionbar

tabLayout.setActionBar(getSupportActionBar());

To show and hide information point

tabLayout.showIndicator(position);
tabLayout.hideIndicator(position);

SAMPLE

The sample can be found on this link and its layout on this.

SCREENSHOTS

UPDATES

1.0

  • Project start with icons, text and both together.

1.1

  • Added information point.

1.2

  • Added ActionBar (Support) integration for change title.
  • Adjusted information point to be editable (show/hide) after create views.

Thanks

Google IOSched by Google.

License

Copyright 2015 Gustavo Fão. All rights reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
You can’t perform that action at this time.