gpt4 book ai didi

android - PagerAdapter,第二页在开始时可见

转载 作者:太空宇宙 更新时间:2023-11-03 10:23:43 25 4
gpt4 key购买 nike

我想弄清楚,下面的事情是如何用 android UI 完成的。我不认为我是第一个遇到这个问题的人,但我不知道要搜索什么,也没有找到任何有用的信息。

我的情况:

目前我有一个扩展 FragmentStatePagerAdapter 的类,用于获取我的页面的 fragment 。我有一个“主要” fragment (不应该填满屏幕!!<- 这里有非常重要的信息)和随后出现的一些屏幕填满页面。

我还有一个 PageTransformer,它可以转换页面,就好像它们已经在当前页面后面一样。)类似于此页面上的 DepthPageTransformer:http://developer.android.com/training/animation/screen-slide.html#viewpager

我的开始屏幕应该是这样的: enter image description here

稍后我会解释一下:左侧圆角区域为主页,不占满屏幕。在该主页的后面,第二页应该已经在后台可见。当我向左滑动主页时,第二页将是以下 Activity 页面。

所以,问题来了:

在我开始变换(滑动)主页面之前,第二个页面不会在后台显示。我开始构建场景(由于问题尚未完成),它看起来像这样:

enter image description here

后面的深色渐变是android的标准渐变。浅蓝色区域是具有透明度的拉伸(stretch)图像(如果这是拼图的一部分)

所以当我开始刷主页的时候,突然变成了这个样子。回到主页后,第二个仍然可见:

enter image description here

从一开始就应该是这样的情况。

我怎样才能做到这一点,两个页面从一开始就可见?这是主要 Activity 代码(基本上它是来自给定 android 开发链接的代码,没有注释):

public class MainActivity extends FragmentActivity {

private static final int NUM_PAGES = 5;
private ViewPager mPager;
private PagerAdapter mPagerAdapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main_slider);

// Instantiate a ViewPager and a PagerAdapter.
mPager = (ViewPager) findViewById(R.id.pager);
mPagerAdapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());
mPager.setAdapter(mPagerAdapter);
mPager.setPageTransformer(true, new DepthPageTransformer());
}

@Override
public void onBackPressed() {
if (mPager.getCurrentItem() == 0) {
super.onBackPressed();
} else {
mPager.setCurrentItem(mPager.getCurrentItem() - 1);
}
}

/**
* A simple pager adapter that represents 5 ScreenSlidePageFragment objects,
* in sequence.
*/
private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
public ScreenSlidePagerAdapter(FragmentManager fragmentManager) {
super(fragmentManager);
}

@Override
public Fragment getItem(int position) {
switch (position) {
case 0:
return new ScreenMainSlideFragment();
}
return new ScreenSlideFragment();
}

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

}

这是 PageTransformer(也许有解决方案):

public class DepthPageTransformer implements PageTransformer {
private static float MIN_SCALE = 1f;

public void transformPage(View view, float position) {
int pageWidth = view.getWidth();

if (position < -1) { // [-Infinity,-1)
// This page is way off-screen to the left.
view.setAlpha(0);

} else if (position <= 0) { // [-1,0]
// Use the default slide transition when moving to the left page
view.setAlpha(1);
view.setTranslationX(0);
view.setScaleX(1);
view.setScaleY(1);

} else if (position <= 1) { // (0,1]
// Fade the page out.
view.setAlpha(0.75f + (1 - position) * 0.25f);

// Counteract the default slide transition
view.setTranslationX(pageWidth * -position);

// Scale the page down (between MIN_SCALE and 1)
float scaleFactor = MIN_SCALE + (1 - MIN_SCALE) * (1 - Math.abs(position));
view.setScaleX(scaleFactor);
view.setScaleY(scaleFactor);

} else { // (1,+Infinity]
// This page is way off-screen to the right.
view.setAlpha(0);
}
}
}

非常感谢!

最佳答案

我不确定这是否能完全解决您的问题,但您是否查看过 ViewPager 适配器的 getPageWidth 方法。它可以帮助你去你想去的地方:

https://developer.android.com/reference/android/support/v4/view/PagerAdapter.html#getPageWidth(int)

在适配器的实现中返回一个小于 1 的值:

...
private static final int POS_MAIN_PAGE = 0;
private static final float WIDTH_MAIN_PAGE = 0.9f;
...

...
@Override
public float getPageWidth (int position) {
if (position == POS_MAIN_PAGE) {
return WIDTH_MAIN_PAGE;
}
return 1f;
}
....

OP评论后更新:

如果第二页需要与第一页同时可见,那么 ViewPager 可能不适合您。 ViewPager 中的页面彼此相邻显示,而不是彼此重叠。

您可以做的是在 ViewPager 的第一页(位置==0)中显示您的主页面和“第二”页面(ViewGroup/Fragment 包含主页和“第二”页面,其中您的主页略小)。你的“第二”页是固定的,你的主页可以是一个滑动抽屉。当用户在主页上(即在滑动抽屉上)向左滑动时,主页可能会滑出视线,而“第二”页面会保持不动。当用户在“第二”页面上向左滑动时,您的 ViewPager 中的“第三”页面可以通过 ViewPager 如何从一个屏幕移动到另一个屏幕的正常方式显示,并且(两者都是主页面和“第二”页面将移出视线。

关于android - PagerAdapter,第二页在开始时可见,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15659103/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com