模仿小米锁屏时的图片切换效果

在红米note2上看到它的锁屏后浏览屏保的效果不错,到网上查了一下,效果名字叫视差滚动,然后又查了一下, 发现其实很简单,只需要实现viewpager的setPageTransformer方法就好了。这个方法就是用来实现viewpager的切换效果的,这里只是实现了一种效果。下面是实现代码

 
mViewPager.setPageTransformer(true, new ViewPager.PageTransformer() {
    @Override
    public void transformPage(View page, float position) {
        //这里的position是有取值区间的,每个区间的意义有不同
        View view = ((LinearLayout)page).getChildAt(0);
        int pageWidth = page.getWidth();
        if (position < -1) { // [-Infinity,-1)
            // This page is way off-screen to the left.
            //居于当前屏幕左边的一页
        } else if (position <= 0) { // [-1,0]
            //当前页
            //下一页  手指往左划,position从0到-1,手指往右划,position从-1到0
            // Use the default slide transition when moving to the left page
            view.setTranslationX((pageWidth/2) * -position);
        } else if (position <= 1) { // (0,1]
            //下一页  手指往左划,position从1到0,手指往右划,position从0到1
            // Counteract the default slide transition
            view.setTranslationX((pageWidth/2) * -position);
        } else { // (1,+Infinity]
            //居于当前屏幕右边的一页
            // This page is way off-screen to the right.
        }
    }
});
注意:我在viewpager中插入的是一个linearlayout,里面有显示图片的子控件,这里只是显示图片的子控件进行x轴的移动,关于这个方法的demo有很多,效果也有很多,大家可以自行查阅

源码链接

实现小米充电动画的效果通常是在Android中利用View动画或者更现代的Lottie动画库。由于这里是一个文字描述,我会简化地展示一种基本的实现方式,假设我们想要创建一个简单的线性渐变充电进度: ```java // 首先,在XML中创建一个视图用于显示动画 <ImageView android:id="@+id/battery_view" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/empty_battery" /> // 然后,在Activity或者Fragment中获取这个视图并设置动画 // 假设有一个从0到100的充电进度 int progress = 50; // 示例进度值 AnimationDrawable batteryAnimation; batteryAnimation = (AnimationDrawable) findViewById(R.id.battery_view).getBackground(); // 创建一个LinearInterpolator(线性插值器)表示平滑过渡 Interpolator interpolator = new LinearInterpolator(); // 创建一个帧动画,模拟充电过程 List<Animator> animators = new ArrayList<>(); for (int i = 0; i <= 100; i += 10) { Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.battery_level_0_to_100 + i); FrameAnimation frameAnim = new FrameAnimation(0, 1000, interpolator); frameAnim.setIntraFrameDelay(i * 10); // 每次帧之间的延迟可根据实际需求调整 frameAnim.setFrames(new Object[]{bitmap}, true); animators.add(frameAnim); } // 设置动画序列 batteryAnimation.setOneShot(true); batteryAnimation.set反复播放(false); batteryAnimation.startSequence(animators.subList(progress * 10, (progress + 1) * 10)); // 根据当前进度开始对应部分的动画 // 当充电进度变化,更新动画 public void onBatteryChanged(int level) { batteryAnimation.stop(); batteryAnimation.startSequence(animators.subList(level * 10, (level + 1) * 10)); } ``` 请注意,这只是一个简化的示例,实际的小米充电效果可能会更复杂,包括颜色渐变、状态指示等,并可能需要配合Service或其他组件实更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值