【问题标题】:Set Custom List view inside NestedScrollView在 NestedScrollView 中设置自定义列表视图
【发布时间】:2015-11-02 16:47:39
【问题描述】:

我正在转向 Coordinator Layout 和 Nested ScrollView,我知道要让它工作,我需要使用 recycle r 视图,但问题是我真的想用旧的列表视图来实现它有什么办法可以实现

这就是我正在做的事情

<?xml version="1.0" encoding="utf-8"?>

<!-- NOT SET HERE:  android:fitsSystemWindows="true" -->
<android.support.design.widget.AppBarLayout
    android:id="@+id/appbar"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    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:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        app:layout_collapseMode="pin"
        app:layout_scrollFlags="scroll|enterAlways"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
</android.support.design.widget.AppBarLayout>

<android.support.v4.widget.NestedScrollView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fillViewport="true"
    android:layout_gravity="fill_vertical"
    app:behavior_overlapTop="32dp"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

    <LinearLayout
        android:id="@+id/ll_main_container"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <com.felipecsl.asymmetricgridview.library.widget.AsymmetricGridView xmlns:android="http://schemas.android.com/apk/res/android"
            android:id="@+id/listView"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="#ffffff"
            android:divider="@android:color/transparent"
            android:dividerHeight="3dp"
            android:fadingEdge="horizontal"
            android:focusable="false"
            android:gravity="center"
            android:listSelector="#00000000" />
    </LinearLayout>

</android.support.v4.widget.NestedScrollView>

我也用过

android:fillViewport="true"

但这会扩展我的列表视图以匹配父级,但现在没有滚动

请帮帮我 我真的需要使用自定义列表视图

我们将不胜感激。

提前感谢。

【问题讨论】:

  • Google 推荐 RecyclerView。我建议你不要逆流而行......
  • 但我真的非常非常需要使用列表视图

标签: android android-recyclerview android-coordinatorlayout nestedscrollview


【解决方案1】:

如果确实需要使用 ListView,可以在自定义 ListView 上实现 NestedScrollingChild。

以下应该有效:

public class NestedScrollingListView extends ListView implements NestedScrollingChild {

private final NestedScrollingChildHelper mScrollingChildHelper;

public NestedScrollingListView(Context context) {
   super(context);
   mScrollingChildHelper = new NestedScrollingChildHelper(this);
   setNestedScrollingEnabled(true);
}

public NestedScrollingListView(Context context, AttributeSet attrs) {
   super(context, attrs);
   mScrollingChildHelper = new NestedScrollingChildHelper(this);
   setNestedScrollingEnabled(true);
}

@Override
public void setNestedScrollingEnabled(boolean enabled) {
   mScrollingChildHelper.setNestedScrollingEnabled(enabled);
}

@Override
public boolean isNestedScrollingEnabled() {
   return mScrollingChildHelper.isNestedScrollingEnabled();
}

@Override
public boolean startNestedScroll(int axes) {
   return mScrollingChildHelper.startNestedScroll(axes);
}

@Override
public void stopNestedScroll() {
    mScrollingChildHelper.stopNestedScroll();
}

@Override
public boolean hasNestedScrollingParent() {
    return mScrollingChildHelper.hasNestedScrollingParent();
}

@Override
public boolean dispatchNestedScroll(int dxConsumed, int dyConsumed, int dxUnconsumed,
                                int dyUnconsumed, int[] offsetInWindow) {
    return mScrollingChildHelper.dispatchNestedScroll(dxConsumed, dyConsumed,
        dxUnconsumed, dyUnconsumed, offsetInWindow);
}

@Override
public boolean dispatchNestedPreScroll(int dx, int dy, int[] consumed, int[] offsetInWindow) {
    return mScrollingChildHelper.dispatchNestedPreScroll(dx, dy, consumed, offsetInWindow);
}

@Override
public boolean dispatchNestedFling(float velocityX, float velocityY, boolean consumed) {
    return mScrollingChildHelper.dispatchNestedFling(velocityX, velocityY, consumed);
}

@Override
public boolean dispatchNestedPreFling(float velocityX, float velocityY) {
    return mScrollingChildHelper.dispatchNestedPreFling(velocityX, velocityY);
}
}

【讨论】:

  • 它有点工作,但子列表视图不滚动
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-10-16
  • 1970-01-01
  • 2021-01-15
  • 1970-01-01
  • 2011-09-26
  • 1970-01-01
相关资源
最近更新 更多