Android -- ViewPager滑动背景渐变

简介:

原理                                                                                   

总布局为RelativeLayout或者FrameLayout,在这里我们用的是RelativeLayout。先设置背景图片,宽度和高度都fill_parent,在设置viewpager,viewpager的背景要透明哟~这样背景图片就可以显示在页面上。对viewpager进行滑动监听,通过滑动的偏移量对当前背景进行淡出,下一个背景进行显示。

布局                                                                                   

复制代码
<RelativeLayout 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"
                tools:context=".MyActivity">

    <us.yydcdut.viewpagercolorchange.BackGroundImage
        android:id="@+id/img"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"/>

    <android.support.v4.view.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        />
</RelativeLayout>
复制代码

有个自定义View,淡出等操作就是在自定义view中进行的。

Code                                                                                   

复制代码
public class MyActivity extends Activity {
    private BackGroundImage mImg;
    private ViewPager mViewPager;
    private List<View> mViewLists;
    private List<Drawable> mDrawableLists;
    private static final int ALL = 5;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_my);
        initViews();
        mImg.setmDrawableLists(mDrawableLists);
        mViewPager.setAdapter(new MyAdapter());
        mViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int i, float v, int i2) {
                mImg.setmDegree(v);
                mImg.setmPosition(i);
                mImg.invalidate();//刷新
            }

            @Override
            public void onPageSelected(int i) {

            }

            @Override
            public void onPageScrollStateChanged(int i) {

            }
        });
    }

    private void initViews() {
        mImg = (BackGroundImage) findViewById(R.id.img);
        mViewPager = (ViewPager) findViewById(R.id.viewPager);
        mViewLists = new ArrayList<View>();
        mDrawableLists = new ArrayList<Drawable>();
        for (int i = 0; i < ALL; i++) {
            View view = getLayoutInflater().inflate(R.layout.vp, null);
            mViewLists.add(view);
            if (i % 2 == 0) {
                mDrawableLists.add(getResources().getDrawable(R.drawable.bg_img1));
            } else {
                mDrawableLists.add(getResources().getDrawable(R.drawable.bg_img2));
            }
        }
    }


    class MyAdapter extends PagerAdapter {

        @Override
        public int getCount() {
            return mViewLists.size();
        }

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

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

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            View v = mViewLists.get(position);
            TextView textView = (TextView) v.findViewById(R.id.txt);
            textView.setText("第" + position + "个");
            ((ViewPager) container).addView(v);
            return v;
        }
    }
}
复制代码
复制代码
public class BackGroundImage extends View {
    private int mPosition;
    private float mDegree;
    private List<Drawable> mDrawableLists;
    private int mPrePosition = 0;
    private Drawable mNext;

    public void setmDrawableLists(List<Drawable> mDrawableLists) {
        this.mDrawableLists = mDrawableLists;
        mNext = mDrawableLists.get(1);//设置下一个背景图片的drawable
    }
 
    public void setmPosition(int mPosition) {
        this.mPosition = mPosition;
    }

    public void setmDegree(float mDegree) {
        this.mDegree = mDegree;
    }

    public BackGroundImage(Context context) {
        super(context);
        //setWillNotDraw(false);
    }

    public BackGroundImage(Context context, AttributeSet attrs) {
        super(context, attrs);
        //setWillNotDraw(false);
    }

    public BackGroundImage(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        //setWillNotDraw(false);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        Log.i("111", "onDraw");
        if (null == mDrawableLists) {
            return;
        }
        int alpha1 = (int) (255 - (mDegree * 255));
        Drawable fore = mDrawableLists.get(mPosition);
        fore.setBounds(0, 0, getWidth(), getHeight());
        mNext.setBounds(0, 0, getWidth(), getHeight());
        if (mPrePosition != mPosition) {//边界判断
            if (mPosition != mDrawableLists.size() - 1) {
                mNext = mDrawableLists.get(mPosition + 1);
            } else {
                mNext = mDrawableLists.get(mPosition);
            }
        }
        fore.setAlpha(alpha1);//淡出
        mNext.setAlpha(255);
        mNext.draw(canvas);
        fore.draw(canvas);
        mPrePosition = mPosition;
        super.onDraw(canvas);
    }
}
复制代码

我是天王盖地虎的分割线                      




本文转自我爱物联网博客园博客,原文链接:http://www.cnblogs.com/yydcdut/p/4138745.html,如需转载请自行联系原作者

相关文章
|
7月前
|
Android开发
android全透明背景色: android 开发 背景常用透明度
android全透明背景色: android 开发 背景常用透明度
54 0
|
7月前
|
JavaScript Android开发
使用贝叶斯曲线滑动安卓屏幕(autojsPro7)
使用贝叶斯曲线滑动安卓屏幕(autojsPro7)
251 0
|
6月前
|
Android开发 容器
35. 【Android教程】视频页面:ViewPager
35. 【Android教程】视频页面:ViewPager
64 3
|
4月前
|
Android开发
Android使用ViewPager做无限轮播,人为滑动时停止
Android使用ViewPager做无限轮播,人为滑动时停止
93 2
|
6月前
|
Android开发
Android中如何动态的调整Dialog的背景深暗
在Android开发中,Dialog和DialogFragment可通过设置`Window`的`backgroundDimAmount`来控制背景变暗,突出对话框。在DialogFragment的`onCreateDialog`或`onViewCreated`中,获取`Dialog`的`Window`,设置`LayoutParams.dimAmount`(例如0.5f)并添加`FLAG_DIM_BEHIND`标志。要动态调整,可保存`LayoutParams`并在需要时更新。对于Dialog,创建时直接设置同样属性。还可以通过定义主题样式设置背景模糊程度。
171 7
|
5月前
|
Android开发
Android仿高德首页三段式滑动
Android仿高德首页三段式滑动
166 0
|
6月前
|
开发工具 Android开发
Android 代码自定义drawble文件实现View圆角背景
Android 代码自定义drawble文件实现View圆角背景
198 0
|
6月前
|
编解码 Android开发
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
111 0
|
7月前
|
Android开发
Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头(1)
Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头(1)
|
6月前
|
XML Android开发 UED