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”
,它们会。我认为它们在这两种情况下都会扩展。谢谢你的回答。”