ViewPager 两边显示部分其他页

主要就是设置margin,Viewpager父节点设置   android :clipChildren= "false"

viewpager.setpagerMargin();



代码

public class MainActivity extends AppCompatActivity {
    ViewPager vp;
    int colors[]=new int[]{Color.BLACK,Color.BLUE,Color.GRAY,Color.GREEN,Color.RED};
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        vp= (ViewPager) findViewById(R.id.vp);
        vp.setPageMargin(30);//设置间距
        vp.setOffscreenPageLimit(3);
        vp.setAdapter(new Adapter());

    }

    class Adapter extends PagerAdapter{
        @Override
        public int getCount() {
            return colors.length;
        }

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

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            ImageView imageView=new ImageView(MainActivity.this);

            imageView.setBackgroundColor(colors[position]);
            container.addView(imageView);


            return imageView;
        }

        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
           // super.destroyItem(container, position, object);
            container.removeView((View) object);
        }


    }
}


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
    android:layout_height="match_parent"
    android:clipChildren="false"
    tools:context="com.example.administrator.myviewpager.MainActivity">

   <android.support.v4.view.ViewPager
       android:id="@+id/vp"
       android:layout_width="match_parent"
       android:layout_height="match_parent"
       android:layout_marginBottom="20dp"
       android:layout_marginLeft="30dp"
       android:layout_marginRight="30dp"
       android:layout_marginTop="40dp"
       android:clipChildren="false"
       android:layout_centerHorizontal="true"

       >

   </android.support.v4.view.ViewPager>

</RelativeLayout>





  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 ViewPager 中显示上一和下一,你可以使用一个自定义的布局来实现。这个布局可以包含两个按钮,一个用于显示上一,另一个用于显示下一。在每个按钮的点击事件中,你可以调用 ViewPager 的 setCurrentItem() 方法来设置当前显示码。 下面是一个简单的实现示例: 1. 创建一个自定义的布局文件 pager_navigation.xml,添加上一和下一按钮: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:gravity="center"> <Button android:id="@+id/btn_previous" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="上一" /> <Button android:id="@+id/btn_next" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="下一" /> </LinearLayout> ``` 2. 在 Activity 中加载布局文件,并找到上一和下一按钮: ```java View pagerNavigation = getLayoutInflater().inflate(R.layout.pager_navigation, null); Button btnPrevious = pagerNavigation.findViewById(R.id.btn_previous); Button btnNext = pagerNavigation.findViewById(R.id.btn_next); ``` 3. 设置按钮的点击事件,通过 ViewPager 的 setCurrentItem() 方法切换面: ```java btnPrevious.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { int currentPage = viewPager.getCurrentItem(); if (currentPage > 0) { viewPager.setCurrentItem(currentPage - 1); } } }); btnNext.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { int currentPage = viewPager.getCurrentItem(); if (currentPage < adapter.getCount() - 1) { viewPager.setCurrentItem(currentPage + 1); } } }); ``` 其中,adapter.getCount() 方法返回 ViewPager 中面的总数。注意,在设置当前码时,要判断当前码是否已经到达边界。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值