2016-08-27 3 views
0

Мой код очень прост, я просто хочу привязываться к музыкальному сервису с помощью MediaBrowserServiceCompat, на самом деле у меня есть более крупная программа с той же проблемой, поэтому я попытался сделать меньшую без всех несущественных частей и я получаю следующее сообщение об ошибке:MediaBrowserServiceCompat не может связываться с сервисом

08-27 11:31:30.848 12214-12214/com.example.android.newcheck E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.android.newcheck, PID: 12214 java.lang.RuntimeException: Unable to bind to service [email protected] with Intent { act=android.media.browse.MediaBrowserService cmp=com.example.android.newcheck/.MusicStreamService }: java.lang.NullPointerException: Attempt to invoke interface method 'android.os.IBinder android.support.v4.media.MediaBrowserServiceCompat$MediaBrowserServiceImpl.onBind(android.content.Intent)' on a null object reference at android.app.ActivityThread.handleBindService(ActivityThread.java:3847) at android.app.ActivityThread.access$2200(ActivityThread.java:221) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1887) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:158) at android.app.ActivityThread.main(ActivityThread.java:7224) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'android.os.IBinder android.support.v4.media.MediaBrowserServiceCompat$MediaBrowserServiceImpl.onBind(android.content.Intent)' on a null object reference at android.support.v4.media.MediaBrowserServiceCompat.onBind(MediaBrowserServiceCompat.java:613) at android.app.ActivityThread.handleBindService(ActivityThread.java:3834) at android.app.ActivityThread.access$2200(ActivityThread.java:221)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1887)  at android.os.Handler.dispatchMessage(Handler.java:102)  at android.os.Looper.loop(Looper.java:158)  at android.app.ActivityThread.main(ActivityThread.java:7224)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 

я в основном использовал Ян Лека лекции на YouTube и сделал все, что он сказал, но я не знаю, почему я получаю эту ошибку, я пытаюсь найти ответы в Интернете, но не смог найти любой ответ. спасибо за помощь.

AndroidManifest:

<service 
     android:name=".MusicStreamService" 
     android:exported="true"> 
     <intent-filter> 
      <action android:name="android.media.browse.MediaBrowserService" /> 
     </intent-filter> 
    </service> 

MainActivity:

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    MediaBrowserCompat mediaBrowser = new MediaBrowserCompat(MainActivity.this, new ComponentName(MainActivity.this, MusicStreamService.class), 
      new MediaBrowserCompat.ConnectionCallback() { 
       @Override 
       public void onConnected() { 
        Log.v("MainActivity","connected"); 
       } 
       @Override 
       public void onConnectionSuspended() { 
        super.onConnectionSuspended(); 
       } 
       @Override 
       public void onConnectionFailed() { 
        super.onConnectionFailed(); 
       } 
      }, null); 
    mediaBrowser.connect(); 
    Button click = (Button) findViewById(R.id.button); 
    click.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      startService(new Intent(MainActivity.this, MusicStreamService.class)); 
     } 
    }); 
} 

MusicStreamService:

public class MusicStreamService extends MediaBrowserServiceCompat { 
@Nullable 
@Override 
public BrowserRoot onGetRoot(@NonNull String clientPackageName, int clientUid, @Nullable Bundle rootHints) { 
    Log.v("***********", "getroot"); 
    return new BrowserRoot(getString(R.string.app_name), // Name visible in Android Auto 
      null); // Bundle of optional extras 
} 

@Override 
public void onLoadChildren(@NonNull String parentId, @NonNull Result<List<MediaBrowserCompat.MediaItem>> result) { 
    Log.v("*********", "one step before connect2"); 
    result.sendResult(null); 
} 

@Override 
public void onCreate() { 
    MediaSessionCompat mediaSession = new MediaSessionCompat(this, MusicStreamService.class.getSimpleName()); 
    setSessionToken(mediaSession.getSessionToken()); 
    mediaSession.setFlags(MediaSessionCompat.FLAG_HANDLES_MEDIA_BUTTONS | 
      MediaSessionCompat.FLAG_HANDLES_TRANSPORT_CONTROLS); 
    mediaSession.setActive(true); 
} 
+0

https://medium.com/google-developers/mediabrowserservicecompat-and-the-modern-media-playback-app-7959a5196d90#.ck07s5vqc, в этом уроке он не говорил о вызове bindService. В любом случае, если я использую вызов bindService, я получаю ошибку в queryLocalInterface, но когда я использую вызовы bindService с сервисом без mediaBrowserServiceCompat, все работает нормально. –

+0

- это хорошая идея использовать Binder в MediaBrowserServiceCompat? –

ответ

5

забыл написать super.onCreate() в методе OnCreate в классе MusicStreamService. решена.

+0

В моем случае у меня возникла проблема с * публичной функцией IBinder onBind (намерение намерения) * в классе обслуживания. Он не должен возвращать null. Я просто удалил переопределение функции и решил проблему. –

Смежные вопросы