0

ここで何が起こっているのかわかりませんが、TouchImageViewを使用してViewPager、ImagePagerAdapterの画像ギャラリーにズーム機能を実装しました。私の他のすべての携帯電話とタブレットでは、コードはズームとページめくりのために完璧に機能します。Motorola Razr の 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);
        }
    }
}
4

1 に答える 1

1

どうやらアニメーションがこの奇妙な動作を引き起こしていたようです。理由はわかりませんが、理解するまで、このアニメーションの設定を削除する必要がありました。

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

現在、フリング アニメーションは標準を使用しています。Motorola Razr がリスナーの順序を台無しにするアダプタ フリング アニメーションを実装する方法に違いありません。

于 2014-01-07T18:03:17.197 に答える