使用TouchImageView和特定电话进行奇怪的缩放行为

时间:2014-01-02 18:23:26

标签: android android-viewpager android-pageradapter touchimageview android-pagetransformer

不确定这里发生了什么,但我已经使用TouchImageView在ViewPager,ImagePagerAdapter的图像库中实现了缩放功能。在我的所有其他手机和平板电脑上,代码非常适用于缩放和翻页。在我们的3款摩托罗拉剃须刀中,缩放在第一张图像上表现得很有趣。有趣的是,当你尝试缩放时,图片#1上没有任何反应。但是如果平移到下一个图像,则从图像1缩放会影响图像2.如果您回到图像1,它仍然不会缩放。如果你平移到图像#3然后回到#1,第一个图像将缩放得很好。不知道如何解决这个问题甚至调试它。我在API中的示例中添加了自定义动画DepthPageTransformer。这是罪魁祸首,但不确定代码中是什么导致了这种行为。

import android.annotation.SuppressLint;
import android.support.v4.view.ViewPager.PageTransformer;
import android.view.View;

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

    // suppress compiler warning...lower Api use standard slide in but 
    // APIs higher than 10 will use the transform page function
    @SuppressLint("NewApi") 
    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(1 - position);

            // 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);
        }
    }
}

1 个答案:

答案 0 :(得分:1)

显然动画导致了这种奇怪的行为。不知道为什么,但在我弄明白之前我必须删除这个动画的设置。

galleryViewPager.setClickable(true);
//galleryViewPager.setAnimation(new DepthPageTransformer());
galleryViewPager.setOnClickListener(new OnClickListener() {...

现在,fling动画正在使用标准。必须是摩托罗拉Razr实现调整侦听器顺序的适配器动画动画的方式。

相关问题