NetBus —— 让你的 App 内部随处感知网络的变化

简介

NetBus 是一个实时监听网络状态的一个框架,接入简单。只需要几步就可以在 Activity 和 Fragment 以及其他要观测的类中很方便的收到网络状态变化的通知。

愿景

  • 可以在 App 任意位置监听网络的变化
  •  同一类中监听不同类型的网络
  • 监听者可以指定不同的网络环境
  • 布局封装,简化布局状态切换

使用

1. 添加依赖

implementation 'com.github.meetsl.netbus:SNetBus:1.1'

2.  初始化

在项目最开始的地方需要对 NetBus 进行初始化,例如 Application 或者 启动页中初始化。初始化代码如下:

//初始化 NetBus(必须)
NetBus.init(this)
//全局设置公共布局(可选)
NetBus.initNetView(loadResId = R.layout.layout_loading_view, netErrorResId = R.layout.layout_net_error_view)

3.  添加监听

  • Activity 或者 Fragment 中添加监听

  -  在 `Activity` 或者 `Fragment`中注册该接收者,在 `onCreate()` 或者 `onCreateView()` 中添加注册:

NetBus.getDefault().register(this)

  -  然后需要在类中添加一个只有一个 boolean 类型参数的方法并添加注解:

/**
 *  接受网络状态变化通知的方法
 *
 *  @param isAvailable : true 当前 NetMode 下网络可用;false 无网络状态,与 NetMode 无关
 */
@NetSubscribe(netMode = NetMode.WIFI, threadMode = ThreadMode.MAIN, priority = 1)
fun onNetEvent(isAvailable: Boolean) {
    Log.i("Callback_Network", "${this.javaClass} $name 网络变化了")
}

  - OK,Activity 或者 Fragment 对网络的监听这样子就可以了。如果你的项目中 Activity 或者 Fragment 中有父类,则注册的这个操作放在父类中也是可以的。

  • 在其他位置中监听网络变化

  - 在代码中新建一个 `NetBusTest` 的测试类,示例代码完整的展示了如何进行监听:

public class NetBusTest {

   /**
     * 需要在适当的时机,比如类对象创建的时候就进行注册
     */
    public void run() {
        NetBus.Companion.getDefault().register(this);
    }

    /**
     * 接收网络状态变化,这里监听的是移动数据网络
     *
     * @param isAvailable true 当前 NetMode 下网络可用;false 无网络状态,与 NetMode 无关
     */
    @NetSubscribe(netMode = NetMode.CELLULAR, threadMode = ThreadMode.MAIN, priority = 1)
    public void onEvent(boolean isAvailable) {
        Log.i("Callback_Network", "NetBusTest ---- 网络变化了");
    }

    /**
     * 在类对象不再被使用或者销毁的时候,进行解注册
     */
    public void stop() {
        NetBus.Companion.getDefault().unregister(this);
    }
}

  - 在类中添加了一个 `run()` 和一个 `stop()` 方法用于注册和解注册,`onEvent` 方法用于接收网络状态变化。与 `Activity` 或者 `Fragment` 不一样的地方就是需要我们自己手动解注册,这一点需要在使用的时候注意一下。

辅助开发

在该框架中还提供了一个用于辅助开发的布局  `PageStateLayout` ,在一个正常的业务 App 中,一个 Page 中一般会有三到四种的状态布局,比如 EmptyLayout (无数据视图) 、NetErrorLayout(网络错误视图)、LoadLayout(加载视图)以及 NormalLayout(正常显示视图)。这个辅助布局有一定的限制,大家可以根据场景决定使不使用。下面说一下这个布局的具体使用: 

  • 设置全局状态布局

  - 比如我们的 App 设计的时候,网络错误的视图都是统一的,那么我们可以将该试图设置为全局视图。这样每一个 `PageStateLayout` 对象在显示网络错误视图时,显示的都是一个:(在 App 启动页或者 Application 中设置)

//全局设置公共布局
NetBus.initNetView(netErrorResId = R.layout.layout_net_error_view)
  • 设置局部状态布局

  - 由于每一个 Page 在同一状态下布局可能不一致,所以提供了局部设置:

private lateinit var stateLayout: PageStateLayout

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        stateLayout = PageStateLayout(this)
        //设置正常显示视图
        stateLayout.setNormalView(R.layout.activity_main)
       //设置该 Page 的 空视图
        stateLayout.setEmptyView(R.layout.layout_empty_default)
        //设置该 Page 的加载视图
        stateLayout.setLoadingView(R.layout.layout_loading_view)
        //设置该 Page 的网络错误视图
        stateLayout.setNetErrorView(R.layout.layout_net_error_view)
        //显示
        setContentView(stateLayout)
        NetBus.getDefault().register(this)
    }

  - 示例代码说明了如何设置局部视图,以及显示使用

  • 显示调用

  - 将 `PageStateLayout` 设置给 Page 后如何控制显示布局,很简单:

@NetSubscribe(netMode = NetMode.WIFI, threadMode = ThreadMode.POSTING, priority = 1)
    fun onEvent(isAvailable: Boolean) {
        println("网络变化了")
        if (!isAvailable)
            stateLayout.showNetErrorView()
        else
            stateLayout.showNormalView()
        Log.i("Callback_Network", "MainActivity ----$isAvailable 网络变化了")
    }

  - `PageStateLayout` 提供了 `showXXXX` 的方法来显示布局

总结

到这里该框架基本就介绍完了,希望它可以在你的项目中,很方便的帮助你监听网络状态。如果在使用中有什么问题或者建议,能告诉我那就太棒了。框架会持续更新,这里放上框架的 github 地址,欢迎 star 以及 comment 。

SNetBus Github

原文地址:https://www.cnblogs.com/aimqqroad-13/p/10196686.html