8

Я пытаюсь использовать библиотеку поддержки дизайна для реализации вкладки. Вопрос заключается в том, что ViewPager перекрывает панель инструментов и tablayout, когда я удалить атрибутViewpager переполняет экран внутри координационного макета

app:layout_behavior="@string/appbar_scrolling_view_behavior" 

из ViewPager.

viewpager overlaps the toolbar and tablayout

и когда я добавить атрибут ViewPager переполняет экран.

viewpager overflows the screen

мне просто нужно ViewPager занять левый после tablayout пространства и панели инструментов, а не переполнять экран ...

Вот мой activity_main.xml

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
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:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" 
    > 

    <android.support.v7.widget.Toolbar 
     android:id="@+id/toolbar" 
     android:layout_width="match_parent" 
     android:layout_height="?attr/actionBarSize" 
     android:background="?attr/colorPrimary" 
     app:layout_scrollFlags="scroll|enterAlways" 
     app:popupTheme="@style/ThemeOverlay.AppCompat.Light" /> 

    <android.support.design.widget.TabLayout 
     android:id="@+id/tablayout" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     app:tabGravity="fill" 
     app:tabMode="fixed" /> 
    </android.support.design.widget.AppBarLayout> 

    <android.support.v4.view.ViewPager 
    android:id="@+id/viewpager" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 
</android.support.design.widget.CoordinatorLayout> 

и вот мой фрагмент_1.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:layout_weight="1" 
android:orientation="vertical" 
android:paddingBottom="@dimen/activity_vertical_margin" 
android:paddingLeft="@dimen/activity_horizontal_margin" 
android:paddingRight="@dimen/activity_horizontal_margin" 
android:paddingTop="@dimen/activity_vertical_margin"> 

    <TextView 
    android:id="@+id/tV_item1" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_marginTop="@dimen/activity_horizontal_margin" 
    android:gravity="center" 
    android:text="@string/tab1_q_persons" 
    android:textSize="20sp" 
    android:textStyle="bold" /> 

    <TextView 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:gravity="center" 
    android:text="0 people" 
    android:textSize="30sp" 
    android:textStyle="bold" /> 

    <ImageView 
    android:id="@+id/iV_plus" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" /> 

    <ImageView 
    android:id="@+id/iV_minus" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" /> 


    <RelativeLayout 
    android:layout_width="match_parent" 
    android:layout_height="0dp" 
    android:layout_weight="1"> 

    <Button 
     android:id="@+id/nextBtn" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     android:layout_alignParentRight="true" 
     android:layout_gravity="end" 
     android:background="@color/colorPrimary" 
     android:elevation="12dp" 
     android:text="@string/next" /> 

</RelativeLayout> 

</LinearLayout> 

Любая помощь будет оценена

ответ

0

Если вы на самом деле не нужен AppBar Layout, удалите его.

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:layout_width="match_parent" 
android:layout_height="match_parent"> 


    <android.support.v7.widget.Toolbar 
     android:id="@+id/toolbar" 
     android:layout_width="match_parent" 
     android:layout_height="?attr/actionBarSize" 
     android:background="?attr/colorPrimary" 
     app:layout_scrollFlags="scroll|enterAlways" 
     app:popupTheme="@style/ThemeOverlay.AppCompat.Light" /> 

    <android.support.design.widget.TabLayout 
     android:id="@+id/tablayout" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     app:tabGravity="fill" 
     app:tabMode="fixed" /> 

<android.support.v4.view.ViewPager 
    android:id="@+id/view_pager" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 

Этот код прекрасно работает для меня.

+1

Мне кажется, что мне нужна компоновка Appbar, в противном случае ** Панель инструментов и Tablayout ovwelaps **. –

+0

Добавить андроид: layout_below = "@ + id/toolbar" на вкладке TabLayout –

+0

вы можете рассказать мне, что является фактическим использованием добавления ** интерфейса Appbar **. Я читал, что это было похоже на ** Linearlayout **. –

1

Я знаю, что кажется поздно. Но я посылаю свой ответ.

В Activity_main.xml используйте RelativeLayout вместо CoordinatorLayout, и вы можете удалить AppBar. Для определения панели инструментов, как AppBar вы можете использовать этот код в MainActivity.java:

Toolbar mToolbar = (Toolbar) findViewById(R.id.toolbar); 
setSupportActionBar(mToolbar); 

При использовании fragment_1.xml другой виджет как CardView или ScrollView вместо LinearLayout или вы можете использовать LinearLayout внутри заменить виджет.

activity_main.xml

<RelativeLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:layout_width="match_parent" 
android:layout_height="match_parent"> 

    <android.support.v7.widget.Toolbar 
     android:id="@+id/toolbar" 
     android:layout_width="match_parent" 
     android:layout_height="?attr/actionBarSize" 
     android:background="?attr/colorPrimary" 
     app:layout_scrollFlags="scroll|enterAlways" 
     app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
     android:layout_alignParentTop="true"/> 

    <android.support.design.widget.TabLayout 
     android:id="@+id/tablayout" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     app:tabGravity="fill" 
     app:tabMode="fixed" 
     android:layout_below="@id/toolbar"/> 

    <android.support.v4.view.ViewPager 
    android:id="@+id/viewpager" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" 
    android:layout_below="@id/tablayout" /> 

</RelativeLayout> 

fragment_1.xml

<android.support.v7.widget.CardView 
    android:layout_height="match_parent" 
    android:layout_width="match_parent" 
    xmlns:android="http://schemas.android.com/apk/res/android"> 

<LinearLayout 

    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_weight="1" 
    android:orientation="vertical" 
    android:paddingBottom="@dimen/activity_vertical_margin" 
    android:paddingLeft="@dimen/activity_horizontal_margin" 
    android:paddingRight="@dimen/activity_horizontal_margin" 
    android:paddingTop="@dimen/activity_vertical_margin"> 

     <TextView 
     android:id="@+id/tV_item1" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:layout_marginTop="@dimen/activity_horizontal_margin" 
     android:gravity="center" 
     android:text="@string/tab1_q_persons" 
     android:textSize="20sp" 
     android:textStyle="bold" /> 

     <TextView 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:gravity="center" 
     android:text="0 people" 
     android:textSize="30sp" 
     android:textStyle="bold" /> 

     <ImageView 
     android:id="@+id/iV_plus" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" /> 

     <ImageView 
     android:id="@+id/iV_minus" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" /> 


     <RelativeLayout 
     android:layout_width="match_parent" 
     android:layout_height="0dp" 
     android:layout_weight="1"> 

     <Button 
      android:id="@+id/nextBtn" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_alignParentBottom="true" 
      android:layout_alignParentRight="true" 
      android:layout_gravity="end" 
      android:background="@color/colorPrimary" 
      android:elevation="12dp" 
      android:text="@string/next" /> 

    </RelativeLayout> 

    </LinearLayout> 
</android.support.v7.widget.CardView> 

Это решение решается та же проблема для меня.

Смежные вопросы