Android разной ширины макетов в ViewPager - PullRequest
6 голосов
/ 12 декабря 2011

Я хочу создать вид прокрутки с помощью горизонтального пейджера.Вид слева должен иметь полную ширину экрана, а справа - только четверть ширины (это будет вертикальная панель, как в браузере Dolphin).Это возможно сделать?Я изменил android:layout_width в правильном макете, но это не сработало.

Мой код:

 public class TestActivity extends FragmentActivity {

@Override
public void onCreate(final Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main_view);

    MyPagerAdapter adapter = new MyPagerAdapter();
    ViewPager pager = (ViewPager) findViewById(R.id.panelPager);
    pager.setAdapter(adapter);
    pager.setCurrentItem(0);
    }
 } 

main_view.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >

<android.support.v4.view.ViewPager
    android:id="@+id/panelPager"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
</LinearLayout>

MyPagerAdapter.java

public class MyPagerAdapter extends PagerAdapter {

@Override
public int getCount() {
    return 2;
}

@Override
public Object instantiateItem(final View collection, final int position) {

    LayoutInflater inflater =
            (LayoutInflater) collection.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);

    int resId = 0;
    switch (position) {
    case 0:
        resId = R.layout.left;
        break;
    case 1:
        resId = R.layout.right;
        break;
    }

    View view = inflater.inflate(resId, null);
    ((ViewPager) collection).addView(view, 0);

    return view;
}

@Override
public void destroyItem(final View arg0, final int arg1, final Object arg2) {
    ((ViewPager) arg0).removeView((View) arg2);

}

@Override
public boolean isViewFromObject(final View arg0, final Object arg1) {
    return arg0 == ((View) arg1);

}

left.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >

<TextView
    android:id="@+id/textView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="LEFT" />

</LinearLayout>

right.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="50dp"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@color/light_blue" >


<TextView
    android:id="@+id/textView2"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="RIGHT"/>

</LinearLayout>

Ответы [ 3 ]

9 голосов
/ 13 сентября 2013

Проверьте ответ Мерфи на этот вопрос .Вам необходимо переопределить метод PagerAdapter getPageWidth() в вашем классе PagerAdapter, например, например:

@Override
public float getPageWidth(int page) {
    if(page==0) {
        Display display = getWindowManager().getDefaultDisplay();
        Point size = new Point();
        display.getSize(size);
        return (float)LEFT_FRAGMENT_PIXEL_WIDTH / size.x;
    }
    else
        return super.getPageWidth(page);
}
2 голосов
/ 31 июля 2012

Адриан совершенно прав. ViewPager не предназначен для показа части следующего поста в качестве предварительного просмотра / тизера, но он может сделать это. В моем классе ViewPagerCursorAdapter extends PagerAdapter я запускаю это:

public Object instantiateItem(View collection, final int position) {
    cursor.moveToPosition(position);
    View newView = getPageView(cursor, collection);
    if (cursor.getCount() > 1) {
        ((ViewPager)collection).setPageMargin(-overlapMargin);
        if (! cursor.isLast()) { newView.setPadding(0, 0, overlapMargin, 0); }
    }
    ((ViewPager) collection).addView(newView);
    return newView; //returns the object reference as the tag for identification.
}

У вас возникнет странная проблема с перекрытием z. Хитрость заключается в том, чтобы либо применить фон только к фону ViewPager, либо применить его к представлению внутри newView, для которого вы только что установили отступ. Хорошо выглядит и прекрасно работает.

1 голос
/ 10 января 2012

Глядя на исходный код ViewPager, он не предназначен для этого; он использует свою собственную ширину для вычисления расстояний прокрутки и т. д. с четким предположением, что все дочерние элементы будут иметь такую ​​же ширину, что и сам ViewPager.

В вашем конкретном случае может быть хакерским решением. Вы можете указать поле между соседними страницами, и это поле может быть отрицательным. Это может дать желаемый результат, если Z-порядок дочерних элементов ViewPager является подходящим. Попробуйте и посмотрите, делает ли он то, что вам нужно.

...