效果图:
界面属性如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center">
<TextView
android:id="@+id/tv_timer"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="40sp"
android:textColor="#000000"/>
<ImageView
android:id="@+id/image_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="centerCrop"/>
</LinearLayout>
代码逻辑如下:
public class MainActivity extends AppCompatActivity {
private int[] images = {R.drawable.wa, R.drawable.dxc, R.drawable.fj, R.drawable.dddd,
R.drawable.da, R.drawable.dasd,R.drawable.dz, R.drawable.as,R.drawable.cccz, R.drawable.fh};
private int currentIndex = 0;
private ImageView imageView;
private TextView timerTextView;
private Handler handler = new Handler();
private Runnable runnable = new Runnable() {
@Override
public void run() {
currentIndex++;
if (currentIndex >= images.length) {
currentIndex = 0;
}
imageView.setImageResource(images[currentIndex]);
handler.postDelayed(this, 1500); // 3秒后再次执行
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imageView = findViewById(R.id.image_view);
timerTextView = findViewById(R.id.tv_timer);
handler.postDelayed(runnable, 10000); // 首次执行
// 设置倒计时
new CountDownTimer(10000, 1000) {
public void onTick(long millisUntilFinished) {
timerTextView.setText("倒计时: " + millisUntilFinished / 1000);
}
public void onFinish() {
timerTextView.setText("计时结束!");
}
}.start();
}
/**
* 在代码中,我们首先定义了一个数组images,存储10张图片的资源ID,以及一个变量currentIndex,记录当前显示的图片索引。
*
* 然后,通过handler.postDelayed(runnable, 3000)方法实现每隔3秒钟切换图片的效果。runnable对象实现了Runnable接口,其中的run()方法用于更新ImageView中的图片以及currentIndex的值。
*
* 最后,我们使用CountDownTimer类实现了倒计时的效果,将时间显示在TextView中。在onFinish()方法中,我们可以添加一些额外的逻辑来处理倒计时结束后的操作。
*
* 这样,我们就实现了一个选择10张图片并倒计时切换的Android应用程序。
*/
}