Android 背景图片轮播

该博客介绍了一个自定义的AutoPlayView组件,用于实现在Android中自动轮播背景图片的效果。通过使用ValueAnimator进行平滑滚动,结合LinearInterpolator实现平直的动画过渡,实现了两张图片无缝切换的视觉体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.example.test;


import android.animation.ValueAnimator;
import android.annotation.TargetApi;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.drawable.Drawable;
import android.os.Build;
import android.util.AttributeSet;
import android.view.View;
import android.view.animation.LinearInterpolator;


@TargetApi(Build.VERSION_CODES.ICE_CREAM_SANDWICH)
public class AutoPlayView extends View {
Drawable mDrawableLeft, mDrawableRight;
int drawableWidth, drawableHeight;
ValueAnimator valueAnimator;


public AutoPlayView(Context context,  AttributeSet attrs) {
super(context, attrs);
init();
}


private void init() {
mDrawableLeft = getResources().getDrawable(R.drawable.ic_launcher);
drawableWidth = Utils.getScreenWith(getContext());
drawableHeight = mDrawableLeft.getMinimumHeight();
mDrawableLeft.setBounds(0, 0, drawableWidth, drawableHeight);


mDrawableRight = getResources().getDrawable(R.drawable.ic_launcher);
mDrawableRight.setBounds(drawableWidth, 0, drawableWidth * 2,
drawableHeight);
}


@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int wdMode = MeasureSpec.getMode(widthMeasureSpec);
int hdMode = MeasureSpec.getMode(heightMeasureSpec);
// 测量布局大小,默认为屏幕的宽,图片的高
if (wdMode == MeasureSpec.EXACTLY && hdMode == MeasureSpec.EXACTLY) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
} else {
int wd = MeasureSpec.makeMeasureSpec(
Utils.getScreenWith(getContext()),
MeasureSpec.EXACTLY);
int hd = MeasureSpec.makeMeasureSpec(drawableHeight,
MeasureSpec.EXACTLY);
setMeasuredDimension(wd, hd);
}
}


@Override
protected void onDraw(Canvas canvas) {
// 思路:左边一张图,右边隐藏一张图,不停的scrollto
mDrawableLeft.draw(canvas);
mDrawableRight.draw(canvas);
}


public void startPlay() {
// 一张图片的宽的移动距离,即可视觉上达到不停的在滚动
valueAnimator = ValueAnimator.ofInt(0, drawableWidth);
valueAnimator.setInterpolator(new LinearInterpolator());
valueAnimator.setRepeatCount(-1);
valueAnimator.setDuration(2000);
valueAnimator.setRepeatMode(ValueAnimator.RESTART);
valueAnimator
.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
int value = (Integer) animation.getAnimatedValue();
scrollTo(value, 0);
}
});
valueAnimator.start();
}


public void stopPlay() {
if (valueAnimator != null && valueAnimator.isRunning()
&& valueAnimator.isStarted()) {
valueAnimator.cancel();
}
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值