Android ViewPager使相机预览变为白色

Android ViewPager使相机预览变为白色,android,camera,android-viewpager,android-camera,surfaceview,Android,Camera,Android Viewpager,Android Camera,Surfaceview,这就是交易: 我有一个带有摄像头预览片段的自定义ViewPager和另一个页面,它们各自都可以正常工作。两者之间的过渡使摄影机变为白色,而不仅仅是保持视图。我使用了一个修改,使其成为垂直视图寻呼机,而不是水平视图寻呼机 在它垂直之前,股票浏览页面工作得很好。这是它以前的样子: 现在: 我错过了什么让它变成白色 自定义视图寻呼机: public class VerticalPager extends ViewPager { public VerticalPager(Context contex

这就是交易:

我有一个带有摄像头预览片段的自定义ViewPager和另一个页面,它们各自都可以正常工作。两者之间的过渡使摄影机变为白色,而不仅仅是保持视图。我使用了一个修改,使其成为垂直视图寻呼机,而不是水平视图寻呼机

在它垂直之前,股票浏览页面工作得很好。这是它以前的样子:

现在:

我错过了什么让它变成白色

自定义视图寻呼机:

public class VerticalPager extends ViewPager {

public VerticalPager(Context context) {
    super(context);
    init();
}

public VerticalPager(Context context, AttributeSet attrs) {
    super(context, attrs);
    init();
}

private void init() {
    // The majority of the magic happens here
    setPageTransformer(true, new VerticalPageTransformer());
    // The easiest way to get rid of the overscroll drawing that happens on the left and right
    setOverScrollMode(OVER_SCROLL_NEVER);
}

private class VerticalPageTransformer implements ViewPager.PageTransformer {

    @Override
    public void transformPage(View view, float position) {

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

        } else if (position <= 1) { // [-1,1]
            //view.setAlpha(1);

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

            //set Y position to swipe in from top
            float yPosition = position * view.getHeight();
            view.setTranslationY(yPosition);

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

/**
 * Swaps the X and Y coordinates of your touch event.
 */
private MotionEvent swapXY(MotionEvent ev) {
    float width = getWidth();
    float height = getHeight();

    float newX = (ev.getY() / height) * width;
    float newY = (ev.getX() / width) * height;

    ev.setLocation(newX, newY);

    return ev;
}

@Override
public boolean onInterceptTouchEvent(MotionEvent ev){
    boolean intercepted = super.onInterceptTouchEvent(swapXY(ev));
    swapXY(ev); // return touch coordinates to original reference frame for any child views
    return intercepted;
}

@Override
public boolean onTouchEvent(MotionEvent ev) {
    return super.onTouchEvent(swapXY(ev));
}
公共类VerticalPager扩展了ViewPager{
公共垂直寻呼机(上下文){
超级(上下文);
init();
}
公共垂直寻呼机(上下文、属性集属性){
超级(上下文,attrs);
init();
}
私有void init(){
//大部分魔法都发生在这里
setPageTransformer(true,新的VerticalPageTransformer());
//消除发生在左侧和右侧的过卷图形的最简单方法
设置超滚动模式(超滚动模式);
}
私有类VerticalPageTransformer实现ViewPager.PageTransformer{
@凌驾
公共页面(视图、浮动位置){
if(位置<-1){/[-无穷大,-1)
//这个页面在屏幕的左边。
//视图。setAlpha(0);

}否则如果(位置首先,检查您的相机表面视图是否被破坏。我的困惑是,我没有在两者之间更改任何相机代码,因此问题必须完全来自ViewPager,在我的垂直调整中。是否有什么我需要覆盖的内容,以便它在完全看不见之前不会破坏页面?问题是whet她说它被破坏了,或者有其他问题。另外,用图像视图替换相机实时预览,检查此视图是否正常工作。经过进一步测试,确实是自定义VerticalPager在片段不在视图中或正在拖动时调用了暂停,甚至onDestroy。如果我停止拖动,但按住它尽管如此,它仍然会激活两个片段,摄影机保持活动状态,另一个片段上的方法不会失败。但是如果我在一个片段上启动一个方法并切换,它将崩溃,因为它读取为null(找不到视图等)。抱歉,刚才看到了您的最后一个响应。页面上的图像视图响应正确。