Service和广播联合更新UI的例子

sa111111 于 2010-11-19 10:56 发表在 [Android实例] [复制链接] [只看楼主] [上一主题] [下一主题]

在Android中,异步更新UI,通常我们会选用Handler启动线程,或者sendMessage的方式,那么利用Service和广播也可以更新UI的,例子如下:
我们建立一个Service:
package com.andy
import android.app.Service;//引入相关包
import android.content.BroadcastReceiver;//引入相关包
import android.content.Context;//引入相关包
import android.content.Intent;//引入相关包
import android.content.IntentFilter;//引入相关包
import android.os.IBinder;//引入相关包
//继承自Service的子类
public class MyService extends Service{
        CommandReceiver cmdReceiver;
        boolean flag;
        @Override
        public void onCreate() {//重写onCreate方法
                flag = true;
                cmdReceiver = new CommandReceiver();
                super.onCreate();
        }
        @Override
        public IBinder onBind(Intent intent) {//重写onBind方法
                // TODO Auto-generated method stub
                return null;
        }
        @Override
        public int onStartCommand(Intent intent, int flags, int startId) {//重写onStartCommand方法
                IntentFilter filter = new IntentFilter();//创建IntentFilter对象
                filter.addAction("wyf.wpf.MyService");
                registerReceiver(cmdReceiver, filter);//注册Broadcast Receiver
                doJob();//调用方法启动线程
                return super.onStartCommand(intent, flags, startId);
        }
        //方法:
        public void doJob(){
                new Thread(){
                        public void run(){
                                while(flag){
                                        try{//睡眠一段时间
                                                Thread.sleep(1000);
                                        }
                                        catch(Exception e){
                                                e.printStackTrace();
                                        }
                                        Intent intent = new Intent();//创建Intent对象
                                        intent.setAction("wyf.wpf.Sample_3_6");
                                        intent.putExtra("data", Math.random());
                                        sendBroadcast(intent);//发送广播
                                }                               
                        }
                       
                }.start();
        }       
        private class CommandReceiver extends BroadcastReceiver{//继承自BroadcastReceiver的子类
                @Override
                public void onReceive(Context context, Intent intent) {//重写onReceive方法
                        int cmd = intent.getIntExtra("cmd", -1);//获取Extra信息
                        if(cmd == Sample_3_6.CMD_STOP_SERVICE){//如果发来的消息是停止服务                               
                                flag = false;//停止线程
                                stopSelf();//停止服务
                        }
                }               
        }
        @Override
        public void onDestroy() {//重写onDestroy方法
                this.unregisterReceiver(cmdReceiver);//取消注册的CommandReceiver
                super.onDestroy();
        }       
}

建立一个activity

package com.andy;//声明包语句
import android.app.Activity;//引入相关包
import android.content.BroadcastReceiver;//引入相关包
import android.content.Context;//引入相关包
import android.content.Intent;//引入相关包
import android.content.IntentFilter;//引入相关包
import android.os.Bundle;//引入相关包
import android.view.View;//引入相关包
import android.view.View.OnClickListener;//引入相关包
import android.widget.Button;//引入相关包
import android.widget.TextView;//引入相关包
//继承自Activity的子类
public class Sample_3_6 extends Activity {
        public static final int CMD_STOP_SERVICE = 0;
        Button btnStart;//开始服务Button对象应用
        Button btnStop;//停止服务Button对象应用
        TextView tv;//TextView对象应用
        DataReceiver dataReceiver;//BroadcastReceiver对象
        @Override
    public void onCreate(Bundle savedInstanceState) {//重写onCreate方法
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);//设置显示的屏幕
        btnStart = (Button)findViewById(R.id.btnStart);
        btnStop = (Button)findViewById(R.id.btnStop);
        tv = (TextView)findViewById(R.id.tv);
        btnStart.setOnClickListener(new OnClickListener() {//为按钮添加点击事件监听               
                        @Override
                        public void onClick(View v) {//重写onClick方法
                                Intent myIntent = new Intent(Sample_3_6.this, wyf.wpf.MyService.class);
                                Sample_3_6.this.startService(myIntent);//发送Intent启动Service
                        }
                });
        btnStop.setOnClickListener(new OnClickListener() {//为按钮添加点击事件监听       
                        @Override
                        public void onClick(View v) {//重写onClick方法
                                Intent myIntent = new Intent();//创建Intent对象
                                myIntent.setAction("wyf.wpf.MyService");
                                myIntent.putExtra("cmd", CMD_STOP_SERVICE);
                                sendBroadcast(myIntent);//发送广播
                        }
                });
    }       
        private class DataReceiver extends BroadcastReceiver{//继承自BroadcastReceiver的子类
                @Override
                public void onReceive(Context context, Intent intent) {//重写onReceive方法
                        double data = intent.getDoubleExtra("data", 0);
                        tv.setText("Service的数据为:"+data);                       
                }               
        }
        @Override
        protected void onStart() {//重写onStart方法
                dataReceiver = new DataReceiver();
                IntentFilter filter = new IntentFilter();//创建IntentFilter对象
                filter.addAction("wyf.wpf.Sample_3_6");
                registerReceiver(dataReceiver, filter);//注册Broadcast Receiver
                super.onStart();
        }
        @Override
        protected void onStop() {//重写onStop方法
                unregisterReceiver(dataReceiver);//取消注册Broadcast Receiver
                super.onStop();
        }

}

Service和广播联合更新UI的例子

时间: 2024-12-14 18:09:00

Service和广播联合更新UI的例子的相关文章

Android线程间通信更新UI的方法(重点分析EventBus)

Android的UI更新只能在UI线程中,即主线程.子线程中如果要进行UI更新,都是要通知主线程来进行. 几种实现方式总结如下,欢迎补充. 1.runOnUiThread() 子线程中持有当前Activity引用(假如为Activity mActivity;),即可以调用mActivity的runOnUiThread(Runnable r)方法. 2.post()和postDelay() 子线程如果持有某个View的引用,要对该View进行更新,则可调用该View对象的post(Runnable

Android开发——实现子线程更新UI

Android中线程按功能分的话,可以分为两个,一个是主线程(UI线程),其他的都是子线程 主线程不能执行那些耗时过长的代码或任务(执行耗时过长的代码会出现应用未响应的提示),所以都是使用子线程来执行耗时过长的代码,比如说下载文件等任务 一般情况,子线程中执行过长的代码,都是需要进行更新UI操作. 但是Android中,为了防止安全,是不允许在子线程更新UI的,但是我们可以使用到Android官方给予的API来实现子线程更新UI的操作(本质上,这些API也是切换回了主线程来进行更新UI) 例子:

Android 通过广播来异步更新UI

之前的项目里要做一个异步更新UI的功能,但是结果出现了ANR,所以想写个demo来测试到底是哪个地方出现了问题,结果发现原来的思路是没有问题,郁闷~~ 现在这个demo 就是模拟项目里面 的步骤 1.接收到系统的广播(现在模拟为人工发送) 2.广播接收到后,handler通知异步线程从网上下载数据,是异步(模拟为sleep) 3.数据下载完后handler再通知UI更新 下面是主要的两个代码,能够正确运行 package com.example.testanr; import android.s

Service 动态更新 UI

http://blog.csdn.net/u013724061/article/details/38642049 最终效果: 动态显示当前时间和电量 思路: 首先在Activity里用内部类定义两种广播,一种是系统广播(电池),另一种是自定义广播. private class SimpleBroadcastReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent int

关于Handler的理解,子线程不能更新UI的纠正和回调的思考

开发Android这么久了,总会听到有人说:主线程不能访问网络,子线程不能更新UI.Android的主线程的确不能长时间阻塞,但是子线程为什么不能更新UI呢?今天把这些东西整理,顺便在子线程更新UI. 首先写了一个handler在子线程更新主线程UI,在子线程做了一个耗时操作:从网络下载了一个图片并利用handler发送到handleMessage()的回调中,并更新到主线程的bitmap.图片显示成功,没有问题.接下来在子线程中更新onCreate()中实例化的textview,报错: and

Android关于线程更新UI的方法

Android关于线程更新UI的方法 在一个Android 程序开始运行的时候,会单独启动一个Process.默认的情况下,所有这个程序中的Activity或者Service(Service和 Activity只是Android提供的Components中的两种,除此之外还有Content Provider和Broadcast Receiver)都会跑在这个Process.   一个Android 程序默认情况下也只有一个Process,但一个Process下却可以有许多个Thread.   在

Android 线程更新UI报错 : Can't create handler inside thread that has not called Looper.prepare()

MainActivity中有一个按钮,绑定了save方法 public void save(View view) { String title = titleText.getText().toString(); String timelength = lengthText.getText().toString(); ExecutorService exec = Executors.newCachedThreadPool(); exec.execute(new NewsService(getApp

Android异步处理一:使用Thread+Handler实现非UI线程更新UI界面

Android应用的开发过程中需要把繁重的任务(IO,网络连接等)放到其他线程中异步执行,达到不阻塞UI的效果. 下面将由浅入深介绍Android进行异步处理的实现方法和系统底层的实现原理. 本文介绍Android异步处理一:使用Thread+Handler实现非UI线程更新UI界面: 即如何使用Thread+Handler的方式从非UI线程发送界面更新消息到UI线程. 概述:每个Android应用程序都运行在一个dalvik虚拟机进程中,进程开始的时候会启动一个主线程(MainThread),

Android中子线程真的不能更新UI吗?

Android的UI访问是没有加锁的,这样在多个线程访问UI是不安全的.所以Android中规定只能在UI线程中访问UI. 但是有没有极端的情况?使得我们在子线程中访问UI也可以使程序跑起来呢?接下来我们用一个例子去证实一下. 新建一个工程,activity_main.xml布局如下所示: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http: