Java 这些标签不会填满表格

Java 这些标签不会填满表格,java,android,Java,Android,选项卡不会像这样填充选项卡布局 当每个tab==max width/2 主要活动java: ViewPager mviewPager = (ViewPager)findViewById(R.id.pager); mviewPager.setAdapter(new viewpager(getSupportFragmentManager(),MainActivity.this)); tabLayout = (TabLayout) findViewById(R.id.sliding_

选项卡不会像这样填充选项卡布局

当每个
tab==max width/2

主要活动java:

ViewPager mviewPager = (ViewPager)findViewById(R.id.pager);
    mviewPager.setAdapter(new viewpager(getSupportFragmentManager(),MainActivity.this));

    tabLayout = (TabLayout) findViewById(R.id.sliding_tabs);
    tabLayout.setupWithViewPager(mviewPager);
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/Colorprimary"
    android:elevation="4dp"
    android:id="@+id/my_tool_bar"
   />

<android.support.design.widget.TabLayout
    android:id="@+id/sliding_tabs"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:tabMode="scrollable"
    />

</android.support.design.widget.AppBarLayout>

<android.support.v4.view.ViewPager
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/pager"
    android:layout_weight="1"
    />
    package com.example.smite.floater;


import android.content.Context;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.widget.Switch;

public class viewpager extends FragmentPagerAdapter {

    final int fragments_counter=2;
    private String titles[] = new String[]{"main","creator"};
    private Context context;

    public viewpager(FragmentManager fm , Context context){
        super(fm);
        this.context = context;
    }

    @Override
    public int getCount() {
        return fragments_counter;
    }

    @Override
    public Fragment getItem(int position) {
        switch (position){

            case 0:
                return new main();
            case 1:
                default:
                return new creator();
        }
    }

    @Override
    public CharSequence getPageTitle(int position) {
        // Generate title based on item position
        return titles[position];
    }

}
主要活动xml:

ViewPager mviewPager = (ViewPager)findViewById(R.id.pager);
    mviewPager.setAdapter(new viewpager(getSupportFragmentManager(),MainActivity.this));

    tabLayout = (TabLayout) findViewById(R.id.sliding_tabs);
    tabLayout.setupWithViewPager(mviewPager);
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/Colorprimary"
    android:elevation="4dp"
    android:id="@+id/my_tool_bar"
   />

<android.support.design.widget.TabLayout
    android:id="@+id/sliding_tabs"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:tabMode="scrollable"
    />

</android.support.design.widget.AppBarLayout>

<android.support.v4.view.ViewPager
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/pager"
    android:layout_weight="1"
    />
    package com.example.smite.floater;


import android.content.Context;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.widget.Switch;

public class viewpager extends FragmentPagerAdapter {

    final int fragments_counter=2;
    private String titles[] = new String[]{"main","creator"};
    private Context context;

    public viewpager(FragmentManager fm , Context context){
        super(fm);
        this.context = context;
    }

    @Override
    public int getCount() {
        return fragments_counter;
    }

    @Override
    public Fragment getItem(int position) {
        switch (position){

            case 0:
                return new main();
            case 1:
                default:
                return new creator();
        }
    }

    @Override
    public CharSequence getPageTitle(int position) {
        // Generate title based on item position
        return titles[position];
    }

}
我的应用程序主题父项是
parent=“theme.AppCompat.Light.NoActionBar”

感谢您的帮助(:

如果您在“app:tabMode=”scrollable“中放置一行,那么tablayout宽度将不会填满整个屏幕。最好的解决方案是这样。 将这行放在XML中

    app:tabMode="fixed"
在Java中,您可以

    if(tabLayout.getTabCount() > MAX_NUMBER) {
       tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE);
    }
MAX_NUMBER是根据您的要求而定的数字。我使用了3,您可以使用3,4或任何适合您要求的数字。 这将确保如果只有几个选项卡,它们将占据整个宽度,如果没有,则可以滚动。

如果您将行
“app:tabMode=“scrollable”
,则tablayout宽度将不会填满整个屏幕。最好的解决方案是这样。 将这行放在XML中

    app:tabMode="fixed"
在Java中,您可以

    if(tabLayout.getTabCount() > MAX_NUMBER) {
       tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE);
    }
MAX_NUMBER是根据您的要求而定的数字。我使用了3,您可以使用3,4或任何适合您要求的数字。
这将确保如果只有几个选项卡,它们将占据整个宽度,如果没有,则可以滚动。

如果谷歌有自己的支持库,则可以使用PagerSlidingTastrip。如果有疑问,请咨询:。如果删除
app:tabMode=“scrollable”,会发生什么情况
@guy1820您找到问题的答案了吗?下面的答案对您有帮助吗?您可以使用PagerSlidingTastrip如果Google有自己的支持库,请不要使用
PagerSlidingTastrip
。如有疑问,请咨询:。如果您删除
app:tabMode=“scrollable”,会发生什么情况
@guy1820您的问题得到答案了吗?下面的答案对您有帮助吗?如果这个答案对您有帮助,请将其标记为已接受。如果没有,请让我了解更多有关此问题的信息。您的答案帮助我解决了选项卡未填充选项卡布局的相同问题。因此,这意味着如果我将
应用程序:tabMode=“可滚动
且宽度更大,选项卡不会扩展到整个宽度。但如果我将
app:tabMode=“固定”
他们会的。我想他们在这两种情况下都会扩展。谢谢你的回答。如果这个答案对你有帮助,请将其标记为接受。如果没有,请让我了解更多关于这个问题的信息。你的回答帮助我解决了标签不填充标签布局的问题。因此,这意味着如果我把
应用程序:tabMode=“可滚动
且宽度更大,选项卡不会扩展到整个宽度。但如果我放置
app:tabMode=“fixed”
,它们会。我认为它们在这两种情况下都会扩展。谢谢你的回答。”