2-AIII--Service服务的绑定

简介: 零、前言1.在绑定时调用计时器,间隔打印时间2.解绑时解除计时器3.在Activity中调用Service的方法绑定服务.gif一、代码实现1.

零、前言

1.在绑定时调用计时器,间隔打印时间
2.解绑时解除计时器
3.在Activity中调用Service的方法

绑定服务.gif

一、代码实现

1.服务类:BindTestService
public class BindTestService extends Service {
    private static final String TAG = "BindTestService";
    private TimerTask mRunTimerTask;

    @Override
    public void onCreate() {
        super.onCreate();
        Log.e(TAG, "onCreate: ");
    }
    
    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        Log.e(TAG, "onStartCommand: ");
        return super.onStartCommand(intent, flags, startId);
    }

    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        Log.e(TAG, "onBind: ");

        //使用计时器间隔打印时间
        Timer timer = new Timer();
        mRunTimerTask = new TimerTask() {
            @Override
            public void run() {
                System.out.println("scheduledExecutionTime:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")
                        .format(scheduledExecutionTime()));
            }
        };
        //延迟3秒,2秒周期执行
        timer.schedule(mRunTimerTask, 3000L,2 * 1000L);
        Log.e(TAG, "计时器已开启");
        return new MyBinder();
    }

    @Override
    public boolean onUnbind(Intent intent) {
        Log.e(TAG, "onUnbind: 成功解绑");
        mRunTimerTask.cancel();
        Log.e(TAG, "计时器已取消");
        return super.onUnbind(intent);
    }
}
2.MyBinder类
/**
 * 作者:张风捷特烈
 * 时间:2018/8/25 0025:11:09
 * 邮箱:1981462002@qq.com
 * 说明:Service的onBind方法返回一个IBinder对象
 * 该对象在是Service与Activity的连接人,在Activity可以获取该对象
 */
public class MyBinder extends Binder {
    public void methodInService() {
        System.out.println("我是服务里的方法");
    }
}
3.注册:app/src/main/AndroidManifest.xml
<service android:name=".bind.BindTestService"/>
4.Activity页:
public class BindActivity extends AppCompatActivity {

    @BindView(R.id.id_btn_bind)
    Button mIdBtnBind;
    @BindView(R.id.id_btn_unbind)
    Button mIdBtnUnbind;
    private ServiceConnection mConn;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_bind);
        ButterKnife.bind(this);
    }

    @OnClick({R.id.id_btn_bind, R.id.id_btn_unbind})
    public void onViewClicked(View view) {
        switch (view.getId()) {
            case R.id.id_btn_bind:
                // [0]启动服务
                Intent intent = new Intent(this, BindTestService.class);
                startService(intent);
                //[1]创建连接对象
                mConn = new ServiceConnection() {
                    // 当连接成功时候调用
                    @Override
                    public void onServiceConnected(ComponentName name, IBinder service) {
                        MyBinder binder = (MyBinder) service;
                        binder.methodInService();
                    }
                    // 当连接断开时候调用
                    @Override
                    public void onServiceDisconnected(ComponentName name) {

                    }
                };
                //[2]绑定服务启动
                bindService(intent, mConn, BIND_AUTO_CREATE);
                break;
            case R.id.id_btn_unbind:
                //[3]解绑服务启动
                    unbindService(mConn);
                break;
        }
    }
}

开启服务时:onCreate==>onStartCommand
绑定时:onBind
解绑时:onUnbind

附录布局:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".BindActivity">

    <Button
        android:id="@+id/id_btn_bind"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:text="绑定服务"
        app:layout_constraintEnd_toStartOf="@+id/id_btn_unbind"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"/>

    <Button
        android:id="@+id/id_btn_unbind"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="解绑服务"
        app:layout_constraintStart_toEndOf="@+id/id_btn_bind"
        app:layout_constraintTop_toTopOf="@+id/id_btn_bind"/>

</android.support.constraint.ConstraintLayout>

后记、

1.声明:

[1]本文由张风捷特烈原创,转载请注明
[2]欢迎广大编程爱好者共同交流
[3]个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正
[4]你的喜欢与支持将是我最大的动力

2.连接传送门:

更多安卓技术欢迎访问:安卓技术栈
我的github地址:欢迎star
简书首发,腾讯云+社区同步更新
张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com

3.联系我

QQ:1981462002
邮箱:1981462002@qq.com
微信:zdl1994328

4.欢迎关注我的微信公众号,最新精彩文章,及时送达:
公众号.jpg
相关文章
|
前端开发
element ui el-table 多选 表头全选框替换文字
element ui el-table 多选 表头全选框替换文字
1868 0
|
JSON 监控 关系型数据库
Docker 容器日志分析
Docker 容器日志分析
601 0
|
5月前
|
Java 应用服务中间件 Maven
在IntelliJ IDEA中如何配置使用Maven以创建Tomcat环境
所以,别担心这些工具看起来有些吓人,实际上这些都是为了帮助你更好的完成工作的工具,就像超市里的各种烹饪工具一样,尽管它们看起来可能很复杂,但只要你学会用,它们会为你烹饪出一道道美妙的食物。这就是学习新技能的乐趣,让我们一起享受这个过程,攀登知识的高峰!
330 27
人脸对比
【7月更文挑战第31天】人脸对比
593 2
|
9月前
|
前端开发 JavaScript UED
React 轮播图组件 Carousel
本文介绍了如何在 React 中实现和优化轮播图组件,涵盖自动播放、手动切换、循环播放和响应式设计等核心功能。通过 `useState` 和 `useEffect` 钩子管理状态和副作用,添加左右箭头和指示器增强交互性。同时,探讨了常见问题如自动播放与手动切换冲突、指示器样式不一致、响应式设计及性能优化,并提供解决方案和代码示例。帮助开发者提升轮播图组件的用户体验。
456 26
|
机器学习/深度学习 人工智能 搜索推荐
LVMH集团与阿里巴巴深化云计算合作
LVMH集团与阿里巴巴深化云计算合作
298 0
|
弹性计算 安全 网络安全
转发路由器 Transit Router(TR):实现企业级互联网络的灵活与可靠
转发路由器 Transit Router(简称“TR”)是地域范围内企业级核心转发网元,可为用户转发同地域或不同地域的网络实例间的流量,并支持在地域内定义灵活的互通、隔离、引流策略,帮助用户打造一张灵活、可靠、大规模的企业级互联网络。通过搭配云数据传输(简称“CDT”),用户可实现跨地域连接场景数据传输按流量计费的能力。
|
设计模式 开发框架 前端开发
基于SqlSugar的开发框架循序渐进介绍(20)-- 在基于UniApp+Vue的移动端实现多条件查询的处理
基于SqlSugar的开发框架循序渐进介绍(20)-- 在基于UniApp+Vue的移动端实现多条件查询的处理
|
Linux
Linux升级命令yum upgrade和yum update,有什么区别?
在日常开发工作中,根据不同的项目会需要配置环境和包,有时候会由于版本问题出现错误,这个时候通常就需要执行 update或者 upgrade命令,这里简要介绍一下区别。
3373 0
Linux升级命令yum upgrade和yum update,有什么区别?