Search code examples
androidandroid-fragmentsandroid-tabhostandroid-nested-fragment

Android Error : No Tab known for Null Tag


I need a fixed area (around 20%) at top and then 3 tabs below it. The xml is

mylist.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.2"
        android:orientation="vertical" >

        <View
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.05"
            android:visibility="invisible" />

        <TextView
            android:id="@+id/list_name"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.3"
            android:textColor="@color/loclistitem_text"
            android:textStyle="bold" />

        <TextView
            android:id="@+id/list_spec"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.3" />

        <View
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.1"
            android:visibility="invisible" />

        <TextView
            android:id="@+id/list_user"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.2" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.8"
        android:orientation="horizontal" >

        <View
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="0.05"
            android:visibility="invisible" />

        <FrameLayout
            android:id="@+id/list_realtabcontent"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="0.95" />

        <View
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="0.05"
            android:visibility="invisible" />
    </LinearLayout>

    <android.support.v4.app.FragmentTabHost
        android:id="@android:id/tabhost"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#CCF8FB" >

        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="0dip"
            android:layout_height="0dip"
            android:layout_weight="0" />
    </android.support.v4.app.FragmentTabHost>

</LinearLayout>

MyListFragment.java

    public class MyListFragment extends Fragment {

        private FragmentTabHost mTabHost;

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                Bundle savedInstanceState) {
            // TODO Auto-generated method stub

            View rootView = inflater.inflate(R.layout.mylist, container,
                    false);
            TextView name = (TextView) rootView.findViewById(R.id.list_name);
            TextView spec = (TextView) rootView.findViewById(R.id.loc_spec);
            TextView users = (TextView) rootView.findViewById(R.id.list_user);
            name.setText(AppSession.getInstance().getData().getName());
            mTabHost = new FragmentTabHost(getActivity());

            mTabHost.setup(getActivity(), getChildFragmentManager(),
                    R.id.list_realtabcontent);

            Bundle arg1 = new Bundle();
            arg1.putInt("Tab1", 1);

            mTabHost.addTab(
                    mTabHost.newTabSpec("Tab1").setIndicator("Tab1",
                            getResources().getDrawable(R.drawable.tab_left)),
                    Tab1.class, arg1);

            Bundle arg2 = new Bundle();
            arg2.putInt("Tab2", 2);
            mTabHost.addTab(
                    mTabHost.newTabSpec("Tab2").setIndicator("Tab2",
                            getResources().getDrawable(R.drawable.tab_middle)),
                    Tab2.class, arg2);

            Bundle arg3 = new Bundle();
            arg3.putInt("Tab3", 3);
            mTabHost.addTab(
                    mTabHost.newTabSpec("Tab3").setIndicator("Tab3",
                            getResources().getDrawable(R.drawable.tab_rigth)),
                    Tab3Fragment.class, arg2);

            return rootView;

        }

        @Override
        public void onDetach() {
            super.onDetach();

            try {
                Field childFragmentManager = Fragment.class
                        .getDeclaredField("mChildFragmentManager");
                childFragmentManager.setAccessible(true);
                childFragmentManager.set(this, null);

            } catch (NoSuchFieldException e) {
                throw new RuntimeException(e);
            } catch (IllegalAccessException e) {
                throw new RuntimeException(e);
            }
        }

    }

I get "No Tab known for Tag null" at android.support.v4.app.FragmentTabHost.doTabChanged.

The error is resolved if I change return rootView to return mTabHost. But then the fixed area at top isn't showing. Its only displaying 3 tabs at the top of the screen. I tried using Activity to set this particular screen and it worked fine(both fixed area at top and tabs are displayed correctly) but I need it using fragments as I am using Navigation Drawer so this has to be fragment. Please advice.

Modified xml

xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/tabhost"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#CCF8FB" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:orientation="vertical" >

        <TextView
            android:id="@+id/loc_playlist_locname"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.2" />

        <FrameLayout
            android:id="@+id/playlist_realtabcontent"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="0.1" />

        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="0dip"
            android:layout_height="0dip"
            android:layout_weight="0" />
    </LinearLayout>

</android.support.v4.app.FragmentTabHost>

Solution

  • I made a few changes to your code: - In implementation, use the FragmentTabHost specified in layout - Use Framelayout specified within FragmentTabHost Element in layout in TabHost setup method. It seems to work, check out code below:

    XML file:

        <?xml version="1.0" encoding="utf-8"?>
        <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >
        <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.2"
        android:orientation="vertical" >
        <View
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.05"
        android:visibility="invisible" />
        <TextView
        android:id="@+id/list_name"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.3"
        android:textStyle="bold" />
        <TextView
        android:id="@+id/list_spec"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.3" />
       <View
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.1"
        android:visibility="invisible" />
        <TextView
        android:id="@+id/list_user"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.2" />
        </LinearLayout>
        <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="0.8"
        android:orientation="horizontal" >
        <View
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="0.05"
        android:visibility="invisible" />
       <View
       android:layout_width="0dp"
       android:layout_height="match_parent"
       android:layout_weight="0.05"
       android:visibility="invisible" />
       </LinearLayout>
       <android.support.v4.app.FragmentTabHost
       android:id="@+id/tabhost"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       android:background="#CCF8FB" >
       <FrameLayout
       android:id="@+id/list_realtabcontent"
       android:layout_width="0dp"
       android:layout_height="match_parent"
       android:layout_weight="0.95" />
       </android.support.v4.app.FragmentTabHost>
       </LinearLayout>
    

    Fragment Class:

        public class MyListFragment extends Fragment {
    
            private FragmentTabHost mTabHost;
    
            @Override
            public View onCreateView(LayoutInflater inflater, ViewGroup container,
                    Bundle savedInstanceState) {
                // TODO Auto-generated method stub
    
                View rootView = inflater.inflate(R.layout.activity_main, container,
                        false);
                TextView name = (TextView) rootView.findViewById(R.id.list_name);
                TextView spec = (TextView) rootView.findViewById(R.id.list_spec);
                TextView users = (TextView) rootView.findViewById(R.id.list_user);
                mTabHost = (FragmentTabHost)rootView.findViewById(R.id.tabhost);
    
                mTabHost.setup(getActivity(), getChildFragmentManager(),
                        R.id.list_realtabcontent);
    
                Bundle arg1 = new Bundle();
                arg1.putInt("Tab1", 1);
    
                mTabHost.addTab(
                       mTabHost.newTabSpec("Tab1").setIndicator("Tab1",
                                getResources().getDrawable(R.drawable.tab_chat_unselected)),
                          TabFragment.class, arg1);
    
                Bundle arg2 = new Bundle();
                arg2.putInt("Tab2", 2);
                mTabHost.addTab(
                        mTabHost.newTabSpec("Tab2").setIndicator("Tab2",
                                getResources().getDrawable(R.drawable.tab_chat_unselected)),
                        TabFragment.class, arg2);
    
                Bundle arg3 = new Bundle();
                arg3.putInt("Tab3", 3);
                mTabHost.addTab(
                        mTabHost.newTabSpec("Tab3").setIndicator("Tab3",
                                getResources().getDrawable(R.drawable.tab_chat_unselected)),
                        TabFragment.class, arg3);
    
                return rootView;
    
            }