Skip to content Skip to sidebar Skip to footer

How To Add Tabhost In Navigation Drawer

In my app I am using navigation drawer from this tutorial http://www.androidhive.info/2013/11/android-sliding-menu-using-navigation-drawer/ Now I am trying to add tabhost with frag

Solution 1:

I found and referred an awsm example called Balaji-K13 .

You can add whatever your list in here like:

Inside MainActivity.java

package com.webileapps.navdrawer;

import android.content.res.Configuration;
import android.os.Bundle;
import android.support.v4.app.ActionBarDrawerToggle;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;

import com.actionbarsherlock.app.SherlockFragment;
import com.actionbarsherlock.app.SherlockFragmentActivity;

publicclassMainActivityextendsSherlockFragmentActivity {
    DrawerLayout mDrawerLayout;
    ListView mDrawerList;
    ActionBarDrawerToggle mDrawerToggle;

    privateCharSequence mDrawerTitle;
    privateCharSequence mTitle;
    privateString[] mPlanetTitles;

    @OverrideprotectedvoidonCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mTitle = mDrawerTitle = getTitle();
        mPlanetTitles = getResources().getStringArray(R.array.planets_array);
        mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
        mDrawerList = (ListView) findViewById(R.id.left_drawer);

        // set a custom shadow that overlays the main content when the drawer// opens
        mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow,
                GravityCompat.START);
        // set up the drawer's list view with items and click listener
        mDrawerList.setAdapter(newArrayAdapter<String>(this,
                R.layout.drawer_list_item, mPlanetTitles));
        mDrawerList.setOnItemClickListener(newDrawerItemClickListener());

        // enable ActionBar app icon to behave as action to toggle nav drawergetSupportActionBar().setDisplayHomeAsUpEnabled(true);
        getSupportActionBar().setHomeButtonEnabled(true);

        // ActionBarDrawerToggle ties together the the proper interactions// between the sliding drawer and the action bar app icon
        mDrawerToggle = newActionBarDrawerToggle(this, /* host Activity */
        mDrawerLayout, /* DrawerLayout object */
        R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */
        R.string.drawer_open, /* "open drawer" description for accessibility */
        R.string.drawer_close/* "close drawer" description for accessibility */
        ) {
            publicvoidonDrawerClosed(View view) {
                getSupportActionBar().setTitle(mTitle);
                invalidateOptionsMenu(); // creates call to// onPrepareOptionsMenu()
            }

            publicvoidonDrawerOpened(View drawerView) {
                getSupportActionBar().setTitle(mDrawerTitle);
                invalidateOptionsMenu(); // creates call to// onPrepareOptionsMenu()
            }
        };
        mDrawerLayout.setDrawerListener(mDrawerToggle);

        if (savedInstanceState == null) {
            selectItem(0);
        }

    }

    @OverridepublicbooleanonCreateOptionsMenu(com.actionbarsherlock.view.Menu menu) {
        returnsuper.onCreateOptionsMenu(menu);
    }

    @OverridepublicbooleanonOptionsItemSelected(
            com.actionbarsherlock.view.MenuItem item) {

        switch (item.getItemId()) {

        case android.R.id.home: {
            if (mDrawerLayout.isDrawerOpen(mDrawerList)) {
                mDrawerLayout.closeDrawer(mDrawerList);
            } else {
                mDrawerLayout.openDrawer(mDrawerList);
            }
            break;
        }

        case R.id.action_contact:
            // QuickContactFragment dialog = new QuickContactFragment();// dialog.show(getSupportFragmentManager(), "QuickContactFragment");// return true;

        }

        returnsuper.onOptionsItemSelected(item);
    }

    // The click listener for ListView in the navigation drawerprivateclassDrawerItemClickListenerimplementsListView.OnItemClickListener {
        @OverridepublicvoidonItemClick(AdapterView<?> parent, View view, int position,
                long id) {
            selectItem(position);
        }
    }


    @OverrideprotectedvoidonPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        // Sync the toggle state after onRestoreInstanceState has occurred.
        mDrawerToggle.syncState();
    }

    @OverridepublicvoidonConfigurationChanged(Configuration newConfig) {
        super.onConfigurationChanged(newConfig);
        // Pass any configuration change to the drawer toggles
        mDrawerToggle.onConfigurationChanged(newConfig);
    }

    privatevoidselectItem(int position) {

        switch (position) {
        case0:
            getSupportFragmentManager()
                    .beginTransaction()
                    .add(R.id.content,
                            PageSlidingTabStripFragment.newInstance(),
                            PageSlidingTabStripFragment.TAG).commit();
            break;
        default:

            SherlockFragment fragment = newPlanetFragment();
            Bundle args = newBundle();
            args.putInt(PlanetFragment.ARG_PLANET_NUMBER, position);
            fragment.setArguments(args);

            getSupportFragmentManager().beginTransaction()
                    .add(R.id.content, fragment).commit();
            break;
        }

        mDrawerLayout.closeDrawer(mDrawerList);
    }



}

Inside PageSlidingTabStripFragment.java

package com.webileapps.navdrawer;

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

import com.actionbarsherlock.app.SherlockFragment;
import com.astuetz.PagerSlidingTabStrip;

publicclassPageSlidingTabStripFragmentextendsFragment {

    publicstaticfinalStringTAG= PageSlidingTabStripFragment.class
            .getSimpleName();

    publicstatic PageSlidingTabStripFragment newInstance() {
        returnnewPageSlidingTabStripFragment();
    }

    @OverridepublicvoidonCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setRetainInstance(true);
    }

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

    @OverridepublicvoidonViewCreated(View view, Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);

        PagerSlidingTabStriptabs= (PagerSlidingTabStrip) view
                .findViewById(R.id.tabs);
        ViewPagerpager= (ViewPager) view.findViewById(R.id.pager);
        MyPagerAdapteradapter=newMyPagerAdapter(getChildFragmentManager());
        pager.setAdapter(adapter);
        tabs.setViewPager(pager);

    }

    publicclassMyPagerAdapterextendsFragmentPagerAdapter {

        publicMyPagerAdapter(android.support.v4.app.FragmentManager fm) {
            super(fm);
        }

        privatefinal String[] TITLES = { "Categories", "Home", "Top Paid",
                "Top Free" };

        @Overridepublic CharSequence getPageTitle(int position) {
            return TITLES[position];
        }

        @OverridepublicintgetCount() {
            return TITLES.length;
        }

        @Overridepublic SherlockFragment getItem(int position) {
            return SuperAwesomeCardFragment.newInstance(position);
        }
    }
    }

Inside PlanetFragment.java

package com.webileapps.navdrawer;

import java.util.Locale;

import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import com.actionbarsherlock.app.SherlockFragment;

publicclassPlanetFragmentextendsSherlockFragment {
    publicstaticfinalStringARG_PLANET_NUMBER="planet_number";

    publicPlanetFragment() {
        // Empty constructor required for fragment subclasses
    }

    @Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        ViewrootView= inflater.inflate(R.layout.fragment_planet, container,
                false);
        inti= getArguments().getInt(ARG_PLANET_NUMBER);
        Stringplanet= getResources().getStringArray(R.array.planets_array)[i];

        intimageId= getResources().getIdentifier(
                planet.toLowerCase(Locale.getDefault()), "drawable",
                getActivity().getPackageName());
        ((ImageView) rootView.findViewById(R.id.image))
                .setImageResource(imageId);
        getActivity().setTitle(planet);
        return rootView;
    }
}

And finally SuperAwesomeCardFragment.java

package com.webileapps.navdrawer;

import android.os.Bundle;
import android.util.TypedValue;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import android.widget.FrameLayout.LayoutParams;
import android.widget.TextView;

import com.actionbarsherlock.app.SherlockFragment;

publicclassSuperAwesomeCardFragmentextendsSherlockFragment{

    privatestaticfinalStringARG_POSITION="position";

    privateint position;

    publicstatic SuperAwesomeCardFragment newInstance(int position) {
        SuperAwesomeCardFragmentf=newSuperAwesomeCardFragment();
        Bundleb=newBundle();
        b.putInt(ARG_POSITION, position);
        f.setArguments(b);
        return f;
    }

    @OverridepublicvoidonCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        position = getArguments().getInt(ARG_POSITION);
    }

    @Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

        LayoutParamsparams=newLayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);

        FrameLayoutfl=newFrameLayout(getActivity());
        fl.setLayoutParams(params);

        finalintmargin= (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 8, getResources()
                .getDisplayMetrics());

        TextViewv=newTextView(getActivity());
        params.setMargins(margin, margin, margin, margin);
        v.setLayoutParams(params);
        v.setLayoutParams(params);
        v.setGravity(Gravity.CENTER);
        v.setBackgroundResource(R.drawable.background_card);
        v.setText("CARD " + (position + 1));

        fl.addView(v);
        return fl;
    }

}

Hope this Helped :)

Post a Comment for "How To Add Tabhost In Navigation Drawer"