Android中Service的一个Demo例子
  Service组件是Android系统重要的一部分,网上看了代码,很简单,但要想熟练使用还是需要Coding。
  本文,主要贴代码,不对Service做过多讲解。
  代码是从网上找的一个例子,Copy下来发现代码不完全正确,稍微修改了下。
  AndroidManifest.xml
   

<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:label="@string/app_name"
android:name=".service.ServiceMainActivity" >
<intent-filter >
<action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<!-- 注册Service -->
<service android:name="LocalService">
<intent-filter>
<action android:name="cn.fansunion.service.LocalService" />
</intent-filter>
</service>
</application>

ServiceMainActivity.java

package cn.fansunion.service;

import cn.fansunion.R;
import android.app.Activity;
import android.app.Service;
import android.content.ComponentName;
import android.content.Intent;
import android.content.ServiceConnection;
import android.os.Bundle;
import android.os.IBinder;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast; public class ServiceMainActivity extends Activity {
private Button startBtn;
private Button stopBtn;
private Button bindBtn;
private Button unBindBtn;
private static final String TAG = "MainActivity";
private LocalService myService; @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.service);
startBtn = (Button) findViewById(R.id.start);
stopBtn = (Button) findViewById(R.id.stop);
bindBtn = (Button) findViewById(R.id.bind);
unBindBtn = (Button) findViewById(R.id.unbind);
startBtn.setOnClickListener(new MyOnClickListener());
stopBtn.setOnClickListener(new MyOnClickListener());
bindBtn.setOnClickListener(new MyOnClickListener());
unBindBtn.setOnClickListener(new MyOnClickListener());
} class MyOnClickListener implements OnClickListener {
@Override
public void onClick(View v) {
Intent intent = new Intent();
intent.setClass(ServiceMainActivity.this, LocalService.class);
switch (v.getId()) {
case R.id.start:
// 启动Service
startService(intent);
toast("startService");
break;
case R.id.stop:
// 停止Service
stopService(intent);
toast("stopService");
break;
case R.id.bind:
// 绑定Service
bindService(intent, conn, Service.BIND_AUTO_CREATE);
toast("bindService");
break;
case R.id.unbind:
// 解除Service
unbindService(conn);
toast("unbindService");
break;
}
}
} private void toast(final String tip){
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(getApplicationContext(), tip, Toast.LENGTH_SHORT).show();
}
});
}
private ServiceConnection conn = new ServiceConnection() {
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
Log.e(TAG, "连接成功");
// 当Service连接建立成功后,提供给客户端与Service交互的对象(根据Android Doc翻译的,不知道准确否。。。。)
myService = ((LocalService.LocalBinder) service).getService();
} @Override
public void onServiceDisconnected(ComponentName name) {
Log.e(TAG, "断开连接");
myService = null;
}
};
}

LocalService.java

package cn.fansunion.service;

import android.app.Service;
import android.content.Intent;
import android.os.Binder;
import android.os.IBinder;
import android.util.Log;
import android.widget.Toast; public class LocalService extends Service {
private static final String TAG = "MyService";
private final IBinder myBinder = new LocalBinder(); @Override
public IBinder onBind(Intent intent) {
Log.e(TAG, "onBind()");
//Toast.makeText(this, "onBind()", Toast.LENGTH_SHORT).show();
return myBinder;
} // 调用startService方法或者bindService方法时创建Service时(当前Service未创建)调用该方法
@Override
public void onCreate() {
Log.e(TAG, "onCreate()");
//Toast.makeText(this, "onCreate()", Toast.LENGTH_SHORT).show();
} // 调用startService方法启动Service时调用该方法
@Override
public void onStart(Intent intent, int startId) {
Log.e(TAG, "onStart()");
//Toast.makeText(this, "onStart()", Toast.LENGTH_SHORT).show();
} // Service创建并启动后在调用stopService方法或unbindService方法时调用该方法
@Override
public void onDestroy() {
Log.e(TAG, "onDestroy()");
//Toast.makeText(this, "onDestroy()", Toast.LENGTH_SHORT).show();
}
//提供给客户端访问
public class LocalBinder extends Binder {
LocalService getService() {
return LocalService.this;
}
}
}

service.xml布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent">
<Button android:id="@+id/start" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="启动Service" />
<Button android:id="@+id/stop" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="停止Service" />
<Button android:id="@+id/bind" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="绑定Service" />
<Button android:id="@+id/unbind" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="解除Service" />
</LinearLayout>

[2015-11-14 17:39:10 - xp2p4android] ------------------------------
[2015-11-14 17:39:10 - xp2p4android] Android Launch!
[2015-11-14 17:39:10 - xp2p4android] adb is running normally.
[2015-11-14 17:39:10 - xp2p4android] Performing cn.fansunion.service.ServiceMainActivity activity launch
[2015-11-14 17:39:10 - xp2p4android] Automatic Target Mode: using device '51bf63f2'
[2015-11-14 17:39:10 - xp2p4android] Uploading xp2p4android.apk onto device '51bf63f2'
[2015-11-14 17:39:10 - xp2p4android] Installing xp2p4android.apk...
[2015-11-14 17:39:13 - xp2p4android] Success!
[2015-11-14 17:39:13 - xp2p4android] Starting activity cn.fansunion.service.ServiceMainActivity on device 51bf63f2
[2015-11-14 17:39:13 - xp2p4android] ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=cn.fansunion/.service.ServiceMainActivity }
[2015-11-14 17:39:13 - xp2p4android] Attempting to connect debugger to 'cn.fansunion' on port 8600

运行效果图

原来的代码,Toast对话框没有展示出来。
在CSDN论坛找到一个贴子说,可能是被手机屏蔽了。
我倒是觉得更有可能调用的方式不对。
Service中调用,Toast合适么?
public void onCreate() {
Log.e(TAG, "onCreate()");
//Toast.makeText(this, "onCreate()", Toast.LENGTH_SHORT).show();
}

最后参考网友的办法,在UI线程,新建线程执行Toast。
private void toast(final String tip){
runOnUiThread(new Runnable() {  
            @Override
            public void run() {
            Toast.makeText(getApplicationContext(), tip, Toast.LENGTH_SHORT).show();                         
            }
        });
}
不错,是在Activity中调用的。

这充分说明,网上代码再漂亮,还是得动手运行下。
代码的那个贴子,是2011年了,好古老啊~

参考资料
Android中Service组件详解
http://blog.csdn.net/zuolongsnail/article/details/6427037

Android Toast显示不出来
http://bbs.csdn.net/topics/390889540

Android中Service的一个Demo例子的更多相关文章

  1. Android中Service的使用详解和注意点(LocalService)

    Android中Service的使用详解和注意点(LocalService) 原文地址 开始,先稍稍讲一点android中Service的概念和用途吧~ Service分为本地服务(LocalServ ...

  2. Android中Service(服务)详解

    http://blog.csdn.net/ryantang03/article/details/7770939 Android中Service(服务)详解 标签: serviceandroidappl ...

  3. 在Android中动画移动一个View的位置,采用Scroller类实现Android动画之 View移动

    在Android中动画移动一个View的位置,采用Scroller类实现 今天说最近自己遇到的一个问题,就是要用动画效果来移动一个VIew的位置. 这个具体的情况是,需要做一个SlidingMenu的 ...

  4. Angular2 不明真相第一个Demo例子

    如果不是去年换工作接触到AngularJS,估计是不会花时间去学习这个框架的,毕竟是前端的框架,不是自己熟悉的领域.但是为了混得下去,去年就学习了AngularJS的一些用法,当时还整理了一些积累 & ...

  5. android中service启动后台程序

    Service是Android中一个类,它是Android四大组件之一,使用Service可以在后台执行长时间的操作( perform long-running operations in the b ...

  6. Android中如何搭建一个WebServer

    今天终于把老大交代的任务搞完了,感觉收获挺多的,所以就写一篇来记录一下吧,首先还是来看一下,老大们的需求 需求: 希望移动端的用户标识(IMEI)和HTML页面的用户标识(Cookie)连接起来,其中 ...

  7. Android中Service和Activity之间的通信

    启动Service并传递数据进去: Android中通过Intent来启动服务会传递一个Intent过去. 可以在Intent中通过putExtra()携带数据 Intent startIntent ...

  8. Android中Service 使用详解(LocalService + RemoteService)

    Service 简介: Service分为本地服务(LocalService)和远程服务(RemoteService): 1.本地服务依附在主进程上而不是独立的进程,这样在一定程度上节约了资源,另外L ...

  9. Android中Service的使用

    我个人的理解是:我们平时使用的android系统的app的后台应用,就是这个原理 可以利用Service实现程序在后台运行,依照这个原理,可以通过Service来实现关键代码的运行与实现. <一 ...

随机推荐

  1. Android核心服务解析篇(三)——Android系统的启动

    从大的方面来说.Android系统的启动能够分为两个部分:第一部分是Linux核心的启动,第二部分是Android系统的启动. 第一部分主要包含系统引导,核心和驱动程序等,因为它们不属于本篇要讲的内容 ...

  2. Unity渲染

    我们先大概了解一下对渲染的优先级有影响的几个因素 1.Camera.Depth 不同相机的深度,在渲染顺序的优先度里面是最高的,Depth越大,渲染的图像越靠前 2.Render.SortingOrd ...

  3. 黑马程序猿-----Java之你不得不知道的排序

    ------<a href="http://www.itheima.com" target="blank">Java培训.Android培训.iOS ...

  4. Android实战技巧之三十七:图片的Base64编解码

    通经常使用Base64这样的编解码方式将二进制数据转换成可见的字符串格式,就是我们常说的大串.10块钱一串的那种,^_^. Android的android.util包下直接提供了一个功能十分完备的Ba ...

  5. HP-lefthand底层结构具体解释及存储灾难数据恢复

    HP-lefthand底层结构具体解释及存储灾难数据恢复 一.HP-lefthand的特点 HP-lefhand是一款很不错的SAN存储,使用iscsi协议为client分配空间. 它支持RAID5. ...

  6. nyoj--12--喷水装置(二)(区间覆盖问题+贪心)

    喷水装置(二) 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描述 有一块草坪,横向长w,纵向长为h,在它的橫向中心线上不同位置处装有n(n<=10000)个点状的喷水 ...

  7. python 字符串匹配问题

    想匹配html = <div class="back fl"><a href="javascript:void(0);" onclick=&q ...

  8. Bayes++ Library入门学习之熟悉class-Bayesian_filter_base(2)

    前面我们已经熟悉了Bayesian_filter::Bayes_filter_base和其子类的击继承关系,接下来我们开始学习该类的实现. bayesFlt.hpp文件为其实现主体,首先是两个常规的头 ...

  9. JS中的switch case

    function GetDepartmentName(type) { switch (type) { case DepartMentQian: alert($('#DepartMentQian').v ...

  10. 用SAXReader解析xml文档【转】

    来源:http://blog.csdn.net/seayqrain/article/details/5024068 使用SAXReader需要导入dom4j-full.jar包. dom4j是一个Ja ...