1. ホーム
  2. android

[解決済み] ScrollView内のViewPagerが正しくスクロールしない

2023-03-30 04:42:41

質問

いくつかのコンポーネントを含む「ページ」があり、そのコンテンツはデバイスの高さより長くなっています。 良いのですが、レイアウトのすべて(ページ全体)を ScrollView の中に入れれば問題ありません。

コンポーネントのひとつは ViewPager . これは正しくレンダリングされますが、スワイプ/フリングに対する応答が正しく行われず、カクカクしていつもうまくいきません。 どうやら ScrollView と「混同」しているようで、正確な水平線でフリックしたときのみ100%動作します。

を削除すると ScrollView を削除すると、ViewPagerは完全に応答します。

いろいろと調べてみましたが、これが既知の不具合であることはわかりませんでした。 他にこれを経験された方はいらっしゃいますか?

  • プラットフォーム バージョン: 1.6
  • 互換ライブラリ v4。
  • デバイス HTC Incredible S

以下は、テスト用のサンプルコードです。 ScrollView をコメントアウトして、正しく動作することを確認してください。

アクティビティです。

package com.ss.activities;

import com.ss.R;

import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.os.Parcelable;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.widget.TextView;

public class PagerInsideScollViewActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        ViewPager vp = (ViewPager) findViewById(R.id.viewpager);
        vp.setAdapter(new MyPagerAdapter(this));
    }
}

class MyPagerAdapter extends PagerAdapter {

    private Context ctx;

    public MyPagerAdapter(Context context) {
        ctx = context;
    }

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

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

        TextView tv =  new TextView(ctx);
        tv.setTextSize(50);
        tv.setTextColor(Color.WHITE);
        tv.setText("SMILE DUDE, SMILE DUDE, SMILE DUDE, SMILE DUDE, SMILE DUDE, " +
                "SMILE DUDE, SMILE DUDE, SMILE DUDE, SMILE DUDE, SMILE DUDE, " +
                "SMILE DUDE, SMILE DUDE, SMILE DUDE, SMILE DUDE, SMILE DUDE, " +
                "SMILE DUDE, SMILE DUDE, SMILE DUDE");

        ((ViewPager) collection).addView(tv);

        return tv;

    }

    @Override
    public void destroyItem(View collection, int position, Object view) {
         ((ViewPager) collection).removeView((View) view);
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view == object;
    }

    @Override
    public Parcelable saveState() {
        return null;
    }

    @Override
    public void restoreState(Parcelable arg0, ClassLoader arg1) {
    }

    @Override
    public void startUpdate(View arg0) {
    }

    @Override
    public void finishUpdate(View arg0) {
    }
}

レイアウト

<?xml version="1.0" encoding="utf-8"?>
    <ScrollView
         xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" >

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:orientation="vertical" >

            <android.support.v4.view.ViewPager
                android:id="@+id/viewpager"
                android:layout_width="fill_parent"
                android:layout_height="300dp" />

        </LinearLayout>

    </ScrollView>

どのように解決するのですか?

さらに読み進めていくと、スクロール コンポーネントの中にスクロール コンポーネントがある場合に問題があることがわかりました。

1つの解決策は、含まれるスクロール可能なコンポーネント (私の場合は ViewPager) の領域で ScrollView の垂直スクロールを「無効化」することです。

このソリューションのコードは次のとおりです。 ここで (そして、それは単に素晴らしい!)