Home | History | Annotate | Download | only in lib
      1 /*
      2  * Copyright 2012 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *     http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 package com.example.android.tabcompat.lib;
     18 
     19 import android.os.Build;
     20 import android.os.Bundle;
     21 import android.support.v4.app.FragmentActivity;
     22 
     23 /**
     24  * Convenience helper to build a set of tabs for a {@link TabCompatActivity}. To use this class,
     25  * extend {@link TabCompatActivity} and:
     26  *
     27  * Call {@link TabCompatActivity#getTabHelper()}, returning a {@link TabHelper}.
     28  *
     29  * Create a {@link CompatTabListener}.
     30  *
     31  * Call {@link TabHelper#newTab(String)} to create each tab.
     32  *
     33  * Call CompatTab.setText().setIcon().setTabListener() to set up your tabs.
     34  *
     35  * Call {@link TabHelper#addTab(CompatTab)} for each tab, and you're done.
     36  */
     37 public abstract class TabHelper {
     38 
     39     protected FragmentActivity mActivity;
     40 
     41     protected TabHelper(FragmentActivity activity) {
     42         mActivity = activity;
     43     }
     44 
     45     /**
     46      * Factory method for creating TabHelper objects for a given activity. Depending on which device
     47      * the app is running, either a basic helper or Honeycomb-specific helper will be returned.
     48      * Don't call this yourself; the TabCompatActivity instantiates one. Instead call
     49      * TabCompatActivity.getTabHelper().
     50      */
     51     public static TabHelper createInstance(FragmentActivity activity) {
     52         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
     53             return new TabHelperHoneycomb(activity);
     54         } else {
     55             return new TabHelperEclair(activity);
     56         }
     57     }
     58 
     59     /**
     60      * Create a new tab.
     61      *
     62      * @param tag A unique tag to associate with the tab and associated fragment
     63      * @return CompatTab for the appropriate android version
     64      */
     65     public CompatTab newTab(String tag) {
     66         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
     67             return new CompatTabHoneycomb(mActivity, tag);
     68         } else {
     69             return new CompatTabEclair(mActivity, tag);
     70         }
     71     }
     72 
     73     public abstract void addTab(CompatTab tab);
     74 
     75     protected abstract void onSaveInstanceState(Bundle outState);
     76 
     77     protected abstract void onRestoreInstanceState(Bundle savedInstanceState);
     78 
     79     protected abstract void setUp();
     80 }
     81