Android 利用TimerTask实现ImageView图片播放效果
在项目开发中,往往 要用到图片播放的效果。今天就用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进行循环的播放。
Android 利用TimerTask实现ImageView图片播放效果的更多相关文章
- Android利用ViewFlipper实现屏幕切换动画效果
1.屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面. 2.介绍ViewFilpper类 Vie ...
- android viewflipper的使用 实现图片滑动效果
package com.homer.viewflipper; import android.app.Activity; import android.os.Bundle; import android ...
- android开发布局文件imageview 图片等比例缩放:
ImageView的属性scaleType,如果等比缩放的话,就使用CenterInside,如果想固定大小的话,就CenterCrop <?xml version="1.0" ...
- UI特效--Android利用ViewFlipper实现屏幕切换动画效果
.屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面.2.介绍ViewFilpper类ViewFl ...
- js 模拟QQ聊天窗口图片播放效果(带滚轮缩放)
页面效果如下: 完整代码如下: <!DOCTYPE html> <html> <head> <title>Test</title> < ...
- Android 使用Gallery组件实现图片播放预览
Gallery(画廊)扩展了LayoutParams,以此提供可以容纳当前的转换信息和先前的位置转换信息的场所. Activity package com.app.test01; import com ...
- android 利用CountDownTimer实现时分秒倒计时效果
https://blog.csdn.net/mrzhao_perfectcode/article/details/81289578
- 利用 border 实现的图片选区效果,只需一层图一蒙层
<html> <style> #p { background: url("http://soso5.gtimg.cn/sosopic_j/0/436416703332 ...
- Android 利用Service实现下载网络图片至sdk卡
package com.example.myapp5; import android.app.Activity; import android.content.Intent; import andro ...
随机推荐
- Springboot使用AOP实现统一处理Web请求日志
1.要使我们自定义的记录日志能够打印出来,我们需要先排除springboot默认的记录日志,添加如下的设置 2.新建 resources/log4j.properties 我的设置为: # LOG4J ...
- BZOJ 3060 Kruskal
思路: 把from&to都>k的直接加边 剩下的如果是一棵树就加. 否则ans++ (我的代码写的是反着的 不过意思都一样) //By SiriusRen #include <cs ...
- CI中的文件上传
//首先在控制器中装载url类和view视图: //在view视图中创建一个表单,注:在做文件上传一定要写encype=“multipart/form-data”: //form表单的提交页面应该使用 ...
- Android中使用GoogleMap的地理位置服务
写在前面:android中使用地理位置功能,可以借助Google给我们提供的框架,要是有地理位置功能,你需要引用Google Play Services,请在sdk manager中下载.如果你还要使 ...
- 精通css学习记录
#字体 * 无衬线字体(Sans-serif):Helvetica,Arial,'Lucida Family',Verdana,Tohoma,'Trebuchet MS' * 有衬线字体(Serif ...
- 认识图片放大工具PhotoZoom的菜单栏
使用PhotoZoom能够对数码图片无损放大,备受设计师和业内人员的青睐,它的出现时一场技术的革新,新颖的技术,简单的界面,优化的算法,使得它可以对图片进行放大而没有锯齿,不会失真.本文为您一起来认识 ...
- PHP迭代器的内部执行过程
下面我们来了解如何实现一个自定义的迭代器,然后再开始慢慢理解迭代器的内部工作原理.先来看一个官方的例子: class myIterator implements Iterator { private ...
- 路飞学城Python-Day52
27-选项卡 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- Angular之constructor和ngOnInit差异及适用场景(转)
原始地址:https://blog.csdn.net/u010730126/article/details/64486997 Angular中根据适用场景定义了很多生命周期函数,其本质上是事件的响应函 ...
- awk手册
awk 手册 简体中文版由bones7456 (bones7456@gmail.com)整理. 原文:应该是 http://phi.sinica.edu.tw/aspac/reports/94/940 ...