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 ...
随机推荐
- H3BPM子表的复制
在做一个流程的时候,碰到了下面的表数据直接从上表中获取,并且为不可编辑状态,没有增加和删除行的按钮.一开始使用的是ComputationRule属性,但是有一项是日期空间,没有这个属性,不知道怎么处理 ...
- Devexpress PdfViewer预览pdf,禁止下载,打印,复制
PDFviewer控件: 参数设置: 1.屏蔽书签栏和右键菜单 2.加载文档支持路径以及流stream加载的方式 pdfViewer.MenuManager.DisposeManager(); pdf ...
- python爬虫:读取PDF
下面的代码可以实现用python读取PDF,包括读取本地和网络上的PDF. pdfminer下载地址:https://pypi.python.org/packages/source/p/pdfmine ...
- **PCD数据获取:Kinect+OpenNI+PCL对接(代码)
前言: PCL使用点云作为数据格式,Kinect可以直接作为三维图像的数据源产生三维数据,其中的桥梁是OpenNI和PrimeSense.为了方便地使用Kinect的数据,还是把OpenNI获取的基础 ...
- springboot-helloworld实现
springboot快速入门 首先,建立一个空的项目 第二步: 建立一个springboot项目 第三步:添加依赖: <?xml version="1.0" encoding ...
- Flex元素布局规则总结,以及布局和容器
一.Flex中的元素分类从功能层面可以把Flex中的元素分为组件(Components)和容器(Containers)两大类:组件 - 是指那类具有明确交互或数据展示功能的元素,例如Button.Ch ...
- css3 3d 魔方
<style><!--@charset "UTF-8"; * { margin: 0; padding: 0 } html,body{ width: 100%; ...
- 洛谷P1567 统计天数
题目背景 统计天数 题目描述 炎热的夏日,KC非常的不爽.他宁可忍受北极的寒冷,也不愿忍受厦门的夏天.最近,他开始研究天气的变化.他希望用研究的结果预测未来的天气. 经历千辛万苦,他收集了连续N(1& ...
- 【Tool】Mac环境维护
1. 安装编译opencv https://blog.csdn.net/lijiang1991/article/details/50756065 /Users/yuhua.cheng/Opt/open ...
- Linux 字符设备驱动简单总结(转)
http://my.oschina.net/u/1169027/blog/191538