添加自定义视图到选项卡

时间:2014-08-29 16:21:05

标签: android

我想为我的标签添加自定义视图。我研究了互联网,但我找不到好的教程。我在onCreate事件中添加了此代码的标签。

        private String[] tabs = { "Tab 1", "Tab 2"};
        for (String tab_name : tabs) {
            actionBar.addTab(actionBar.newTab().setText(tab_name)
                    .setTabListener(this));
        }

我没有任何标签的xml文件。

我该怎么做?你能举个例子吗?

1 个答案:

答案 0 :(得分:1)

首先我建议您使用:

https://developer.android.com/samples/SlidingTabsBasic/src/com.example.android.common/view/SlidingTabLayout.html

并且不要使用操作栏标签。

这是google play app标签的源代码。 之后,您可以使用mSlidingTabLayout.setCustomTabView(int layoutResId, int textViewId)创建自己的布局,为SlidingTabLayout选项卡视图扩展自定义布局。看看:

Android SlidingTabLayout with icons

完整的例子。

<?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">

    <com.example.android.common.view.SlidingTabLayout
          android:id="@+id/sliding_tabs"
          android:layout_width="match_parent"
          android:layout_height="wrap_content" />

    <android.support.v4.view.ViewPager
          android:id="@+id/viewpager"
          android:layout_width="match_parent"
          android:layout_height="0px"
          android:layout_weight="1"
          android:background="@android:color/white"/>

</LinearLayout>

以及fragmentactivity

mViewPager = (ViewPager) view.findViewById(R.id.viewpager);
mViewPager.setAdapter(new MyAdapter());
mSlidingTabLayout = (SlidingTabLayout) view.findViewById(R.id.sliding_tabs);
mSlidingTabLayout.setViewPager(mViewPager);

mViewPager的适配器必须覆盖以下方法

 @Override
        public CharSequence getPageTitle(int position) {
            return your tab title;
        }

<强>更新

第一步是为每个标签创建自定义布局:

     <?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/text1"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:gravity="center_vertical"
    android:paddingLeft="6dip"
    android:minHeight="?android:attr/listPreferredItemHeight"
/>

然后,当您想要向操作栏添加标签时,您必须执行以下操作:

    ActionBar.Tab tab1=actionBar.newTab();
    tab1.setTabListener(this);
    tab1.setCustomView(R.layout.tab);
    TextView txt1 = (TextView)tab1.getCustomView().findViewById(R.id.text1);
    txt1.setText("Tab 1");