360插件化方案RePlugin學(xué)習(xí)筆記-插件與宿主間的通信方式

1.使用Intent傳遞數(shù)據(jù)

在跳轉(zhuǎn)的Intent中攜帶數(shù)據(jù),常規(guī)使用方法,不再舉例。
參考360插件化方案RePlugin初體驗(yàn) 中跳轉(zhuǎn)intent,向intent中放入數(shù)據(jù)進(jìn)行傳遞,也可使用startActivityForResult傳遞數(shù)據(jù)并跳轉(zhuǎn)到插件,再通過setResult從插件傳遞數(shù)據(jù)給宿主。

2.使用廣播

新建TestPluginReceiver.kt

class TestPluginReceiver : BroadcastReceiver() {
    override fun onReceive(context: Context, intent: Intent) {
        Toast.makeText(context, "已經(jīng)收到信息", Toast.LENGTH_SHORT).show()
    }
}

宿主中注冊:

//聲明
private lateinit var pluginReceiver: TestPluginReceiver

//注冊
pluginReceiver = TestPluginReceiver()
registerReceiver(pluginReceiver, IntentFilter("com.test.qby.receiver"))

//別忘記在onDestroy中注銷
unregisterReceiver(pluginReceiver)

插件中發(fā)送廣播

sendBroadcast(Intent("com.test.qby.receiver"))

3.使用Messenger(仿照應(yīng)用間通信方式)

把宿主當(dāng)作服務(wù)端,新建MessengerService.kt

class MessengerService : Service() {

    companion object {

        private val TAG = "PluginActivity"
    }
    
    private val mMessenger = Messenger(MessengerHandler())

    override fun onBind(intent: Intent): IBinder? {
        return mMessenger.binder
    }

    private class MessengerHandler : Handler() {
        override fun handleMessage(msg: Message) {
            when (msg.what) {
                1 -> {
                    Log.e(TAG, "宿主得到信息")
                    val data = msg.data
                    val msgContent = data.getString("msg")
                    Log.e(TAG, "插件發(fā)來的信息是" + msgContent!!)

                    // 回復(fù)客戶端
                    val client = msg.replyTo
                    val replyData = Bundle()
                    replyData.putString("reply", "插件發(fā)來的信息<$msgContent>,宿主已收到")
                    val replyMsg = Message.obtain()
                    replyMsg.what = 0
                    replyMsg.data = replyData
                    try {
                        client.send(replyMsg)
                    } catch (e: RemoteException) {
                        Log.e(TAG, "", e)
                    }

                }
                else -> super.handleMessage(msg)
            }
        }
    }

}

宿主清單文件中注冊

<service android:name=".service.MessengerService"
            android:exported="true"
            android:process=":remote" >
            <intent-filter>
                <action android:name="com.test.qby.myapplication.service.MessengerService" />
            </intent-filter>
</service>

在插件中綁定服務(wù),發(fā)送信息,并獲取結(jié)果

    //聲明,初始化
    companion object {
        val TAG: String = "PluginActivity"
     }
    var mService:Messenger?= null
    var mMessenger:Messenger = Messenger(MessengerHandler())
    
    //獲取信息的handler
    @Suppress("UNUSED_EXPRESSION")
    class MessengerHandler: Handler() {
        override fun handleMessage(msg: Message) {
            Log.e(TAG, "插件得到信息")
            when (msg.what) {
                0 -> {
                    val data: Bundle = msg.data
                    Log.e(TAG, "" + data.getString("reply"))
                }
                else -> ""
            }
        }
    }

    //服務(wù)連接
    private val mConnection: ServiceConnection = object: ServiceConnection {
        override fun onServiceDisconnected(name: ComponentName?) {
        }

        override fun onServiceConnected(name: ComponentName?, service: IBinder?) {
            mService = Messenger(service)

            // 向服務(wù)端發(fā)送數(shù)據(jù)
            try {
                val msg = Message.obtain()
                msg.what = 1
                val data = Bundle()
                data.putString("msg", "能看到我嗎?")
                msg.data = data

                // 設(shè)置服務(wù)端回復(fù)的Messenger
                msg.replyTo = mMessenger

                mService!!.send(msg)
            } catch (e:RemoteException) {
                Log.e(TAG, "", e)
            }
        }
    }

    // 綁定 Service
    val service = Intent("com.test.qby.myapplication.service.MessengerService")
    service.component = ComponentName("com.test.qby.myapplication", "com.test.qby.myapplication.service.MessengerService")
    RePlugin.getHostContext().bindService(service, mConnection, Service.BIND_AUTO_CREATE)

    //onDestroy中斷開連接
    RePlugin.getHostContext().unbindService(mConnection)

4.使用AIDL

參考360插件化方案RePlugin學(xué)習(xí)筆記-插件使用宿主中的類使用場景3

5.使用EventBus

宿主項(xiàng)目app下build.gradle中添加依賴

compile 'org.greenrobot:eventbus:3.1.1'

新建EventBus事件類MessageEvent.kt

class MessageEvent(var message: String?) {

    //發(fā)出信息的方法
    fun sendEventBus() {
        EventBus.getDefault().post(this)
    }
}

宿主中注冊、執(zhí)行事件、注銷

//注冊
EventBus.getDefault().register(this)

//執(zhí)行事件的方法,doEvent為自定義,命名隨意,參數(shù)與post參數(shù)一致即可
@Subscribe(threadMode = ThreadMode.MAIN)
fun doEvent(messageEvent: MessageEvent?) {
     Toast.makeText(this, messageEvent!!.message,Toast.LENGTH_SHORT).show()
}

//注銷
if(EventBus.getDefault().isRegistered(this)) {
     EventBus.getDefault().unregister(this);
}

插件中調(diào)用,發(fā)送信息的方法

//獲取宿主類加載器
val hostClassLoader = RePlugin.getHostClassLoader()
//獲取MessageEvent類
val msgEvent = hostClassLoader.loadClass("com.test.qby.myapplication.pojo.MessageEvent")
//得到有參構(gòu)造方法
val constructor = msgEvent.getConstructor(String::class.java)
//調(diào)用有參構(gòu)造,傳遞參數(shù)
val eventBusInfo = constructor.newInstance("使用EventBus傳遞信息")
//獲取發(fā)送方法
val method = msgEvent.getDeclaredMethod("sendEventBus")
//調(diào)用發(fā)送方法,發(fā)出信息
method.invoke(eventBusInfo)

通信方式的選擇還是要根據(jù)具體的使用場景來決定。

以上僅個人學(xué)習(xí)記錄,如有疏漏或謬誤,歡迎留言交流!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容