blob: 4639159f2b92f85f4ee88aea605319c90b7d439f [file] [log] [blame]
// Copyright 2020 The Cobalt Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "starboard/player.h"
#include <algorithm>
#include "starboard/configuration.h"
#include "starboard/shared/starboard/player/filter/player_components.h"
#include "starboard/string.h"
SbPlayerOutputMode SbPlayerGetPreferredOutputMode(
const SbPlayerCreationParam* creation_param) {
using starboard::shared::starboard::player::filter::PlayerComponents;
if (!creation_param) {
SB_LOG(ERROR) << "creation_param cannot be NULL";
return kSbPlayerOutputModeInvalid;
}
#if SB_API_VERSION >= 15
const SbMediaAudioStreamInfo& audio_stream_info =
creation_param->audio_stream_info;
const SbMediaVideoStreamInfo& video_stream_info =
creation_param->video_stream_info;
#else // SB_API_VERSION >= 15
const SbMediaAudioSampleInfo& audio_stream_info =
creation_param->audio_sample_info;
const SbMediaVideoSampleInfo& video_stream_info =
creation_param->video_sample_info;
#endif // SB_API_VERSION >= 15
if (audio_stream_info.codec != kSbMediaAudioCodecNone &&
!audio_stream_info.mime) {
SB_LOG(ERROR) << "creation_param->audio_stream_info.mime cannot be NULL";
return kSbPlayerOutputModeInvalid;
}
if (video_stream_info.codec != kSbMediaVideoCodecNone &&
!video_stream_info.mime) {
SB_LOG(ERROR) << "creation_param->video_stream_info.mime cannot be NULL";
return kSbPlayerOutputModeInvalid;
}
if (video_stream_info.codec != kSbMediaVideoCodecNone &&
!video_stream_info.max_video_capabilities) {
SB_LOG(ERROR) << "creation_param->video_stream_info.max_video_capabilities"
<< " cannot be NULL";
return kSbPlayerOutputModeInvalid;
}
auto codec = video_stream_info.codec;
auto drm_system = creation_param->drm_system;
auto max_video_capabilities = video_stream_info.max_video_capabilities;
// Sub players must use decode-to-texture on Android.
if (max_video_capabilities && strlen(max_video_capabilities) > 0) {
if (PlayerComponents::Factory::OutputModeSupported(
kSbPlayerOutputModeDecodeToTexture, codec, drm_system)) {
return kSbPlayerOutputModeDecodeToTexture;
}
SB_NOTREACHED();
return kSbPlayerOutputModeInvalid;
}
// The main player may use any output mode.
SbPlayerOutputMode output_modes_to_check[] = {
kSbPlayerOutputModePunchOut,
kSbPlayerOutputModeDecodeToTexture,
};
// Check |kSbPlayerOutputModeDecodeToTexture| first if the caller prefers it.
if (creation_param->output_mode == kSbPlayerOutputModeDecodeToTexture) {
std::swap(output_modes_to_check[0], output_modes_to_check[1]);
}
if (PlayerComponents::Factory::OutputModeSupported(output_modes_to_check[0],
codec, drm_system)) {
return output_modes_to_check[0];
}
if (PlayerComponents::Factory::OutputModeSupported(output_modes_to_check[1],
codec, drm_system)) {
return output_modes_to_check[1];
}
SB_LOG(WARNING) << "creation_param->video_stream_info.codec ("
<< video_stream_info.codec << ") is not supported";
return kSbPlayerOutputModeInvalid;
}