Android Service 组件

简介:
Service是Androd系统提供的四种组件之一,它的地位和Activity是并列的,只不过没有Activity的使用频率高。顾名思义Service就是运行在后台的一种服务程序,一般很少和用户交互,因此没有可视化界面。

下面我们演示一下如何创建一个Service:
1:我们通过布局文件layout/main.xml创建一个启动、停止、及绑定一个Service
<?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/startButton01"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="启动Service"
  />
  <Button
    android:id="@+id/stopButton02"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="停止Service"
  />
  <Button
    android:id="@+id/bindButton03"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="绑定Service"
  />
  <Button
    android:id="@+id/unbindButton04"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="解除绑定"
  />
</LinearLayout>
2:我们创建一个MainActivity.java来实现Service
package com.android.test;

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 MainActivity  extends Activity {
     
   private Button startBtn, stopBtn, bindBtn, unbindBtn;
  
         public  void onCreate(Bundle savedInstanceState) {
                 super.onCreate(savedInstanceState);
                setContentView(R.layout.main);
                 //实例化Button
                startBtn = (Button)findViewById(R.id.startButton01);
                stopBtn = (Button)findViewById(R.id.stopButton02);
                bindBtn = (Button)findViewById(R.id.bindButton03);
                unbindBtn = (Button)findViewById(R.id.unbindButton04);
                 //添加监听器
                startBtn.setOnClickListener(startListener);
                stopBtn.setOnClickListener(stopListener);
                bindBtn.setOnClickListener(bindListener);
                unbindBtn.setOnClickListener(unBindListener);
        }
         //启动Service监听器
         private OnClickListener startListener =  new OnClickListener() {

     public  void onClick(View v) {
      Intent intent =  new Intent();
       //设置Action属性
      intent.setAction( "com.android.test.action.MY_SERVICE");
      startService(intent);
    }
          
        };
         //停止Service监听器
         private OnClickListener stopListener =  new OnClickListener() {

     public  void onClick(View v) {
      Intent intent =  new Intent();
      intent.setAction( "com.android.test.action.MY_SERVICE");
      stopService(intent);
    }
        };
         //绑定Service监听器
         private OnClickListener bindListener =  new OnClickListener() {

     public  void onClick(View v) {
      Intent intent =  new Intent();
      intent.setAction( "com.android.test.action.MY_SERVICE");
       //绑定Service
      bindService(intent, conn, Service.BIND_AUTO_CREATE);
    }
        };
         //解除Service监听器
         private OnClickListener unBindListener =  new OnClickListener() {

     public  void onClick(View v) {
      Intent intent =  new Intent();
      intent.setAction( "com.android.test.action.MY_SERVICE");
       //解除绑定
      unbindService(conn);
    }
        };
        
         private ServiceConnection conn =  new ServiceConnection() {

     public  void onServiceConnected(ComponentName name, IBinder service) {
      Log.i( "SERVICE""连接成功!");
      Toast.makeText(MainActivity. this"连接成功!", Toast.LENGTH_LONG).show();
    }

     public  void onServiceDisconnected(ComponentName name) {
      Log.i( "SERVICE""断开连接!");
      Toast.makeText(MainActivity. this"断开连接!", Toast.LENGTH_LONG).show();
    }      
        };
3:创建一个MyService.java继承Service,覆盖其声明周期中的方法,并在各个方法中显示信息
package com.android.test;

import android.app.Service;
import android.content.Intent;
import android.os.IBinder;
import android.util.Log;
import android.widget.Toast;

public  class MyService  extends Service {
   //可以返回null,通常返回一个aidl定义的接口
   public IBinder onBind(Intent intent) {
    Log.i( "SERVICE""onBind......");
    Toast.makeText(MyService. this"onBind......", Toast.LENGTH_LONG).show();
     return  null;
  }
   //Service创建时调用
   public  void onCreate() {
    Log.i( "SERVICE""onCreate......");
  }
   //当客户端调用startService()方法启动Service时,该方法被调用
   public  void onStart(Intent intent,  int startId) {
    Log.i( "SERVICE""onStart......");
    Toast.makeText(MyService. this"onStart......", Toast.LENGTH_LONG).show();
  }
   //当Service不再使用时调用
   public  void onDestroy() {
    Log.i( "SERVICE""onDestroy......");
    Toast.makeText(MyService. this"onDestroy......", Toast.LENGTH_LONG).show();
  }
}
4:在AndroidManifest.xml配置文件中声明Activity和Service
<?xml version= "1.0" encoding= "utf-8"?>
<manifest xmlns:android= "http://schemas.android.com/apk/res/android"
            package="com.android.test"
            android:versionCode="1"
            android:versionName="1.0">
        <application android:icon="@drawable/icon" android:label="@string/app_name">
                <activity android:name=".MainActivity"
                                    android:label="@string/app_name">
                        <intent-filter>
                                <action android:name="android.intent.action.MAIN" />
                                <category android:name="android.intent.category.LAUNCHER" />
                        </intent-filter>
                </activity>
    <service android:name="MyService">
      <intent-filter>
        <action android:name="com.android.test.action.MY_SERVICE"/>
      </intent-filter>
    </service>
        </application>
        <uses-sdk android:minSdkVersion="4" />

</manifest>
运行如图:









本文转自 Art_Hero 51CTO博客,原文链接:http://blog.51cto.com/curran/527777,如需转载请自行联系原作者
目录
打赏
0
0
0
0
234
分享
相关文章
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
深入理解安卓应用开发的核心组件
【10月更文挑战第8天】探索Android应用开发的精髓,本文带你了解安卓核心组件的奥秘,包括Activity、Service、BroadcastReceiver和ContentProvider。我们将通过代码示例,揭示这些组件如何协同工作,构建出功能强大且响应迅速的应用程序。无论你是初学者还是资深开发者,这篇文章都将为你提供新的视角和深度知识。
安卓应用开发中的自定义View组件
【10月更文挑战第5天】在安卓应用开发中,自定义View组件是提升用户交互体验的利器。本篇将深入探讨如何从零开始创建自定义View,包括设计理念、实现步骤以及性能优化技巧,帮助开发者打造流畅且富有创意的用户界面。
154 0
安卓开发中的自定义视图:打造个性化UI组件
在安卓应用开发中,自定义视图是一种强大的工具,它允许开发者创造独一无二的用户界面元素,从而提升应用的外观和用户体验。本文将通过一个简单的自定义视图示例,引导你了解如何在安卓项目中实现自定义组件,并探讨其背后的技术原理。我们将从基础的View类讲起,逐步深入到绘图、事件处理以及性能优化等方面。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
43. 【Android教程】服务:Service
43. 【Android教程】服务:Service
72 2
安卓应用开发中的自定义View组件
【10月更文挑战第5天】自定义View是安卓应用开发的一块基石,它为开发者提供了无限的可能。通过掌握其原理和实现方法,可以创造出既美观又实用的用户界面。本文将引导你了解自定义View的创建过程,包括绘制技巧、事件处理以及性能优化等关键步骤。
深入解析Android架构组件——Jetpack的使用与实践
本文旨在探讨谷歌推出的Android架构组件——Jetpack,在现代Android开发中的应用。Jetpack作为一系列库和工具的集合,旨在帮助开发者更轻松地编写出健壮、可维护且性能优异的应用。通过详细解析各个组件如Lifecycle、ViewModel、LiveData等,我们将了解其原理和使用场景,并结合实例展示如何在实际项目中应用这些组件,提升开发效率和应用质量。
85 6
深入解析Android应用开发中的四大核心组件
本文将探讨Android开发中的四大核心组件——Activity、Service、BroadcastReceiver和ContentProvider。我们将深入了解每个组件的定义、作用、使用方法及它们之间的交互方式,以帮助开发者更好地理解和应用这些组件,提升Android应用开发的能力和效率。
396 5
安卓应用开发中的自定义View组件实践
【9月更文挑战第10天】在安卓开发领域,自定义View是提升用户体验和实现界面个性化的重要手段。本文将通过一个实际案例,展示如何在安卓项目中创建和使用自定义View组件,包括设计思路、实现步骤以及可能遇到的问题和解决方案。文章不仅提供了代码示例,还深入探讨了自定义View的性能优化技巧,旨在帮助开发者更好地掌握这一技能。
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!

热门文章

最新文章

  • 1
    如何修复 Android 和 Windows 不支持视频编解码器的问题?
    44
  • 2
    Android历史版本与APK文件结构
    126
  • 3
    【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    34
  • 4
    当flutter react native 等混开框架-并且用vscode-idea等编译器无法打包apk,打包安卓不成功怎么办-直接用android studio如何打包安卓apk -重要-优雅草卓伊凡
    4
  • 5
    APP-国内主流安卓商店-应用市场-鸿蒙商店上架之必备前提·全国公安安全信息评估报告如何申请-需要安全评估报告的资料是哪些-优雅草卓伊凡全程操作
    10
  • 6
    【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    9
  • 7
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    40
  • 8
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    34
  • 9
    Android经典面试题之Kotlin中Lambda表达式和匿名函数的区别
    1
  • 10
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    29
  • 1
    escrcpy:【技术党必看】Android开发,Escrcpy 让你无线投屏新体验!图形界面掌控 Android,30-120fps 超流畅!🔥
    25
  • 2
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    28
  • 3
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    29
  • 4
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    40
  • 5
    Android历史版本与APK文件结构
    126
  • 6
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    34
  • 7
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
    27
  • 8
    APP-国内主流安卓商店-应用市场-鸿蒙商店上架之必备前提·全国公安安全信息评估报告如何申请-需要安全评估报告的资料是哪些-优雅草卓伊凡全程操作
    60
  • 9
    【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    38
  • 10
    当flutter react native 等混开框架-并且用vscode-idea等编译器无法打包apk,打包安卓不成功怎么办-直接用android studio如何打包安卓apk -重要-优雅草卓伊凡
    73
  • AI助理

    你好,我是AI助理

    可以解答问题、推荐解决方案等