Создание пользовательских медиа маршрута поставщика: Вот это подделка MediaRouteProvider для настраиваемый медиа-маршрут. Этот класс ничего не делает, кроме как публиковать фальшивый пользовательский MediaRoute, чтобы его можно было увидеть и выбрать с помощью Cast SDK из MediaRouter.
import android.content.Context;
import android.content.IntentFilter;
import android.media.AudioManager;
import android.os.Bundle;
import android.support.v7.media.MediaRouteDescriptor;
import android.support.v7.media.MediaRouteDiscoveryRequest;
import android.support.v7.media.MediaRouteProvider;
import android.support.v7.media.MediaRouteProvider.RouteController;
import android.support.v7.media.MediaRouteProviderDescriptor;
import android.support.v7.media.MediaRouter;
import java.util.ArrayList;
public final class CustomMediaRouteProvider extends MediaRouteProvider {
private static final ArrayList<IntentFilter> CONTROL_FILTERS_BASIC;
private static MediaRouteDescriptor DEFAULT_MEDIA_ROUTE_DESCRIPTOR;
static {
// This filter will be used by Cast SDK to match the session category.
IntentFilter customControls = new IntentFilter();
customControls.addCategory(CustomSessionProvider.CUSTOM_CATEGORY);
CONTROL_FILTERS_BASIC = new ArrayList<IntentFilter>();
CONTROL_FILTERS_BASIC.add(customControls);
Bundle extras = new Bundle();
extras.putCharSequence("ROUTE_URL", "http://abcdef.cyz");
DEFAULT_MEDIA_ROUTE_DESCRIPTOR =
new MediaRouteDescriptor.Builder("fake-custom-route-id", "fake custom route")
.setDescription("Foo description")
.addControlFilters(CONTROL_FILTERS_BASIC)
.setPlaybackStream(AudioManager.STREAM_MUSIC)
.setPlaybackType(MediaRouter.RouteInfo.PLAYBACK_TYPE_REMOTE)
.setVolumeHandling(MediaRouter.RouteInfo.PLAYBACK_VOLUME_VARIABLE)
.setVolumeMax(100)
.setVolume(10)
.setExtras(extras)
.build();
}
public CustomMediaRouteProvider(Context context) {
super(context);
}
@Override
public void onDiscoveryRequestChanged(MediaRouteDiscoveryRequest request) {
if (request == null || request.getSelector() == null) {
return;
}
publishRoutes();
}
@Override
public RouteController onCreateRouteController(String routeId) {
return null;
}
private void publishRoutes() {
MediaRouteProviderDescriptor providerDescriptor =
new MediaRouteProviderDescriptor.Builder().addRoute(DEFAULT_MEDIA_ROUTE_DESCRIPTOR).build();
setDescriptor(providerDescriptor);
}
}
Вам нужна реализация SessionProvider для пользовательской сессии:
import android.content.Context;
import com.google.android.gms.cast.framework.Session;
import com.google.android.gms.cast.framework.SessionProvider;
public class CustomSessionProvider extends SessionProvider {
public static final String CUSTOM_CATEGORY = "CUSTOM";
public CustomSessionProvider(Context applicationContext) {
super(applicationContext, CUSTOM_CATEGORY);
}
@Override
public Session createSession(String sessionId) {
return new CustomSession(getContext(), getCategory(), sessionId);
}
@Override
public boolean isSessionRecoverable() {
return true;
}
}
И реализация Session: Вот подделка реализации Сеанса для пользовательского типа медиа маршрута.Это всегда удается при запуске/возобновлении/завершении.
import android.content.Context;
import android.os.Bundle;
import com.google.android.gms.cast.framework.Session;
public class CustomSession extends Session {
private static final String FAKE_SESSION_ID = "custom.session.id.12345";
CustomSession(Context applicationContext, String category, String sessionId) {
super(applicationContext, category, sessionId);
}
@Override
protected void start(Bundle routeInfoExtra) {
notifySessionStarted(FAKE_SESSION_ID);
}
@Override
protected void resume(Bundle routeInfoExtra) {
notifySessionResumed(false);
}
@Override
protected void end(boolean stopCasting) {
notifySessionEnded(0);
}
}
В вашем Cast V3 приложении отправителя, указать дополнительный поставщик сеанса:
public class CastOptionsProvider implements OptionsProvider {
@Override
public List<SessionProvider> getAdditionalSessionProviders(Context appContext) {
List<SessionProvider> additionalProviders = new ArrayList<>();
additionalProviders.add(new CustomSessionProvider(appContext));
return additionalProviders;
}
}
В вашей заявке добавить поставщик MediaRouter:
public class CastVideosApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
MediaRouter mediaRouter = MediaRouter.getInstance(this);
mediaRouter.addProvider(new CustomMediaRouteProvider(this));
}
}
вы пытались выполнить [Cast SDK v3 Android Codelab] (https://codelabs.developers.google.com/codelabs/cast-videos-android/#0)? также проверьте этот [документ] (https://developers.google.com/cast/docs/android_sender_integrate). –
Да, я проверил это, но я ничего не мог найти о добавлении там не-литых устройств. Тем не менее, мы реализовали все остальные части SDK. – mennovogel
Проверьте это (https://productforums.google.com/forum/#!topic/chromecast/hoHJMeM5Qns), если он может помочь вам спариться. –