如何为可滑动标签添加图标

Posted

技术标签:

【中文标题】如何为可滑动标签添加图标【英文标题】:how to add the icon for swipeable tabs 【发布时间】:2014-02-27 00:25:12 【问题描述】:

我正在从here 下载代码我想显示带有图标的选项卡如何可能请帮助我。

 public class MainActivity extends FragmentActivity implements
            ActionBar.TabListener 

    private ViewPager viewPager;
    private TabsPagerAdapter mAdapter;
    private ActionBar actionBar;
    // Tab titles
    private String[] tabs =  "Text", "Photo", "Record" ,"Tag";


    @TargetApi(Build.VERSION_CODES.HONEYCOMB)
    @SuppressLint("NewApi")
    @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());

        final int[] ICONS = new int[] 
            R.drawable.ic_launcher,
            R.drawable.ic_launcher,
            R.drawable.ic_launcher,
            R.drawable.ic_launcher,
    ;

        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) 
    


【问题讨论】:

【参考方案1】:

如果您使用的是TabLayout,只需执行此操作(此示例使用三个选项卡):

 //An array containing your icons from the drawable directory
 final int[] ICONS = new int[]
            R.drawable.icon_1,
            R.drawable.icon_2,
            R.drawable.icon_3
    ;

    //Get reference to your Tablayout
    TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
    tabLayout.setupWithViewPager(mViewPager);

    tabLayout.getTabAt(0).setIcon(ICONS[0]);
    tabLayout.getTabAt(1).setIcon(ICONS[1]);
    tabLayout.getTabAt(2).setIcon(ICONS[2]);

【讨论】:

谢谢!这个对我有用。其他相关 SO 问题的解决方案标记为“已弃用”。【参考方案2】:

在你的 for 循环中添加 .setIcon(resources.getDrawable(DrawableIDHere)),并稍微改变你的 for 循环。

// Adding Tabs
for (int i=0; i < tabs.length; i++)

actionBar.addTab(actionBar.newTab().setText(tabs[i])
                         .setIcon(resources.getDrawable(ICONS[i]))
                         .setTabListener(this));
//endfor

另外,不要忘记将正确的可绘制 ID 放入您的 ICONS 数组中!

【讨论】:

.setIcon(resources.GetDrwable(ICONS[i])) 资源无法解析错误..这是什么?? 你需要改用getResources()【参考方案3】:
// here you add an array of your icon   
 final int[] ICONS = new int[] 
                    R.drawable.ic_launcher,
                    R.drawable.ic_launcher,
                    R.drawable.ic_launcher,
                    R.drawable.ic_launcher,
            ;

    // add this following code to solve your problem
    // here NewsFeedActivity.this.getResources() is used to get the drawable folder resource
    // instead of NewsFeedActivity you have to use your activity name here  
    for (int i=0; i < tabs.length; i++)
            
            actionBar.addTab(actionBar.newTab().setText(tabs[i])
                                     .setIcon(NewsFeedActivity.this.getResources().getDrawable(ICONS[i]))
                                     .setTabListener(this));
            //endfor

【讨论】:

我在代码中添加了注释,这是我在堆栈溢出中的第一条注释。 我认为代码很容易解释并且代码注释很好。感谢您的提交。【参考方案4】:

您好,请查看ViewPagerIndicator 库。

这是可滑动标签的一个很好的例子。

【讨论】:

以上是关于如何为可滑动标签添加图标的主要内容,如果未能解决你的问题,请参考以下文章

如何为按钮右侧添加图像/图标?

VC6.0程序编译后如何为程序添加图标

如何将动画设置为滑动菜单图标

如何为你的网站添加标志性的图标(头像)呢?

如何更改ios7中非活动标签栏图标的颜色?

如何为应用程序自定义 iPad 图标主屏幕?