Android 使用片段将图像添加到选项卡

Android 使用片段将图像添加到选项卡,android,android-layout,android-fragments,android-xml,android-tabs,Android,Android Layout,Android Fragments,Android Xml,Android Tabs,我有3个不同的选项卡,每个选项卡都有文本。现在我想了解如何在选项卡的文本顶部添加可绘制的图像。我知道使用tabhosts可以做到这一点,但这已被弃用。我的班级如下: public class MainActivity extends FragmentActivity implements ActionBar.TabListener { private ViewPager viewPager; private TabsPagerAdapter mAdapter; private Acti

我有3个不同的选项卡,每个选项卡都有文本。现在我想了解如何在选项卡的文本顶部添加可绘制的图像。我知道使用tabhosts可以做到这一点,但这已被弃用。我的班级如下:

public class MainActivity extends FragmentActivity implements
    ActionBar.TabListener {

private ViewPager viewPager;
private TabsPagerAdapter mAdapter;
private ActionBar actionBar;
// Tab titles
private String[] tabs = { "Top Rated", "Games", "Movies" };

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    // Initilization
    viewPager = (ViewPager) findViewById(R.id.pager);
    actionBar = getActionBar();
    mAdapter = new TabsPagerAdapter(getSupportFragmentManager());

    viewPager.setAdapter(mAdapter);
    actionBar.setHomeButtonEnabled(false);
    actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);        

    // Adding Tabs
    for (String tab_name : tabs) {
        actionBar.addTab(actionBar.newTab().setText(tab_name)
                .setTabListener(this));
    }

    /**
     * on swiping the viewpager make respective tab selected
     * */
    viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {

        @Override
        public void onPageSelected(int position) {
            // on changing the page
            // make respected tab selected
            actionBar.setSelectedNavigationItem(position);
        }

        @Override
        public void onPageScrolled(int arg0, float arg1, int arg2) {
        }

        @Override
        public void onPageScrollStateChanged(int arg0) {
        }
    });
}

@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) {
}

@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
    // on tab selected
    // show respected fragment view
    viewPager.setCurrentItem(tab.getPosition());
}

@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) {
}
}请参见此链接:

示例代码:

actionBar.addTab(actionBar.newTab().setText(tab_name).setIcon(R.drawable.tab_icon).setTabListener(this));
但请考虑: 不推荐使用操作栏导航模式,内联工具栏操作栏不支持该模式。请考虑使用其他常见导航模式。 编辑: 对于您的代码,您可以执行以下操作:

创建图标,就像您为标题所做的那样:

// Tab titles
private String[] tabs = { "Top Rated", "Games", "Movies" };
//make sure this has the same length as tabs-array!
private int[] icons = {R.drawable.tab_rated, R.drawable.tab_games, R.drawable.tab_movies} 
并将它们添加到循环中:

// Adding Tabs
for (int i = 0; i < tabs.length; i++) {
   actionBar.addTab(actionBar.newTab().setText(tabs[i]).setIcon(icons[i]).setTabListener(this));
}
请参阅此链接:

示例代码:

actionBar.addTab(actionBar.newTab().setText(tab_name).setIcon(R.drawable.tab_icon).setTabListener(this));
但请考虑: 不推荐使用操作栏导航模式,内联工具栏操作栏不支持该模式。请考虑使用其他常见导航模式。 编辑: 对于您的代码,您可以执行以下操作:

创建图标,就像您为标题所做的那样:

// Tab titles
private String[] tabs = { "Top Rated", "Games", "Movies" };
//make sure this has the same length as tabs-array!
private int[] icons = {R.drawable.tab_rated, R.drawable.tab_games, R.drawable.tab_movies} 
并将它们添加到循环中:

// Adding Tabs
for (int i = 0; i < tabs.length; i++) {
   actionBar.addTab(actionBar.newTab().setText(tabs[i]).setIcon(icons[i]).setTabListener(this));
}

您好,您提供给我的代码有效。唯一的问题是,它将为所有选项卡指定相同的可绘制图标。我想知道如何为每个选项卡元素添加不同的drawable。然后将R.drawable.tab_图标更改为您喜欢的任何drawable。我会马上更新我的答案…您好,您提供给我的代码有效。唯一的问题是,它将为所有选项卡指定相同的可绘制图标。我想知道如何为每个选项卡元素添加不同的drawable。然后将R.drawable.tab_图标更改为您喜欢的任何drawable。我会马上更新我的答案。。。