简体   繁体   English

ScrollView内部ViewPager无法正常工作

[英]ScrollView Inside ViewPager Not Working

i have an activity ViewPager and which have Tabbed Childs. 我有一个活动ViewPager和有Tabbed Childs。 The childs with recycler View do Scroll. 带回收者的孩子查看do Scroll。 Although When i create a simple fragment with scroll view it does not work. 虽然当我用滚动视图创建一个简单的片段时,它不起作用。 here is the main activity fragment - 这是主要的活动片段 -

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent" android:layout_height="match_parent"
android:id="@+id/tabbed_main"
android:background="#FFFFFF"
android:screenOrientation="portrait"
xmlns:fab="http://schemas.android.com/apk/res-auto">
<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:isScrollContainer="true"
        android:scrollbars="none">
        <android.support.v4.view.ViewPager
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/vp_horizontal_ntb"
            android:gravity="center"
            android:paddingLeft="0dp"
            android:paddingRight="0dp"
            android:isScrollContainer="true"
            app:layout_behavior="@string/appbar_scrolling_view_behavior" />
    </LinearLayout>
</RelativeLayout>

<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"
    android:fitsSystemWindows="true">
<com.gigamole.navigationtabbar.ntb.NavigationTabBar
    android:layout_width="match_parent"
    android:layout_height="60dp"
    android:id="@+id/ntb_horizontal"
    app:ntb_badge_size="12sp"
    app:ntb_badge_bg_color="#ffff0000"
    app:ntb_badge_gravity="top"
    app:ntb_badge_position="right"
    app:ntb_badge_title_color="#ffffffff"
    app:ntb_badge_use_typeface="true"
    app:ntb_badged="true"
    app:ntb_animation_duration="400" />
</LinearLayout>


<com.getbase.floatingactionbutton.FloatingActionsMenu
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom|end"
    android:id="@+id/create_new_button"
    android:layout_marginBottom="60dp"
    android:layout_marginRight="16dp"
    android:layout_marginEnd="16dp"
    fab:fab_addButtonColorNormal="@color/white_add"
    fab:fab_addButtonColorPressed="@color/white_pressed"
    fab:fab_addButtonPlusIconColor="@color/half_black"
    fab:fab_labelStyle="@style/menu_labels_style">
    <com.getbase.floatingactionbutton.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/action_create_post"
        fab:fab_colorNormal="@color/white_add"
        fab:fab_title="Create New Post"
        fab:fab_icon="@drawable/ic_create_black_24dp"
        fab:fab_colorPressed="@color/white_pressed"/>
    <com.getbase.floatingactionbutton.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/action_create_new_message"
        fab:fab_colorNormal="@color/white_add"
        fab:fab_title="Write New Message"
        fab:fab_icon="@drawable/ic_insert_comment_black_24dp"
        fab:fab_colorPressed="@color/white_pressed"/>
    <com.getbase.floatingactionbutton.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/action_upload_new_album"
        fab:fab_colorNormal="@color/white_add"
        fab:fab_title="Upload New Album"
        fab:fab_icon="@drawable/ic_add_a_photo_black_24dp"
        fab:fab_colorPressed="@color/white_pressed"/>
</com.getbase.floatingactionbutton.FloatingActionsMenu>

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

and here is the child fragment - 这是儿童片段 -

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingRight="22dp"
android:paddingLeft="22dp"
android:fillViewport="true"
android:focusableInTouchMode="true"
android:focusable="true"
android:scrollbars="none"
xmlns:tools="http://schemas.android.com/tools"
android:background="@drawable/main_background_blured"
android:isScrollContainer="true">
<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:isScrollContainer="true">
    <View
        android:layout_width="match_parent"
        android:layout_height="10dp"/>
    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:layout_margin="5dp"
        android:paddingTop="0dp"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        app:cardCornerRadius="4dp"
        app:cardElevation="8dp">
        <com.evolutionstudios.atmiyo.customfonts.RailwayRegular
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="SETTINGS"
            android:layout_gravity="center"
            android:gravity="center"
            android:textSize="25dp"
            android:textColor="@color/main_logo_color"/>
    </android.support.v7.widget.CardView>
    <View
        android:layout_width="match_parent"
        android:layout_height="10dp"/>
    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="5dp"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        app:cardCornerRadius="4dp"
        app:cardElevation="6dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Security"
                android:textColor="@color/half_black"
                android:paddingLeft="14dp"
                android:textSize="15dp"
                android:paddingTop="10dp"
                android:paddingBottom="3dp"/>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:src="@color/half_black"
                android:paddingLeft="10dp"
                android:paddingRight="10dp" />
            <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Change Password"
                android:paddingLeft="20dp"
                android:paddingTop="10dp"
                android:paddingBottom="5dp"
                android:textSize="18dp"
                android:textColor="@color/main_logo_color"/>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="1dp"
                android:src="@color/edward"
                android:paddingLeft="10dp"
                android:paddingRight="10dp"/>
            <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Change Default Email"
                android:paddingLeft="20dp"
                android:paddingTop="10dp"
                android:paddingBottom="10dp"
                android:textSize="18dp"
                android:textColor="@color/main_logo_color"/>
        </LinearLayout>
    </android.support.v7.widget.CardView>
    <View
        android:layout_width="match_parent"
        android:layout_height="10dp"/>
    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="5dp"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        app:cardElevation="6dp"
        app:cardCornerRadius="4dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="General"
                android:textSize="15dp"
                android:paddingLeft="14dp"
                android:paddingTop="10dp"
                android:paddingBottom="3dp"/>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:src="@color/half_black"
                android:paddingLeft="10dp"
                android:paddingRight="10dp" />
            <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Change Name"
                android:paddingLeft="20dp"
                android:paddingTop="10dp"
                android:paddingBottom="0dp"
                android:textSize="18dp"
                android:textColor="@color/main_logo_color"/>
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="SomeName"
                android:textSize="15dp"
                android:paddingLeft="20dp"
                android:paddingTop="0dp"
                android:paddingBottom="5dp"/>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="1dp"
                android:src="@color/edward"
                android:paddingLeft="10dp"
                android:paddingRight="10dp"/>
            <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Change Phone Number"
                android:paddingLeft="20dp"
                android:paddingTop="10dp"
                android:paddingBottom="0dp"
                android:textSize="18dp"
                android:textColor="@color/main_logo_color"/>
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="phone number"
                android:textSize="15dp"
                android:paddingLeft="20dp"
                android:paddingTop="0dp"
                android:paddingBottom="10dp"/>
        </LinearLayout>
    </android.support.v7.widget.CardView>
    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="5dp"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        app:cardElevation="6dp"
        app:cardCornerRadius="4dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Blocking"
                android:textSize="15dp"
                android:paddingLeft="14dp"
                android:paddingTop="10dp"
                android:paddingBottom="3dp"/>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:src="@color/half_black"
                android:paddingLeft="10dp"
                android:paddingRight="10dp" />
            <RelativeLayout
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:paddingBottom="5dp">
                <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Blocking"
                    android:paddingLeft="20dp"
                    android:paddingTop="10dp"
                    android:paddingBottom="0dp"
                    android:textSize="18dp"
                    android:layout_alignParentStart="true"
                    android:textColor="@color/main_logo_color" />
                <com.cengalabs.flatui.views.FlatToggleButton
                    android:layout_width="60dp"
                    android:layout_height="22dp"
                    android:layout_alignParentEnd="true"
                    xmlns:flat="http://schemas.android.com/apk/res-auto"
                    flat:fl_space="14dp"
                    flat:fl_cornerRadius="14dp"
                    flat:fl_size="50dp"
                    android:layout_marginTop="10dp"
                    android:layout_marginRight="10dp"
                    flat:fl_theme="@array/grass"/>
            </RelativeLayout>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="1dp"
                android:src="@color/edward"
                android:paddingLeft="10dp"
                android:paddingRight="10dp"/>
            <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Block List"
                android:paddingLeft="20dp"
                android:paddingTop="10dp"
                android:paddingBottom="10dp"
                android:textSize="18dp"
                android:textColor="@color/main_logo_color"/>
        </LinearLayout>
    </android.support.v7.widget.CardView>
    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="5dp"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        app:cardElevation="6dp"
        app:cardCornerRadius="4dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Language"
                android:textSize="15dp"
                android:paddingLeft="14dp"
                android:paddingTop="10dp"
                android:paddingBottom="3dp"/>
            <ImageView
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:src="@color/half_black"
                android:paddingLeft="10dp"
                android:paddingRight="10dp" />
            <com.evolutionstudios.atmiyo.customfonts.RailwayLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Change Language"
                android:paddingLeft="20dp"
                android:paddingTop="10dp"
                android:paddingBottom="0dp"
                android:textSize="18dp"
                android:textColor="@color/main_logo_color"/>
            <com.evolutionstudios.atmiyo.customfonts.TrilliumWebLight
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="SomeLanguage"
                android:textSize="15dp"
                android:paddingLeft="20dp"
                android:paddingTop="0dp"
                android:paddingBottom="10dp"/>
        </LinearLayout>

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

i have tried with a lot of answers here like here , here also and here too 我在这里尝试了很多答案,在这里也在 这里

as someone pointed to use NestedScrollView instead ScrollView and i tried that too, but with no luck. 有人指出使用NestedScrollView而不是ScrollView,我也试过,但没有运气。 Any solutions? 有解决方案吗

I managed to solve a similar vertical scrolling problem in my ViewPager doing the following: 我设法在我的ViewPager中解决类似的垂直滚动问题,执行以下操作:

  1. I created a separate layout (content_event) with ViewPager: 我使用ViewPager创建了一个单独的布局(content_event):

     <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v4.view.ViewPager android:id="@+id/viewPagerActivEvent" android:layout_width="match_parent" android:layout_height="wrap_content" app:layout_behavior="@string/appbar_scrolling_view_behavior"> </android.support.v4.view.ViewPager> </RelativeLayout> 
  2. And created NestedScrollView enclosing preceding layout with "android:fillViewport" set to true: 并创建了嵌套前面布局的NestedScrollView,其中“android:fillViewport”设置为true:

     <android.support.v4.widget.NestedScrollView android:layout_width="match_parent" android:layout_height="match_parent" android:fillViewport="true" app:layout_behavior="@string/appbar_scrolling_view_behavior" > <include layout="@layout/content_event" > </android.support.v4.widget.NestedScrollView> 

Maybe it's not quite right but worked for me:) 也许这不太对,但为我工作:)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM