2014-08-28 32 views
1

我有一个ViewPager和它的适配器我有3个孩子(片段)。这3个孩子的内容应该有不同的高度。Android的 - 如何ViewPager与不同高度的多个孩子

我已经尝试覆盖ViewPager中的onMeasure Methode像这样(src:stackoverflow.com/questions/8394681/android-i-am-unable-to-have-viewpager-wrap-content/18167273#18167273)

@Override 
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
    super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
    View view = null; 

    for (int i = 0; i < getChildCount(); i++) { 
     // find the first child view 
     view = getChildAt(i); 
     if (view != null) { 
      // measure the first child view with the specified measure spec 
      view.measure(widthMeasureSpec, heightMeasureSpec); 
     } 

     setMeasuredDimension(getMeasuredWidth(), 
     measureHeight(heightMeasureSpec, view)); 
    } 

} 

但这不适用于ViewPager中的所有孩子,它只为所有孩子设置一个高度。

这是CustomViewPager从ViewPager扩展:

这是viewPager适配器:每次调用新的片段时

public class MyPagerAdapter extends FragmentPagerAdapter { 

    private final String[] TITLES = { "card1", "card2", "Card3" }; 

    public MyPagerAdapter(FragmentManager fm) { 
     super(fm); 
    } 

    @Override 
    public CharSequence getPageTitle(int position) { 
     return TITLES[position]; 
    } 

    @Override 
    public int getCount() { 
     return TITLES.length; 
    } 

    @Override 
    public Fragment getItem(int position) { 
     switch (position) { 
     case 0: 
      return CookCardFragment.newInstance(position); 

     case 1: 
      return RecipeCardFragment.newInstance(position); 

     case 2: 
      return CookCardFragment.newInstance(position); 
     } 
     return null; 
    } 

} 

回答

0

做一两件事只是试图改变viewpager控制的高度在你的FragmentActivity

+0

问题是,viewPager的childs并不总是相同的高度。例如,我有一个评论孩子,viewPager应该根据内容缩放其高度。 – ninjaxelite 2014-08-28 07:41:50

+0

将viewpager高度更改为android:layout_height =“wrap_content” – sandy 2014-08-28 09:57:55

+0

wrap_content不适用于viewpager – ninjaxelite 2014-08-28 15:03:02

0
@Override 
    public float getPageWidth(int position) { 
    return 0.98f; //(0-1] this values specifies how much space a page will occupy on screen 
}