Android中点击button,实现ImageView中图片的循环切换
今天有做到这个功能,上网找了资料,看到一个挺好的(http://blog.sina.com.cn/s/blog_60539d04010143ir.html),做了下小修改。
activity代码:
package ztestchangedpicture; import com.example.ztestchangedpicture.R; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.ImageView; public class ChangedPicture extends Activity { private Button forChange; private ImageView forDisplay; int[] image = {R.drawable.img_temp_16,R.drawable.img_temp_17,R.drawable.img_temp_18,R.drawable.img_temp_19}; int counts = 0; @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.changed_picture); forChange = (Button) findViewById(R.id.btn_click); forDisplay = (ImageView) findViewById(R.id.img_display); forDisplay.setImageResource(image[0]); forChange.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //因为数组中有4张图片,第一张已默认。 if(counts >= 3){ counts = -1;// } /*counts初始值为0,所以不执行if判断,直接执行下面的语句,而数据的第一张图片已默认, * 所以++counts的值为1,依次当点击第三次时,counts值为2,而++counts为3,再次点击时就执行if判断,将-1 * 赋值给counts,再执行下面的语句,++counts为0,重新开始*/ forDisplay.setImageResource(image[++counts]); } }); } }
XML布局文件代码:
<?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" > <Button android:id="@+id/btn_click" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="changed picture for click" /> <ImageView android:id="@+id/img_display" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="20dp" android:layout_gravity="center" /> </LinearLayout>
需要注意的是,代码中有++counts,所以不要再xml中默认图片
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。