在项目开发中,往往 要用到图片播放的效果。今天就用TimerTask和ImageView是实现简单的图片播放效果。

当中,TimerTask和Timer结合一起使用。主要是利用TimerTask的迭代延时等时间段处理事件的机制。

详细实比例如以下:

1.layout xml代码

<span style="font-family:Microsoft YaHei;font-size:18px;"><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_horizontal"
android:orientation="vertical" > <!-- 開始播放 -->
<Button
android:id="@+id/my_start_btn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Start" /> <!-- 停止播放 -->
<Button
android:id="@+id/my_stop_btn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Stop" /> <!-- 又一次開始播放 -->
<Button
android:id="@+id/my_restart_btn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Restart" /> <ImageView
android:id="@+id/image_iv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/onea" /> </LinearLayout></span>

2.MainActivity代码

<span style="font-family:Microsoft YaHei;font-size:18px;">package com.example.myimageplaydemo;

import java.util.Timer;
import java.util.TimerTask; import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView; public class MainActivity extends Activity implements OnClickListener { private Button startBtn, stopBtn,restartBtn;
private ImageView imageIv;
private Timer timer;
private TimerTask timerTask;
private int count = 0; private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
int myCount = Integer.valueOf(msg.obj.toString()); switch (msg.what) {
case 1:
setImageViewSrc(myCount);
break;
case 2:
stopTimer();
break;
case 3:
setImageViewSrc(myCount);
break;
}
}
}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
} @Override
public void onStart() {
super.onStart(); startBtn = (Button) this.findViewById(R.id.my_start_btn);
stopBtn = (Button) this.findViewById(R.id.my_stop_btn);
restartBtn = (Button) this.findViewById(R.id.my_restart_btn);
imageIv = (ImageView) this.findViewById(R.id.image_iv); startBtn.setOnClickListener(this);
stopBtn.setOnClickListener(this);
restartBtn.setOnClickListener(this);
} @Override
public void onStop() {
super.onStop();
stopTimer();
} @Override
public void onClick(View v) {
// TODO Auto-generated method stub
switch (v.getId()) {
case R.id.my_start_btn:
if (timerTask == null) {
timer = new Timer();
//延迟一秒,迭代一秒设置图片
timerTask = new TimerTask() { @Override
public void run() {
++count;
handler.sendMessage(handler.obtainMessage(1, count));
}
};
timer.schedule(timerTask, 1000, 1000);
} else {
handler.sendMessage(handler.obtainMessage(1, count));
}
break;
case R.id.my_stop_btn:
handler.sendMessage(handler.obtainMessage(2, count));
break;
case R.id.my_restart_btn:
if (timerTask == null) {
count = 0 ;
timer = new Timer();
timerTask = new TimerTask() { @Override
public void run() {
count++;
handler.sendMessage(handler.obtainMessage(3, count));
}
};
timer.schedule(timerTask, 1000, 1000);
} else {
handler.sendMessage(handler.obtainMessage(3, 0));
}
}
} /**
* 依据count循环对ImageView设置图片
* @param count
*/
private void setImageViewSrc(int count) {
int myCount = count % 7;
switch (myCount) {
case 0:
imageIv.setImageResource(R.drawable.onea);
break;
case 1:
imageIv.setImageResource(R.drawable.oneb);
break;
case 2:
imageIv.setImageResource(R.drawable.onec);
break;
case 3:
imageIv.setImageResource(R.drawable.oned);
break;
case 4:
imageIv.setImageResource(R.drawable.onee);
break;
case 5:
imageIv.setImageResource(R.drawable.onef);
break;
case 6:
imageIv.setImageResource(R.drawable.oneg);
break;
}
} /**
* 销毁TimerTask和Timer
*/
private void stopTimer(){
if (timerTask != null) {
timerTask.cancel();
timerTask = null;
} if(timer != null){
timer.cancel();
timer = null;
}
} }
</span>

当中

<span style="font-family:Microsoft YaHei;font-size:18px;"><span style="white-space:pre">			</span>if (timerTask == null) {
timer = new Timer();
//延迟一秒。迭代一秒设置图片
timerTask = new TimerTask() { @Override
public void run() {
++count;
handler.sendMessage(handler.obtainMessage(1, count));
}
};
timer.schedule(timerTask, 1000, 1000);
} else {
handler.sendMessage(handler.obtainMessage(1, count));
}</span>

timerTask延迟一秒后再每秒设置不一样的图片,依据count进行循环的播放。

源代码地址:http://download.csdn.net/detail/a123demi/7736643

Android 利用TimerTask实现ImageView图片播放效果的更多相关文章

  1. Android利用ViewFlipper实现屏幕切换动画效果

    1.屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面. 2.介绍ViewFilpper类 Vie ...

  2. android viewflipper的使用 实现图片滑动效果

    package com.homer.viewflipper; import android.app.Activity; import android.os.Bundle; import android ...

  3. android开发布局文件imageview 图片等比例缩放:

    ImageView的属性scaleType,如果等比缩放的话,就使用CenterInside,如果想固定大小的话,就CenterCrop <?xml version="1.0" ...

  4. UI特效--Android利用ViewFlipper实现屏幕切换动画效果

    .屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面.2.介绍ViewFilpper类ViewFl ...

  5. js 模拟QQ聊天窗口图片播放效果(带滚轮缩放)

    页面效果如下: 完整代码如下: <!DOCTYPE html> <html> <head> <title>Test</title> < ...

  6. Android 使用Gallery组件实现图片播放预览

    Gallery(画廊)扩展了LayoutParams,以此提供可以容纳当前的转换信息和先前的位置转换信息的场所. Activity package com.app.test01; import com ...

  7. android 利用CountDownTimer实现时分秒倒计时效果

    https://blog.csdn.net/mrzhao_perfectcode/article/details/81289578

  8. 利用 border 实现的图片选区效果,只需一层图一蒙层

    <html> <style> #p { background: url("http://soso5.gtimg.cn/sosopic_j/0/436416703332 ...

  9. Android 利用Service实现下载网络图片至sdk卡

    package com.example.myapp5; import android.app.Activity; import android.content.Intent; import andro ...

随机推荐

  1. Springboot使用AOP实现统一处理Web请求日志

    1.要使我们自定义的记录日志能够打印出来,我们需要先排除springboot默认的记录日志,添加如下的设置 2.新建 resources/log4j.properties 我的设置为: # LOG4J ...

  2. BZOJ 3060 Kruskal

    思路: 把from&to都>k的直接加边 剩下的如果是一棵树就加. 否则ans++ (我的代码写的是反着的 不过意思都一样) //By SiriusRen #include <cs ...

  3. CI中的文件上传

    //首先在控制器中装载url类和view视图: //在view视图中创建一个表单,注:在做文件上传一定要写encype=“multipart/form-data”: //form表单的提交页面应该使用 ...

  4. Android中使用GoogleMap的地理位置服务

    写在前面:android中使用地理位置功能,可以借助Google给我们提供的框架,要是有地理位置功能,你需要引用Google Play Services,请在sdk manager中下载.如果你还要使 ...

  5. 精通css学习记录

    #字体 * 无衬线字体(Sans-serif):Helvetica,Arial,'Lucida Family',Verdana,Tohoma,'Trebuchet MS'  * 有衬线字体(Serif ...

  6. 认识图片放大工具PhotoZoom的菜单栏

    使用PhotoZoom能够对数码图片无损放大,备受设计师和业内人员的青睐,它的出现时一场技术的革新,新颖的技术,简单的界面,优化的算法,使得它可以对图片进行放大而没有锯齿,不会失真.本文为您一起来认识 ...

  7. PHP迭代器的内部执行过程

    下面我们来了解如何实现一个自定义的迭代器,然后再开始慢慢理解迭代器的内部工作原理.先来看一个官方的例子: class myIterator implements Iterator { private ...

  8. 路飞学城Python-Day52

    27-选项卡 <!DOCTYPE html> <html lang="en"> <head>     <meta charset=&quo ...

  9. Angular之constructor和ngOnInit差异及适用场景(转)

    原始地址:https://blog.csdn.net/u010730126/article/details/64486997 Angular中根据适用场景定义了很多生命周期函数,其本质上是事件的响应函 ...

  10. awk手册

    awk 手册 简体中文版由bones7456 (bones7456@gmail.com)整理. 原文:应该是 http://phi.sinica.edu.tw/aspac/reports/94/940 ...