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 ...
随机推荐
- C - Game With Sticks
Problem description After winning gold and silver in IOI 2014, Akshat and Malvika want to have some ...
- 从Android源码分析View绘制
在开发过程中,我们常常会来自定义View.它是用户交互组件的基本组成部分,负责展示图像和处理事件,通常被当做自定义组件的基类继承.那么今天就通过源码来仔细分析一下View是如何被创建以及在绘制过程中发 ...
- (转)vue router 如何使用params query传参,以及有什么区别
写在前面: 传参是前端经常需要用的一个操作,很多场景都会需要用到上个页面的参数,本文将会详细介绍vue router 是如何进行传参的,以及一些小细节问题.有需要的朋友可以做一下参考,喜欢的可以点波赞 ...
- 【Oracle】非RMAN恢复数据文件、控制文件
实验环境:OEL 5.6 oracle 11g(11.2.0.4.0) 注意: system表空间数据文件不能在线recover,需要启动到mount状态再recover: undo表空间数据文件可以 ...
- C++的Matlab接口
与 原文 过程有些不同,根据具体环境自行配置即可! 转自于:http://blog.csdn.net/left_la/article/details/8206645 我的计算机环境是win7 64位系 ...
- Associated Values & enum
it is sometimes useful to be able to store associated values of other types alongside these case val ...
- jq图片懒加载
jQuery图片延迟加载插件jQuery.lazyload,使用延迟加载在可提高网页下载速度.在某些情况下,它也能帮助减轻服务器负载. 使用方法 引用jquery和jquery.lazyload.js ...
- 常用CSS代码片段常见css bug
1.禁止文字被选中 .unselectable { -moz-user-select: -moz-none; -khtml-user-select: none; -webkit-user-select ...
- MongoDB经典入门(2)--shell命令
MongoDB是MongoDB自带的交互式Javascript shell,用来对MongoDB进行操作和管理的交互式环境. 使用 "./mongo --help" 可查看相关连接 ...
- java 常用API 包装 练习
package com.oracel.demo01; import java.util.Random; public class Swzy { public static void main(Stri ...