我正在使用:
- 包含以编程方式添加
fragment
activity
布局。 - 父片段具有视图寻呼机
FragmentStatePagerAdapter
,所有内容都在ScrollView
内。
视图 - 页充满了一些具有回收器视图的子片段。
问题是:
视图寻呼机- 片段有一个列表,所以我必须以编程方式设置父视图寻呼机高度。但我做不到。
为此,我使用了
viewpager.getLayoutParams().height = 20000;
viewpager.requestLayout();`
和
ViewGroup.LayoutParams params = viewPagerBottom.getLayoutParams();
params.height = 20000;
viewPagerBottom.setLayoutParams(params);
另外,我已经尝试查看寻呼机和查看寻呼机片段高度属性作为wrap_content
- 如果我不使用
android:fillViewport="true"
设置滚动视图android:layout_height="match_parent"
,则无法看到查看寻呼机内容。
它是父片段布局.xml。
<ScrollView
style="@style/scrollDefaultStyle"
android:layout_height="wrap_content"
android:fillViewport="true"
>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<TabLayout .... />
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />
</LinearLayout>
</ScrollView>
您可以自定义ViewPager
,以在从此答案轻扫页面时将ViewPager
调整为当前页面大小。
您可以使用以下代码:
public class WrapContentViewPager extends ViewPager {
private int mCurrentPagePosition = 0;
public WrapContentViewPager(Context context) {
super(context);
}
public WrapContentViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
try {
boolean wrapHeight = MeasureSpec.getMode(heightMeasureSpec) == MeasureSpec.AT_MOST;
if (wrapHeight) {
View child = getChildAt(mCurrentPagePosition);
if (child != null) {
child.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
int h = child.getMeasuredHeight();
heightMeasureSpec = MeasureSpec.makeMeasureSpec(h, MeasureSpec.EXACTLY);
}
}
} catch (Exception e) {
e.printStackTrace();
}
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
public void reMeasureCurrentPage(int position) {
mCurrentPagePosition = position;
requestLayout();
}
}
在 xml 中声明它:
<your.package.name.WrapContentViewPager
android:id="@+id/view_pager"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</your.package.name.WrapContentViewPager>
在该调用之后reMeasureCurrentpage
页面滑动功能。
final WrapContentViewPager wrapContentViewPager = (WrapContentViewPager) findViewById(R.id.view_pager);
wrapContentViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
wrapContentViewPager.reMeasureCurrentPage(wrapContentViewPager.getCurrentItem());
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
注意:ListView
可能有数百行。将wrap_content
用于ListView
不是好主意。要么您需要为ListView
提供固定高度,要么需要使用match_parent
.