我在嵌套滚动视图中有一个viewpager,它可能包含或可能不包含数据。如果确实包含数据,则为分页的两列交错网格视图。我希望能够向下滚动到足够远的位置,以完全隐藏上面的视图,并且可以全屏滚动显示回收站视图。我的问题是一旦加载数据,我只能滚动多一点。看起来嵌套滚动范围扩大了在回收器视图中出现的第一项的高度。有什么我想念的吗?
在哪里当回收器视图中的项目加载时,整个视图是可滚动的,但是滚动范围仅扩展到第一个项目的高度。回收站加载后,我希望能够滚动到标签顶部:
我只是对这里发生的事情感到困惑。
这是该视图的xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/comment_layout_root"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/card_background">
<android.support.v4.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_above="@+id/comment_footer"
android:scrollbars="none">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<RelativeLayout
android:id="@+id/image_frame"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/collection_image"
android:layout_width="match_parent"
android:layout_height="@dimen/item_detail_container_height"
android:background="@color/color_black"
android:scaleType="centerCrop"
android:layout_centerInParent="true"
/>
<Button
style="@style/Button.LightPurple.Inverse"
android:id="@+id/edit_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginTop="10dp"
android:layout_marginLeft="10dp"
android:text="@string/collection_edit"
android:visibility="gone"
/>
</RelativeLayout>
<include layout="@layout/item_detail_multi_nav_layout" />
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/color_list_divider" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:orientation="vertical">
<TextView
android:id="@+id/collection_title"
android:layout_width="397dp"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginTop="@dimen/body_font_padding"
android:gravity="center_vertical"
android:text="@string/live_action_item_name"
android:textColor="@color/on_board_clubs_join_btn"
android:textSize="18sp" />
<TextView
android:id="@+id/collection_description"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginTop="@dimen/body_font_padding"
android:autoLink="web"
android:gravity="center_vertical"
android:maxLines="3"
android:text="@string/medal_item_description_placeholder"
android:textColor="@color/color_dark_gray"
android:textSize="14sp" />
<TextView
android:id="@+id/collection_item_count"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginTop="@dimen/body_font_padding"
android:gravity="center_vertical"
android:text="@string/item_collection_count"
android:textAppearance="@style/TextAppearance.Large.Black.MontserratSemiBold"
android:textColor="@color/search_follow_button"
android:textSize="12sp" />
<TextView
android:id="@+id/collection_uploadedby"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginBottom="@dimen/body_font_padding"
android:layout_marginTop="15dp"
android:gravity="center_vertical"
android:text="@string/item_uploaded_by"
android:textAppearance="@style/TextAppearance.Large.Black.Montserrat" />
<include layout="@layout/action_feed_header_for_uploadedby" />
</LinearLayout>
<android.support.design.widget.TabLayout
android:id="@+id/tab_picker"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_gravity="center"
android:elevation="0dp"
app:tabPaddingStart="5dp"
app:tabPaddingEnd="5dp"
app:tabMinWidth="0dp"
app:tabIndicatorColor="@color/colorAccent"
app:tabIndicatorHeight="4dp"
app:tabMode="scrollable"
app:tabSelectedTextColor="@color/bpDark_gray"
app:tabTextAppearance="@android:style/TextAppearance.Widget.TabWidget"
app:tabTextColor="@color/bpWhite" />
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/color_list_divider" />
<com.gemr.android.widgets.misc.WrapContentViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/card_background"
android:nestedScrollingEnabled="false"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
</LinearLayout>
</android.support.v4.widget.NestedScrollView>
<LinearLayout
android:id="@+id/comment_footer"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_gravity="bottom"
android:background="@color/card_background"
android:orientation="vertical">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/color_list_divider" />
<LinearLayout
android:id="@+id/comment_box_layout"
style="@style/comment_box_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/bpWhite"
android:orientation="horizontal">
<EditText
android:id="@+id/comment_box"
style="@style/comment_box_text"
android:layout_width="0dp"
android:layout_height="@dimen/comment_text_box_height"
android:layout_gravity="center_vertical"
android:layout_weight="1"
android:background="@drawable/edit_text_post"
android:gravity="center_vertical"
android:hint="@string/comment_box_hint"
android:inputType="textCapSentences|textMultiLine"
android:maxLines="3"
android:selectAllOnFocus="true" />
<TextView
android:id="@+id/comment_post"
android:layout_width="wrap_content"
android:layout_height="35dp"
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:background="@drawable/card_view_selector"
android:gravity="center_vertical"
android:padding="4dp"
android:text="@string/comment_post"
android:textAppearance="@style/TextAppearance.Large.Gray.Montserrat" />
</LinearLayout>
</LinearLayout>
这是用寻呼机设置的RecyclerView:
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/card_background">
<android.support.v4.widget.SwipeRefreshLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipeContainer"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.RecyclerView
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/feed_recycler"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:itemCount="3"/>
</android.support.v4.widget.SwipeRefreshLayout>
<include layout="@layout/fab_layout" />
我在这里可以忽略一些简单的东西吗?
答案 0 :(得分:0)
尝试一下,这可能会对您有所帮助
public class CustomNestedScrollView extends NestedScrollView {
private int slop;
private float mInitialMotionX;
private float mInitialMotionY;
public CustomNestedScrollView(Context context) {
super(context);
init(context);
}
private void init(Context context) {
ViewConfiguration config = ViewConfiguration.get(context);
slop = config.getScaledEdgeSlop();
}
public CustomNestedScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context);
}
public CustomNestedScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context);
}
private float xDistance, yDistance, lastX, lastY;
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
final float x = ev.getX();
final float y = ev.getY();
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
xDistance = yDistance = 0f;
lastX = ev.getX();
lastY = ev.getY();
// This is very important line that fixes
computeScroll();
break;
case MotionEvent.ACTION_MOVE:
final float curX = ev.getX();
final float curY = ev.getY();
xDistance += Math.abs(curX - lastX);
yDistance += Math.abs(curY - lastY);
lastX = curX;
lastY = curY;
if (xDistance > yDistance) {
return false;
}
}
return super.onInterceptTouchEvent(ev);
}
}
答案 1 :(得分:0)
问题是Recyclerview
设置为match_parent
。因为它的大小等于屏幕大小减去NestedScrollView
组合中所有其他内容的大小。
在需要整个屏幕包含NestedScrollView
中其他内容的设备中,Recyclerview
的大小将为偶数。
步骤1:
将Recyclerview
及其父级(SwipeRefreshLayout
和FrameLayout
)的高度更改为wrap_content
。
步骤2:
如果无法按预期工作,请将固定大小设置为Recyclerview
(仅设置为Recyclerview
,而父项应保持wrap_content
)。
第3步:
如果您希望它与提供的图像完全一样,我认为您需要在运行时计算大小。在这种情况下,您可以撤消步骤2。
答案 2 :(得分:0)
为什么不尝试将Coordinate Layout和AppBarLayout结合使用以实现此目的。它要简单得多。您可以检查此链接以获取不同的滚动条。
https://github.com/codepath/android_guides/wiki/Handling-Scrolls-with-CoordinatorLayout
此链接准确显示了您想要实现的目标