アプリのアクティビティとフラグメントで MediaBrowserCompat の複数のインスタンスを作成しました。この状況では、すべてのコンポーネントで MediaBrowserCompat を作成し、サービスなどに接続する必要があります。簡単にするために、Dagger を使用して MediaBrowserCompat のインスタンスを 1 つだけ作成し、必要な場所に挿入するのは悪い考えですか?
このような:
これは、MediaBrowserCompat を作成する私の MediaBrowserModule
@Module
class MediaBrowserModule {
@Provides
@Singleton
fun providesMediaBrowserCompat(
context: Context,
componentName: ComponentName,
connectionCallback: MediaBrowserConnectionCallback
): MediaBrowserCompat = MediaBrowserCompat(context, componentName, connectionCallback, null)
@Provides
fun providesMediaBrowserServiceComponentName(context: Context): ComponentName =
ComponentName(context, MediaBrowserService::class.java)
@Provides
@Singleton
fun providesMediaBrowserConnectionStatus(): MutableLiveData<MediaBrowserConnectionCallback.ConnectionStatus> =
MutableLiveData()
}
MediaBrowser 接続コールバックの実装:
class MediaBrowserConnectionCallback @Inject constructor(private val connectionStatus: MutableLiveData<ConnectionStatus>) :
MediaBrowserCompat.ConnectionCallback() {
override fun onConnected() {
super.onConnected()
connectionStatus.postValue(ConnectionStatus.Connected)
}
override fun onConnectionSuspended() {
super.onConnectionSuspended()
connectionStatus.postValue(ConnectionStatus.Suspended)
}
override fun onConnectionFailed() {
super.onConnectionFailed()
connectionStatus.postValue(ConnectionStatus.Failed)
}
enum class ConnectionStatus {
Connected, Suspended, Failed
}
}
最後に、以下のようにどこでも使用できます。
class MainActivity : DaggerAppCompatActivity(), Observer<MediaBrowserConnectionCallback.ConnectionStatus> {
@Inject
lateinit var connectionState: MutableLiveData<MediaBrowserConnectionCallback.ConnectionStatus>
@Inject
lateinit var mediaBrowserCompat: MediaBrowserCompat
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
connectionState.observe(this, this)
}
override fun onStart() {
super.onStart()
if (!mediaBrowserCompat.isConnected)
mediaBrowserCompat.connect()
}
override fun onChanged(status: MediaBrowserConnectionCallback.ConnectionStatus?) {
Toast.makeText(this, status?.name, Toast.LENGTH_LONG).show()
}
}
ありがとう。