Androidでスワイプで画面を切り替える方法

Androidでは、ViewPager コンポーネントを使用することでスワイプして切り替える効果を実装できます。

まず、XMLレイアウトファイルでViewPagerコンポーネントを追加します。

<androidx.viewpager.widget.ViewPager
    android:id="@+id/viewPager"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />

次に、ActivityでViewPagerコンポーネントを見つけてアダプターを設定します:

ViewPager viewPager = findViewById(R.id.viewPager);
viewPager.setAdapter(new MyPagerAdapter(getSupportFragmentManager()));

次に、ViewPager内のページを管理するため、PagerAdapterの作成

public class MyPagerAdapter extends FragmentPagerAdapter {

    public MyPagerAdapter(FragmentManager fm) {
        super(fm);
    }

    @Override
    public Fragment getItem(int position) {
        // 返回对应位置的Fragment
        return MyFragment.newInstance(position);
    }

    @Override
    public int getCount() {
        // 返回Fragment的个数
        return 3;
    }
}

上記の例では、3つのフラグメントを含むアダプターを作成しましたが、必要に応じてフラグメントの数を変更できます。

最後に、ViewPagerに表示するFragmentを作成する

public class MyFragment extends Fragment {

    private static final String ARG_POSITION = "position";

    public static MyFragment newInstance(int position) {
        MyFragment fragment = new MyFragment();
        Bundle args = new Bundle();
        args.putInt(ARG_POSITION, position);
        fragment.setArguments(args);
        return fragment;
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.fragment_my, container, false);
        int position = getArguments().getInt(ARG_POSITION);
        // 根据position设置Fragment中的内容
        TextView textView = rootView.findViewById(R.id.textView);
        textView.setText("Page " + position);
        return rootView;
    }
}

上記の例では、位置情報を表示する TextView を表示する単純なフラグメントを作成しています。

これらの手順に従うだけで、Android で左右にスライドして画面を切り替える効果を実装できます。必要に応じてページのレイアウトや内容を変更して、目的の効果を実現してください。

bannerAds