以编程方式设置 ViewPager 高度会自动滚动到最底部
Posted
技术标签:
【中文标题】以编程方式设置 ViewPager 高度会自动滚动到最底部【英文标题】:Setting ViewPager height programmatically automatically scrolls to very bottom 【发布时间】:2022-01-20 04:52:47 【问题描述】:我是 android 开发的初学者。目前,我正在为我们的项目制作一个应用程序。在我的应用程序中,我在布局中间有一个带有TabLayout
的片段,带有ViewPager below it
。在我的 XML 布局中,我将ViewPager
的高度设置为match_parent
以填充下方的剩余空间。
我有两个片段用于ViewPager
,第一个片段包含GridView
,另一个包含ListView
。
这些视图将填充来自我的 Firebase 的数据。现在我所做的是根据屏幕高度减去 TabLayout
的高度以及状态栏来设置ViewPager
的高度,这样当用户滚动到在最底部,TabLayout
将位于应用栏下方,就像它们合并在一起一样。
我的问题是,在以编程方式设置 ViewPager
的高度后,NestedScrollView
会自动滚动到最底部。我已经在 Android 11 (API 30) 上测试了我的应用程序,它运行良好,但是当我在 Android 5 (API 21) 上运行它时,我看到了滚动问题。
我还尝试在设置高度后立即使用 nestedScrollView.fullScroll(View.FOCUS_UP)
和 nestedScrollView.scrollTo(0, 0)
以编程方式滚动 NestedScrollView,但似乎没有任何反应。
这是我的片段布局:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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_
android:layout_
android:background="@color/toolbar"
android:fitsSystemWindows="true"
android:theme="@style/AppTheme2">
<androidx.core.widget.NestedScrollView
android:id="@+id/nestedScrollView"
android:layout_
android:layout_
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:fillViewport="true"
android:overScrollMode="never">
<RelativeLayout
android:layout_
android:layout_>
<RelativeLayout
android:id="@+id/topLayout"
android:layout_
android:layout_>
<de.hdodenhof.circleimageview.CircleImageView
android:id="@+id/civ_profile_picture"
android:layout_
android:layout_
android:layout_centerHorizontal="true"
android:layout_marginTop="30dp"
android:scaleType="centerCrop"
android:src="@drawable/placeholder_profile_picture"
app:civ_border_color="@color/white"
app:civ_border_
tools:ignore="MissingConstraints" />
<RelativeLayout
android:id="@+id/layout_change_profile_picture"
android:layout_
android:layout_
android:layout_centerHorizontal="true"
android:layout_marginTop="30dp"
android:visibility="gone">
<de.hdodenhof.circleimageview.CircleImageView
android:layout_
android:layout_
android:src="#88000000"
app:civ_border_color="@color/white"
app:civ_border_ />
<ImageView
android:layout_
android:layout_
android:layout_centerInParent="true"
android:src="@drawable/ic_baseline_photo_camera_white_24" />
</RelativeLayout>
<EditText
android:id="@+id/type_edit"
android:layout_
android:layout_
android:layout_below="@id/username_edit"
android:layout_centerHorizontal="true"
android:gravity="center"
android:hint="type"
android:inputType="textNoSuggestions"
android:lines="1"
android:textAlignment="center"
android:textColor="@color/white"
android:textSize="14sp"
android:visibility="gone"
app:boxBackgroundMode="none" />
<EditText
android:id="@+id/username_edit"
android:layout_
android:layout_
android:layout_below="@id/civ_profile_picture"
android:layout_centerHorizontal="true"
android:layout_marginTop="8dp"
android:gravity="center"
android:hint="Username"
android:inputType="textNoSuggestions"
android:lines="1"
android:textAlignment="center"
android:textColor="@color/white"
android:textSize="20sp"
android:visibility="gone"
app:boxBackgroundMode="none" />
<TextView
android:id="@+id/Username"
android:layout_
android:layout_
android:layout_below="@id/civ_profile_picture"
android:layout_centerHorizontal="true"
android:layout_marginTop="8dp"
android:background="@null"
android:ellipsize="end"
android:fontFamily="@font/roboto"
android:gravity="center"
android:maxWidth="240dp"
android:maxLines="1"
android:scrollHorizontally="true"
android:text="Username"
android:textAlignment="center"
android:textColor="@color/white"
android:textSize="20dp" />
<TextView
android:id="@+id/TypesArtists"
android:layout_
android:layout_
android:layout_below="@id/Username"
android:layout_centerHorizontal="true"
android:layout_marginTop="5dp"
android:background="@null"
android:ellipsize="end"
android:fontFamily="@font/poppins"
android:gravity="center"
android:maxWidth="240dp"
android:maxLines="1"
android:scrollHorizontally="true"
android:text="Type"
android:textAlignment="center"
android:textColor="@color/gray_text_light"
android:textSize="14dp" />
<LinearLayout
android:layout_
android:layout_
android:layout_below="@id/TypesArtists"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dp"
android:layout_marginBottom="20dp"
android:orientation="horizontal">
<RelativeLayout
android:layout_
android:layout_>
<TextView
android:id="@+id/txt_rating"
android:layout_
android:layout_
android:layout_centerHorizontal="true"
android:text="0.0"
android:textColor="@color/white"
android:textSize="18sp" />
<TextView
android:layout_
android:layout_
android:layout_below="@+id/txt_rating"
android:layout_centerHorizontal="true"
android:layout_marginTop="4dp"
android:fontFamily="@font/poppins"
android:text="Rating"
android:textColor="@color/accent1"
android:textSize="14sp" />
</RelativeLayout>
<View
android:layout_
android:layout_
android:layout_marginHorizontal="20dp"
android:background="@color/divider_light" />
<RelativeLayout
android:layout_
android:layout_>
<TextView
android:id="@+id/txt_post_count"
android:layout_
android:layout_
android:layout_centerHorizontal="true"
android:text="0"
android:textColor="@color/white"
android:textSize="18sp" />
<TextView
android:id="@+id/txt_post"
android:layout_
android:layout_
android:layout_below="@+id/txt_post_count"
android:layout_centerHorizontal="true"
android:layout_marginTop="4dp"
android:fontFamily="@font/poppins"
android:text="Posts"
android:textColor="@color/accent1"
android:textSize="14sp" />
</RelativeLayout>
<View
android:layout_
android:layout_
android:layout_marginHorizontal="16dp"
android:background="@color/divider_light" />
<RelativeLayout
android:layout_
android:layout_>
<TextView
android:id="@+id/txt_reviews_count"
android:layout_
android:layout_
android:layout_centerHorizontal="true"
android:text="0"
android:textColor="@color/white"
android:textSize="18sp" />
<TextView
android:id="@+id/txt_review"
android:layout_
android:layout_
android:layout_below="@+id/txt_reviews_count"
android:layout_centerHorizontal="true"
android:layout_marginTop="4dp"
android:fontFamily="@font/poppins"
android:text="Reviews"
android:textColor="@color/accent1"
android:textSize="14sp" />
</RelativeLayout>
</LinearLayout>
<TextView
android:id="@+id/ratingTxt"
android:layout_
android:layout_
android:layout_below="@id/TypesArtists"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dp"
android:fontFamily="@font/poppins"
android:text="rating 0/5"
android:textColor="@color/white"
android:textSize="14dp"
android:visibility="gone" />
<com.iarcuschin.simpleratingbar.SimpleRatingBar
android:id="@+id/rating_bar"
android:layout_
android:layout_
android:layout_below="@id/ratingTxt"
android:layout_centerHorizontal="true"
android:layout_marginTop="10dp"
android:layout_marginBottom="20dp"
android:visibility="gone"
app:srb_drawBorderEnabled="false"
app:srb_fillColor="@color/accent2"
app:srb_isIndicator="true"
app:srb_maxStarSize="14dp"
app:srb_numberOfStars="5"
app:srb_rating="5"
app:srb_starBackgroundColor="#172435"
app:srb_starSize="20dp"
app:srb_stepSize="0.5" />
</RelativeLayout>
<com.google.android.material.tabs.TabLayout
android:id="@+id/tab_layout"
android:layout_
android:layout_
android:layout_below="@id/topLayout"
android:layout_centerInParent="true"
android:background="@color/item_dark"
android:outlineSpotShadowColor="@color/Magenta"
app:tabIndicatorColor="@color/Magenta"
app:tabIndicatorHeight="3dp"
app:tabSelectedTextColor="@color/white"
app:tabTextAppearance="@style/TabLayoutTextAppearance"
app:tabTextColor="@color/gray_text_dark"
tools:layout_editor_absoluteX="0dp" />
<androidx.viewpager.widget.ViewPager
android:id="@+id/view_pager"
android:layout_
android:layout_
android:layout_below="@id/tab_layout"
android:background="@color/Background0" />
</RelativeLayout>
</androidx.core.widget.NestedScrollView>
</RelativeLayout>
这里是设置ViewPager高度的方法:
private void setViewPagerParams()
tabLayout.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener()
@Override
public void onGlobalLayout()
tabLayout.getViewTreeObserver().removeOnGlobalLayoutListener(this);
//get height of tab layout (px)
int tabLayoutHeight = tabLayout.getHeight();
//get height of screen (px)
Display display = getActivity().getWindowManager().getDefaultDisplay();
Point size = new Point();
display.getSize(size);
//get height of status bar
Rect rectangle = new Rect();
Window window = getActivity().getWindow();
window.getDecorView().getWindowVisibleDisplayFrame(rectangle);
int statusBarHeight = rectangle.top;
heightOfViewPager = size.y - (tabLayoutHeight + statusBarHeight);
ViewGroup.LayoutParams viewPagerParams = viewPager.getLayoutParams();
viewPagerParams.height = heightOfViewPager;
RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(viewPagerParams);
params.addRule(RelativeLayout.BELOW, R.id.tab_layout);
viewPager.setLayoutParams(params);
);
【问题讨论】:
【参考方案1】:更新:
经过数小时的研究和代码修改,我发现问题出在我的 XML 文件中。
我将根元素从 RelativeLayout 更改为 LinearLayout,并添加了 android:descendantFocusability="blocksDescendants"
作为其属性。
这个answer帮助了我
另一个更新:虽然滚动停止了,但根布局 LinearLayout
停止了其所有后代视图的聚焦,从而阻止了其中包含的 EditText
上的所有输入。更好的解决方案是将android:focusableInTouchMode
属性设置为true
,这样编辑文本仍然可以聚焦,同时防止不必要的滚动。
【讨论】:
以上是关于以编程方式设置 ViewPager 高度会自动滚动到最底部的主要内容,如果未能解决你的问题,请参考以下文章