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 ...
随机推荐
- 从有约束条件下的凸优化角度思考神经网络训练过程中的L2正则化
从有约束条件下的凸优化角度思考神经网络训练过程中的L2正则化 神经网络在训练过程中,为应对过拟合问题,可以采用正则化方法(regularization),一种常用的正则化方法是L2正则化. 神经网络中 ...
- POJ 1703 带权并查集
直接解释输入了: 第一行cases. 然后是n和m代表有n个人,m个操作 给你两个空的集合 每个操作后面跟着俩数 D操作是说这俩数不在一个集合里. A操作问这俩数什么关系 不能确定:输出Not sur ...
- CCS3的过渡、变换、动画以及响应式布局、弹性布局
CSS3 过渡 .变换.动画 在没有CSS3之前,如果页面上需要一些动画效果,要么你自己编写 JavaScript,要么使用 JavaScript 框架(如 jQuery)来提高效率. 但是CSS3出 ...
- 【Oracle】ORA-55610: Invalid DDL statement on history-tracked table
—删除表emp1时出现问题 SCOTT@GOOD> drop table emp1; drop table emp1 * ERROR at line 1: ORA-55610: Invalid ...
- 信息检索及DM必备知识总结:luncene
原文链接:http://blog.csdn.net/htw2012/article/details/17734529 有少量修改!如有疑问,请访问原作者. 一:信息检索领域: 信息检索和网络数据领域( ...
- (转)基于MVC4+EasyUI的Web开发框架经验总结(2)- 使用EasyUI的树控件构建Web界面
http://www.cnblogs.com/wuhuacong/p/3669575.html 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开 ...
- GNU/Linux分支图
- phpunit使用
phpunit使用 标签(空格分隔): php 现在是凌晨 3 点.我们怎样才能知道自己的代码依然在工作呢? Web 应用程序是 24x7 不间断运行的,因此我的程序是否还在运行这个问题会在晚上一直困 ...
- phthon中的open函数模式
原文地址:http://www.runoob.com/python/python-func-open.html r 以只读方式打开文件.文件的指针将会放在文件的开头.这是默认模式. rb 以二进制格式 ...
- redis_2 数据类型
1.key Redis keys 命令 下表给出了与 Redis 键相关的基本命令: 序号 命令及描述 1 DEL key该命令用于在 key 存在时删除 key. 2 DUMP key 序列化给定 ...