android:viewpager2滑动fragment

一,代码:

1,xml:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".activity.FragPageActivity">
    <LinearLayout
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <androidx.viewpager2.widget.ViewPager2
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:id="@+id/fragViewPager"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            />

        <LinearLayout
            android:orientation="horizontal"
            android:layout_width="match_parent"
            android:layout_height="200px">
            <Button
                android:id="@+id/btn1"
                android:layout_width="100dp"
                android:layout_height="50dp"
                android:background="#ff0000"
                android:text="按钮一"/>
            <Button
                android:id="@+id/btn2"
                android:layout_width="100dp"
                android:layout_height="50dp"
                android:text="按钮二"/>
            <Button
                android:id="@+id/btn3"
                android:layout_width="100dp"
                android:layout_height="50dp"
                android:text="按钮三"/>
        </LinearLayout>
        <LinearLayout
            android:orientation="horizontal"
            android:layout_width="match_parent"
            android:layout_height="100px">
        </LinearLayout>
    </LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

单个fragment的xml

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffff00"
    tools:context=".fragment.HomeFragment">

    <!-- TODO: Update blank fragment layout -->
    <TextView
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:textSize="45sp"
        android:text="home页面" />

    <Button
        android:id="@+id/apibutton"
        android:layout_width="wrap_content"
        android:layout_height="60dp"
        android:layout_gravity="center"
        android:text="点击这里访问接口"
        tools:layout_editor_absoluteX="169dp"
        tools:layout_editor_absoluteY="128dp" />

</FrameLayout>

2,java

1,HomeFragment.java,就是默认创建时的代码

package com.example.okdemo1.fragment;

import android.os.Bundle;

import androidx.fragment.app.Fragment;

import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import com.example.okdemo1.R;

/**
 * A simple {@link Fragment} subclass.
 * Use the {@link HomeFragment#newInstance} factory method to
 * create an instance of this fragment.
 */
public class HomeFragment extends Fragment {

    // TODO: Rename parameter arguments, choose names that match
    // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
    private static final String ARG_PARAM1 = "param1";
    private static final String ARG_PARAM2 = "param2";

    // TODO: Rename and change types of parameters
    private String mParam1;
    private String mParam2;

    public HomeFragment() {
        // Required empty public constructor
    }

    /**
     * Use this factory method to create a new instance of
     * this fragment using the provided parameters.
     *
     * @param param1 Parameter 1.
     * @param param2 Parameter 2.
     * @return A new instance of fragment HomeFragment.
     */
    // TODO: Rename and change types and number of parameters
    public static HomeFragment newInstance(String param1, String param2) {
        HomeFragment fragment = new HomeFragment();
        Bundle args = new Bundle();
        args.putString(ARG_PARAM1, param1);
        args.putString(ARG_PARAM2, param2);
        fragment.setArguments(args);
        return fragment;
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getArguments() != null) {
            mParam1 = getArguments().getString(ARG_PARAM1);
            mParam2 = getArguments().getString(ARG_PARAM2);
        }
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        return inflater.inflate(R.layout.fragment_home, container, false);
    }
}

FragAdapter.java

package com.example.okdemo1.adapter;

import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentActivity;
import androidx.viewpager2.adapter.FragmentStateAdapter;

import java.util.List;

public class FragAdapter extends FragmentStateAdapter {

    private List<Fragment> mFragments;

    public FragAdapter(FragmentActivity fa,List<Fragment> fragments) {
        super(fa);
        mFragments=fragments;
    }

    @Override
    public Fragment createFragment(int position) {
        return  mFragments.get(position);
    }

    @Override
    public int getItemCount() {
        return  mFragments.size();
    }

}

activity.java

package com.example.okdemo1.activity;

import android.annotation.SuppressLint;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.graphics.Insets;
import androidx.core.view.ViewCompat;
import androidx.core.view.WindowInsetsCompat;
import androidx.fragment.app.Fragment;
import androidx.viewpager.widget.ViewPager;
import androidx.viewpager2.widget.ViewPager2;

import com.example.okdemo1.R;
import com.example.okdemo1.adapter.FragAdapter;
import com.example.okdemo1.fragment.HomeFragment;
import com.example.okdemo1.fragment.MessageFragment;
import com.example.okdemo1.fragment.ServiceFragment;

import java.util.ArrayList;
import java.util.List;

public class FragPageActivity extends AppCompatActivity {
    private List<Fragment> fragmentList = new ArrayList<>();
    private ViewPager2  vp_content;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        EdgeToEdge.enable(this);
        setContentView(R.layout.activity_frag_page);
        
        //添加fragment到列表
        fragmentList.add(new HomeFragment());
        fragmentList.add(new MessageFragment());
        fragmentList.add(new ServiceFragment());
        //创建adapter
        FragAdapter viewPagerAdapter=new FragAdapter(this,fragmentList);//创建适配器对象

        //得到viewpager
        vp_content = findViewById(R.id.fragViewPager);
        vp_content.setAdapter(viewPagerAdapter); // 设置翻页视图的适配器
        vp_content.setCurrentItem(0);

        //滑动时的事件回调
        vp_content.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                // 当页面开始滑动时调用
                System.out.println("位置:"+position);
            }

            @Override
            public void onPageSelected(int position) {
                // 当页面被选中时调用,position是当前页面的索引
                // 此处要选中相应的按钮,标识出滑动到的位置
                int currentPage = position;
                System.out.println("选中位置:"+position);
                setButtonSelected(currentPage);
            }

            @Override
            public void onPageScrollStateChanged(int state) {
                // 当页面滑动状态改变时调用,state可以是SCROLL_STATE_IDLE, SCROLL_STATE_DRAGGING, SCROLL_STATE_SETTLING
            }
        });


        //按钮的点击事件, 第一个按钮
        Button btn1 = findViewById(R.id.btn1);
        btn1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //滑动到第一页
                vp_content.setCurrentItem(0,true);
            }
        });
        //按钮的点击事件, 第二个按钮
        Button btn2 = findViewById(R.id.btn2);
        btn2.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //滑动到第二页
                vp_content.setCurrentItem(1,true);
            }
        });
        //按钮的点击事件, 第三个按钮
        Button btn3 = findViewById(R.id.btn3);
        btn3.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //滑动到第三页
                vp_content.setCurrentItem(2,true);
            }
        });
    }

    @SuppressLint("ResourceAsColor")
    private void setButtonSelected(int id) {
        System.out.println("选中按钮id:"+id);
        Button btn1 = findViewById(R.id.btn1);
        Button btn2 = findViewById(R.id.btn2);
        Button btn3 = findViewById(R.id.btn3);
        if (id == 0) {
            btn1.setBackgroundColor(Color.parseColor("#FF0000"));
            btn2.setBackgroundColor(Color.parseColor("#D3D3D3"));
            btn3.setBackgroundColor(Color.parseColor("#D3D3D3"));
        } else if (id == 1) {
            btn2.setBackgroundColor(Color.parseColor("#FF0000"));
            btn1.setBackgroundColor(Color.parseColor("#D3D3D3"));
            btn3.setBackgroundColor(Color.parseColor("#D3D3D3"));
        } else if (id == 2) {
            btn3.setBackgroundColor(Color.parseColor("#FF0000"));
            btn2.setBackgroundColor(Color.parseColor("#D3D3D3"));
            btn1.setBackgroundColor(Color.parseColor("#D3D3D3"));
        }
    }
}

二,测试效果:

 

 

posted @ 2025-05-01 09:27  刘宏缔的架构森林  阅读(45)  评论(0)    收藏  举报