Android开门动画和关门动画的实现

    整篇文章代码和逻辑比较简单,实现效果相对理想,大神勿喷.老规矩先上效果图:


    我们要实现的效果是:页面跳转的时候,A页面类似开门的效果,打开的过程中逐渐显示B页面.退回的时候预览进入的A页面关闭B页面.对于动画我的想法是两张图片拼凑起来实现一张图片的视觉效果

    需求明确了现在差构思:要实现这种效果也不难,首先我们先思考一下怎么才能在动画过渡的时候可以预览到B页面的视图...相信很多人都猜到了我的小心思:"所有动画过程在B页面完成,不就可以预览到B页面了吗".先为你的机智点个赞,对!就是这个道理.在这之前我们需要把A页面跳到B页面的默认动画取消

        startActivity(intent);
        overridePendingTransition(0,0);

    可以看到第二句是实现的关键,他的作用是覆盖Activity原有的跳转动画,使用自定义动画.参数详解:1.Activity进入动画;2.Activity退场动画

    慢着,在B页面开始动画之前我们还差一个东西,那就是A页面的视图,我这里选择的办法是:获取A页面根视图的截图,通过Bitmap传到B页面,好的我们来一步步的实现:

/**
     * 获取指定View的截图
     * @param view
     */
    public static Bitmap getImageOfView(View view) {
        int width1 = view.getMeasuredWidth();
        int height1 = view.getMeasuredHeight();
        Bitmap bmp1 = Bitmap.createBitmap(width1, height1,
                Bitmap.Config.ARGB_8888);
        view.draw(new Canvas(bmp1));
        Canvas canvas = new Canvas(bmp1);
        Paint paint = new Paint();
        paint.setColor(Color.TRANSPARENT);
        canvas.drawBitmap(bmp1, 0, 0, null);
        return bmp1;
    }

    这里我们用到的是画笔来绘制传入视图的方法,注意:如果我们的根视图没有背景色,那么我们取到的图片是背景透明的,就达不到我们想要的效果了.如果想解决这个麻烦也可以设置根视图的背景色,或者修改上述代码中的paint.setcolor()方法中的默认

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值