ViewPager设置高度为warp_content

需要将Viewpager设置高度为自适应,根据里面的图片高度变化,故在XML文件中设置为layout_height="wrap_content",但出来的结果发现viewpager占据了整个屏幕。 
由于我的布局文件中,在viewpager下面有一个listview,还有一个对应于viewpager当前所选择页的点,在网上看到的一些说在外面再套层父控件,但没有成功,可能是我设置不正确吧。 
后来在网上找到了一个列子,重写ViewPager控件,实现了根据内容高度自适应的效果。代码如下:

public class CustomViewPager extends ViewPager{

  public CustomViewPager(Context context) {
    super(context);
  }
  public CustomViewPager(Context context, AttributeSet attrs) {
    super(context, attrs);
  }
  @Override
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

    int height = 0;
    for(int i = 0; i < getChildCount(); i++) {
      View child = getChildAt(i);
      child.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
      int h = child.getMeasuredHeight();
      if(h > height) height = h;
    }

    heightMeasureSpec = MeasureSpec.makeMeasureSpec(height, MeasureSpec.EXACTLY);

    super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  }
}

之后在xml布局中使用就好了,直接设置layout_height="wrap_content",效果实现。

参考地址: http://www.cnblogs.com/zzy-android/p/3582169.html


【原文:http://www.tuicool.com/articles/AbiqYv7】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值