mirror of
https://github.com/TeamNewPipe/NewPipe
synced 2025-01-12 02:10:32 +00:00
made exoplayer work with youtube again
This commit is contained in:
parent
b06238ba5d
commit
f5892093a9
@ -801,12 +801,11 @@ public class VideoItemDetailFragment extends Fragment {
|
|||||||
// External Player
|
// External Player
|
||||||
Intent intent = new Intent();
|
Intent intent = new Intent();
|
||||||
try {
|
try {
|
||||||
intent.setAction(Intent.ACTION_VIEW);
|
intent.setAction(Intent.ACTION_VIEW)
|
||||||
|
.setDataAndType(Uri.parse(selectedVideoStream.url),
|
||||||
intent.setDataAndType(Uri.parse(selectedVideoStream.url),
|
MediaFormat.getMimeById(selectedVideoStream.format))
|
||||||
MediaFormat.getMimeById(selectedVideoStream.format));
|
.putExtra(Intent.EXTRA_TITLE, info.title)
|
||||||
intent.putExtra(Intent.EXTRA_TITLE, info.title);
|
.putExtra("title", info.title);
|
||||||
intent.putExtra("title", info.title);
|
|
||||||
|
|
||||||
activity.startActivity(intent); // HERE !!!
|
activity.startActivity(intent); // HERE !!!
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@ -816,9 +815,9 @@ public class VideoItemDetailFragment extends Fragment {
|
|||||||
.setPositiveButton(R.string.install, new DialogInterface.OnClickListener() {
|
.setPositiveButton(R.string.install, new DialogInterface.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
Intent intent = new Intent();
|
Intent intent = new Intent()
|
||||||
intent.setAction(Intent.ACTION_VIEW);
|
.setAction(Intent.ACTION_VIEW)
|
||||||
intent.setData(Uri.parse(activity.getString(R.string.fdroid_vlc_url)));
|
.setData(Uri.parse(activity.getString(R.string.fdroid_vlc_url)));
|
||||||
activity.startActivity(intent);
|
activity.startActivity(intent);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -837,20 +836,33 @@ public class VideoItemDetailFragment extends Fragment {
|
|||||||
// exo player
|
// exo player
|
||||||
|
|
||||||
if(info.dashMpdUrl != null && !info.dashMpdUrl.isEmpty()) {
|
if(info.dashMpdUrl != null && !info.dashMpdUrl.isEmpty()) {
|
||||||
Intent mpdIntent = new Intent(activity, ExoPlayerActivity.class)
|
// try dash
|
||||||
|
Intent intent = new Intent(activity, ExoPlayerActivity.class)
|
||||||
.setData(Uri.parse(info.dashMpdUrl))
|
.setData(Uri.parse(info.dashMpdUrl))
|
||||||
.putExtra(ExoPlayerActivity.CONTENT_TYPE_EXTRA, Util.TYPE_DASH);
|
.putExtra(ExoPlayerActivity.CONTENT_TYPE_EXTRA, Util.TYPE_DASH);
|
||||||
startActivity(mpdIntent);
|
startActivity(intent);
|
||||||
|
} else if((info.audio_streams != null && !info.audio_streams.isEmpty()) &&
|
||||||
|
(info.video_only_streams != null && !info.video_only_streams.isEmpty())) {
|
||||||
|
// try smooth streaming
|
||||||
|
|
||||||
|
} else {
|
||||||
|
//default streaming
|
||||||
|
Intent intent = new Intent(activity, ExoPlayerActivity.class)
|
||||||
|
.setDataAndType(Uri.parse(selectedVideoStream.url),
|
||||||
|
MediaFormat.getMimeById(selectedVideoStream.format))
|
||||||
|
.putExtra(ExoPlayerActivity.CONTENT_TYPE_EXTRA, Util.TYPE_OTHER);
|
||||||
|
|
||||||
|
activity.startActivity(intent); // HERE !!!
|
||||||
}
|
}
|
||||||
//-------------
|
//-------------
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// Internal Player
|
// Internal Player
|
||||||
Intent intent = new Intent(activity, PlayVideoActivity.class);
|
Intent intent = new Intent(activity, PlayVideoActivity.class)
|
||||||
intent.putExtra(PlayVideoActivity.VIDEO_TITLE, info.title);
|
.putExtra(PlayVideoActivity.VIDEO_TITLE, info.title)
|
||||||
intent.putExtra(PlayVideoActivity.STREAM_URL, selectedVideoStream.url);
|
.putExtra(PlayVideoActivity.STREAM_URL, selectedVideoStream.url)
|
||||||
intent.putExtra(PlayVideoActivity.VIDEO_URL, info.webpage_url);
|
.putExtra(PlayVideoActivity.VIDEO_URL, info.webpage_url)
|
||||||
intent.putExtra(PlayVideoActivity.START_POSITION, info.start_position);
|
.putExtra(PlayVideoActivity.START_POSITION, info.start_position);
|
||||||
activity.startActivity(intent); //also HERE !!!
|
activity.startActivity(intent); //also HERE !!!
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright (C) Christian Schabesberger 2015 <chris.schabesberger@mailbox.org>
|
* Copyright (C) Christian Schabesberger 2015 <chris.schabesberger@mailbox.org>
|
||||||
* ExoPlayerActivity.java is part of NewPipe. all changes are under GPL3
|
* ExoPlayerActivity.java is part of NewPipe. all changes are under GPL3
|
||||||
|
* ExoPlayerActivity.java is part of NewPipe. all changes are under GPL3
|
||||||
*
|
*
|
||||||
* NewPipe is free software: you can redistribute it and/or modify
|
* NewPipe is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -44,8 +45,6 @@ import org.schabi.newpipe.player.exoplayer.HlsRendererBuilder;
|
|||||||
import org.schabi.newpipe.player.exoplayer.NPExoPlayer;
|
import org.schabi.newpipe.player.exoplayer.NPExoPlayer;
|
||||||
import org.schabi.newpipe.player.exoplayer.NPExoPlayer.RendererBuilder;
|
import org.schabi.newpipe.player.exoplayer.NPExoPlayer.RendererBuilder;
|
||||||
import org.schabi.newpipe.player.exoplayer.SmoothStreamingRendererBuilder;
|
import org.schabi.newpipe.player.exoplayer.SmoothStreamingRendererBuilder;
|
||||||
import org.schabi.newpipe.player.exoplayer.SmoothStreamingTestMediaDrmCallback;
|
|
||||||
import org.schabi.newpipe.player.exoplayer.WidevineTestMediaDrmCallback;
|
|
||||||
|
|
||||||
import com.google.android.exoplayer.AspectRatioFrameLayout;
|
import com.google.android.exoplayer.AspectRatioFrameLayout;
|
||||||
import com.google.android.exoplayer.ExoPlaybackException;
|
import com.google.android.exoplayer.ExoPlaybackException;
|
||||||
@ -84,15 +83,12 @@ import android.view.MotionEvent;
|
|||||||
import android.view.SurfaceHolder;
|
import android.view.SurfaceHolder;
|
||||||
import android.view.SurfaceView;
|
import android.view.SurfaceView;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
|
||||||
import android.view.View.OnKeyListener;
|
import android.view.View.OnKeyListener;
|
||||||
import android.view.View.OnTouchListener;
|
import android.view.View.OnTouchListener;
|
||||||
import android.view.accessibility.CaptioningManager;
|
import android.view.accessibility.CaptioningManager;
|
||||||
import android.widget.Button;
|
|
||||||
import android.widget.MediaController;
|
import android.widget.MediaController;
|
||||||
import android.widget.PopupMenu;
|
import android.widget.PopupMenu;
|
||||||
import android.widget.PopupMenu.OnMenuItemClickListener;
|
import android.widget.PopupMenu.OnMenuItemClickListener;
|
||||||
import android.widget.TextView;
|
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import java.net.CookieHandler;
|
import java.net.CookieHandler;
|
||||||
@ -127,24 +123,16 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
|
|
||||||
private EventLogger eventLogger;
|
private EventLogger eventLogger;
|
||||||
private MediaController mediaController;
|
private MediaController mediaController;
|
||||||
private View debugRootView;
|
|
||||||
private View shutterView;
|
private View shutterView;
|
||||||
private AspectRatioFrameLayout videoFrame;
|
private AspectRatioFrameLayout videoFrame;
|
||||||
private SurfaceView surfaceView;
|
private SurfaceView surfaceView;
|
||||||
private TextView debugTextView;
|
|
||||||
private TextView playerStateTextView;
|
|
||||||
private SubtitleLayout subtitleLayout;
|
private SubtitleLayout subtitleLayout;
|
||||||
private Button videoButton;
|
|
||||||
private Button audioButton;
|
|
||||||
private Button textButton;
|
|
||||||
private Button retryButton;
|
|
||||||
|
|
||||||
private NPExoPlayer player;
|
private NPExoPlayer player;
|
||||||
private DebugTextViewHelper debugViewHelper;
|
|
||||||
private boolean playerNeedsPrepare;
|
private boolean playerNeedsPrepare;
|
||||||
|
|
||||||
private long playerPosition;
|
private long playerPosition;
|
||||||
private boolean enableBackgroundAudio;
|
private boolean enableBackgroundAudio = true;
|
||||||
|
|
||||||
private Uri contentUri;
|
private Uri contentUri;
|
||||||
private int contentType;
|
private int contentType;
|
||||||
@ -181,8 +169,7 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
text += "unknown";
|
text += "unknown";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
playerStateTextView.setText(text);
|
//todo: put text in some log
|
||||||
updateButtonVisibilities();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -218,7 +205,6 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
Toast.makeText(getApplicationContext(), errorString, Toast.LENGTH_LONG).show();
|
Toast.makeText(getApplicationContext(), errorString, Toast.LENGTH_LONG).show();
|
||||||
}
|
}
|
||||||
playerNeedsPrepare = true;
|
playerNeedsPrepare = true;
|
||||||
updateButtonVisibilities();
|
|
||||||
showControls();
|
showControls();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -327,23 +313,17 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
});
|
});
|
||||||
|
|
||||||
shutterView = findViewById(R.id.shutter);
|
shutterView = findViewById(R.id.shutter);
|
||||||
debugRootView = findViewById(R.id.controls_root);
|
|
||||||
|
|
||||||
videoFrame = (AspectRatioFrameLayout) findViewById(R.id.video_frame);
|
videoFrame = (AspectRatioFrameLayout) findViewById(R.id.video_frame);
|
||||||
surfaceView = (SurfaceView) findViewById(R.id.surface_view);
|
surfaceView = (SurfaceView) findViewById(R.id.surface_view);
|
||||||
surfaceView.getHolder().addCallback(surfaceHolderCallback);
|
surfaceView.getHolder().addCallback(surfaceHolderCallback);
|
||||||
debugTextView = (TextView) findViewById(R.id.debug_text_view);
|
|
||||||
|
|
||||||
playerStateTextView = (TextView) findViewById(R.id.player_state_view);
|
|
||||||
subtitleLayout = (SubtitleLayout) findViewById(R.id.subtitles);
|
subtitleLayout = (SubtitleLayout) findViewById(R.id.subtitles);
|
||||||
|
|
||||||
|
//todo: replace that creapy mediaController
|
||||||
mediaController = new KeyCompatibleMediaController(this);
|
mediaController = new KeyCompatibleMediaController(this);
|
||||||
mediaController.setAnchorView(root);
|
mediaController.setAnchorView(root);
|
||||||
retryButton = (Button) findViewById(R.id.retry_button);
|
|
||||||
videoButton = (Button) findViewById(R.id.video_controls);
|
|
||||||
audioButton = (Button) findViewById(R.id.audio_controls);
|
|
||||||
textButton = (Button) findViewById(R.id.text_controls);
|
|
||||||
|
|
||||||
|
//todo: check what cookie handler does, and if we even need it
|
||||||
CookieHandler currentHandler = CookieHandler.getDefault();
|
CookieHandler currentHandler = CookieHandler.getDefault();
|
||||||
if (currentHandler != defaultCookieManager) {
|
if (currentHandler != defaultCookieManager) {
|
||||||
CookieHandler.setDefault(defaultCookieManager);
|
CookieHandler.setDefault(defaultCookieManager);
|
||||||
@ -351,14 +331,6 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
|
|
||||||
audioCapabilitiesReceiver = new AudioCapabilitiesReceiver(this, audioCapabilitiesListener);
|
audioCapabilitiesReceiver = new AudioCapabilitiesReceiver(this, audioCapabilitiesListener);
|
||||||
audioCapabilitiesReceiver.register();
|
audioCapabilitiesReceiver.register();
|
||||||
|
|
||||||
|
|
||||||
retryButton.setOnClickListener(new OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
preparePlayer(true);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -452,14 +424,16 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
String userAgent = Util.getUserAgent(this, "NewPipeExoPlayer");
|
String userAgent = Util.getUserAgent(this, "NewPipeExoPlayer");
|
||||||
switch (contentType) {
|
switch (contentType) {
|
||||||
case Util.TYPE_SS:
|
case Util.TYPE_SS:
|
||||||
return new SmoothStreamingRendererBuilder(this, userAgent, contentUri.toString(),
|
// default
|
||||||
new SmoothStreamingTestMediaDrmCallback());
|
//return new SmoothStreamingRendererBuilder(this, userAgent, contentUri.toString());
|
||||||
case Util.TYPE_DASH:
|
case Util.TYPE_DASH:
|
||||||
return new DashRendererBuilder(this, userAgent, contentUri.toString(),
|
// if a dash manifest is available
|
||||||
new WidevineTestMediaDrmCallback(contentId, provider));
|
//return new DashRendererBuilder(this, userAgent, contentUri.toString());
|
||||||
case Util.TYPE_HLS:
|
case Util.TYPE_HLS:
|
||||||
|
// for livestreams
|
||||||
return new HlsRendererBuilder(this, userAgent, contentUri.toString());
|
return new HlsRendererBuilder(this, userAgent, contentUri.toString());
|
||||||
case Util.TYPE_OTHER:
|
case Util.TYPE_OTHER:
|
||||||
|
// video only streaming
|
||||||
return new ExtractorRendererBuilder(this, userAgent, contentUri);
|
return new ExtractorRendererBuilder(this, userAgent, contentUri);
|
||||||
default:
|
default:
|
||||||
throw new IllegalStateException("Unsupported type: " + contentType);
|
throw new IllegalStateException("Unsupported type: " + contentType);
|
||||||
@ -481,15 +455,10 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
player.addListener(eventLogger);
|
player.addListener(eventLogger);
|
||||||
player.setInfoListener(eventLogger);
|
player.setInfoListener(eventLogger);
|
||||||
player.setInternalErrorListener(eventLogger);
|
player.setInternalErrorListener(eventLogger);
|
||||||
debugViewHelper = new DebugTextViewHelper(player, debugTextView);
|
|
||||||
playerStateTextView.setVisibility(View.GONE);
|
|
||||||
debugTextView.setVisibility(View.GONE);
|
|
||||||
debugViewHelper.start();
|
|
||||||
}
|
}
|
||||||
if (playerNeedsPrepare) {
|
if (playerNeedsPrepare) {
|
||||||
player.prepare();
|
player.prepare();
|
||||||
playerNeedsPrepare = false;
|
playerNeedsPrepare = false;
|
||||||
updateButtonVisibilities();
|
|
||||||
}
|
}
|
||||||
player.setSurface(surfaceView.getHolder().getSurface());
|
player.setSurface(surfaceView.getHolder().getSurface());
|
||||||
player.setPlayWhenReady(playWhenReady);
|
player.setPlayWhenReady(playWhenReady);
|
||||||
@ -497,8 +466,6 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
|
|
||||||
private void releasePlayer() {
|
private void releasePlayer() {
|
||||||
if (player != null) {
|
if (player != null) {
|
||||||
debugViewHelper.stop();
|
|
||||||
debugViewHelper = null;
|
|
||||||
playerPosition = player.getCurrentPosition();
|
playerPosition = player.getCurrentPosition();
|
||||||
player.release();
|
player.release();
|
||||||
player = null;
|
player = null;
|
||||||
@ -507,163 +474,9 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// User controls
|
|
||||||
|
|
||||||
private void updateButtonVisibilities() {
|
|
||||||
retryButton.setVisibility(playerNeedsPrepare ? View.VISIBLE : View.GONE);
|
|
||||||
videoButton.setVisibility(haveTracks(NPExoPlayer.TYPE_VIDEO) ? View.VISIBLE : View.GONE);
|
|
||||||
audioButton.setVisibility(haveTracks(NPExoPlayer.TYPE_AUDIO) ? View.VISIBLE : View.GONE);
|
|
||||||
textButton.setVisibility(haveTracks(NPExoPlayer.TYPE_TEXT) ? View.VISIBLE : View.GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean haveTracks(int type) {
|
|
||||||
return player != null && player.getTrackCount(type) > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void showVideoPopup(View v) {
|
|
||||||
PopupMenu popup = new PopupMenu(this, v);
|
|
||||||
configurePopupWithTracks(popup, null, NPExoPlayer.TYPE_VIDEO);
|
|
||||||
popup.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void showAudioPopup(View v) {
|
|
||||||
PopupMenu popup = new PopupMenu(this, v);
|
|
||||||
Menu menu = popup.getMenu();
|
|
||||||
menu.add(Menu.NONE, Menu.NONE, Menu.NONE, R.string.enable_background_audio);
|
|
||||||
final MenuItem backgroundAudioItem = menu.findItem(0);
|
|
||||||
backgroundAudioItem.setCheckable(true);
|
|
||||||
backgroundAudioItem.setChecked(enableBackgroundAudio);
|
|
||||||
OnMenuItemClickListener clickListener = new OnMenuItemClickListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onMenuItemClick(MenuItem item) {
|
|
||||||
if (item == backgroundAudioItem) {
|
|
||||||
enableBackgroundAudio = !item.isChecked();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
configurePopupWithTracks(popup, clickListener, NPExoPlayer.TYPE_AUDIO);
|
|
||||||
popup.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void showTextPopup(View v) {
|
|
||||||
PopupMenu popup = new PopupMenu(this, v);
|
|
||||||
configurePopupWithTracks(popup, null, NPExoPlayer.TYPE_TEXT);
|
|
||||||
popup.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void showVerboseLogPopup(View v) {
|
|
||||||
PopupMenu popup = new PopupMenu(this, v);
|
|
||||||
Menu menu = popup.getMenu();
|
|
||||||
menu.add(Menu.NONE, 0, Menu.NONE, R.string.logging_normal);
|
|
||||||
menu.add(Menu.NONE, 1, Menu.NONE, R.string.logging_verbose);
|
|
||||||
menu.setGroupCheckable(Menu.NONE, true, true);
|
|
||||||
menu.findItem((VerboseLogUtil.areAllTagsEnabled()) ? 1 : 0).setChecked(true);
|
|
||||||
popup.setOnMenuItemClickListener(new OnMenuItemClickListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onMenuItemClick(MenuItem item) {
|
|
||||||
if (item.getItemId() == 0) {
|
|
||||||
VerboseLogUtil.setEnableAllTags(false);
|
|
||||||
} else {
|
|
||||||
VerboseLogUtil.setEnableAllTags(true);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
popup.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void configurePopupWithTracks(PopupMenu popup,
|
|
||||||
final OnMenuItemClickListener customActionClickListener,
|
|
||||||
final int trackType) {
|
|
||||||
if (player == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
int trackCount = player.getTrackCount(trackType);
|
|
||||||
if (trackCount == 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
popup.setOnMenuItemClickListener(new OnMenuItemClickListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onMenuItemClick(MenuItem item) {
|
|
||||||
return (customActionClickListener != null
|
|
||||||
&& customActionClickListener.onMenuItemClick(item))
|
|
||||||
|| onTrackItemClick(item, trackType);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Menu menu = popup.getMenu();
|
|
||||||
// ID_OFFSET ensures we avoid clashing with Menu.NONE (which equals 0).
|
|
||||||
menu.add(MENU_GROUP_TRACKS, NPExoPlayer.TRACK_DISABLED + ID_OFFSET, Menu.NONE, R.string.off);
|
|
||||||
for (int i = 0; i < trackCount; i++) {
|
|
||||||
menu.add(MENU_GROUP_TRACKS, i + ID_OFFSET, Menu.NONE,
|
|
||||||
buildTrackName(player.getTrackFormat(trackType, i)));
|
|
||||||
}
|
|
||||||
menu.setGroupCheckable(MENU_GROUP_TRACKS, true, true);
|
|
||||||
menu.findItem(player.getSelectedTrack(trackType) + ID_OFFSET).setChecked(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String buildTrackName(MediaFormat format) {
|
|
||||||
if (format.adaptive) {
|
|
||||||
return "auto";
|
|
||||||
}
|
|
||||||
String trackName;
|
|
||||||
if (MimeTypes.isVideo(format.mimeType)) {
|
|
||||||
trackName = joinWithSeparator(joinWithSeparator(buildResolutionString(format),
|
|
||||||
buildBitrateString(format)), buildTrackIdString(format));
|
|
||||||
} else if (MimeTypes.isAudio(format.mimeType)) {
|
|
||||||
trackName = joinWithSeparator(joinWithSeparator(joinWithSeparator(buildLanguageString(format),
|
|
||||||
buildAudioPropertyString(format)), buildBitrateString(format)),
|
|
||||||
buildTrackIdString(format));
|
|
||||||
} else {
|
|
||||||
trackName = joinWithSeparator(joinWithSeparator(buildLanguageString(format),
|
|
||||||
buildBitrateString(format)), buildTrackIdString(format));
|
|
||||||
}
|
|
||||||
return trackName.length() == 0 ? "unknown" : trackName;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String buildResolutionString(MediaFormat format) {
|
|
||||||
return format.width == MediaFormat.NO_VALUE || format.height == MediaFormat.NO_VALUE
|
|
||||||
? "" : format.width + "x" + format.height;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String buildAudioPropertyString(MediaFormat format) {
|
|
||||||
return format.channelCount == MediaFormat.NO_VALUE || format.sampleRate == MediaFormat.NO_VALUE
|
|
||||||
? "" : format.channelCount + "ch, " + format.sampleRate + "Hz";
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String buildLanguageString(MediaFormat format) {
|
|
||||||
return TextUtils.isEmpty(format.language) || "und".equals(format.language) ? ""
|
|
||||||
: format.language;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String buildBitrateString(MediaFormat format) {
|
|
||||||
return format.bitrate == MediaFormat.NO_VALUE ? ""
|
|
||||||
: String.format(Locale.US, "%.2fMbit", format.bitrate / 1000000f);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String joinWithSeparator(String first, String second) {
|
|
||||||
return first.length() == 0 ? second : (second.length() == 0 ? first : first + ", " + second);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String buildTrackIdString(MediaFormat format) {
|
|
||||||
return format.trackId == null ? "" : " (" + format.trackId + ")";
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean onTrackItemClick(MenuItem item, int type) {
|
|
||||||
if (player == null || item.getGroupId() != MENU_GROUP_TRACKS) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
player.setSelectedTrack(type, item.getItemId() - ID_OFFSET);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void toggleControlsVisibility() {
|
private void toggleControlsVisibility() {
|
||||||
if (mediaController.isShowing()) {
|
if (mediaController.isShowing()) {
|
||||||
mediaController.hide();
|
mediaController.hide();
|
||||||
debugRootView.setVisibility(View.GONE);
|
|
||||||
playerStateTextView.setVisibility(View.GONE);
|
|
||||||
debugTextView.setVisibility(View.GONE);
|
|
||||||
} else {
|
} else {
|
||||||
showControls();
|
showControls();
|
||||||
}
|
}
|
||||||
@ -671,9 +484,6 @@ public class ExoPlayerActivity extends Activity {
|
|||||||
|
|
||||||
private void showControls() {
|
private void showControls() {
|
||||||
mediaController.show(0);
|
mediaController.show(0);
|
||||||
debugRootView.setVisibility(View.VISIBLE);
|
|
||||||
playerStateTextView.setVisibility(View.VISIBLE);
|
|
||||||
debugTextView.setVisibility(View.VISIBLE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void configureSubtitleView() {
|
private void configureSubtitleView() {
|
||||||
|
@ -1,64 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2014 The Android Open Source Project
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
package org.schabi.newpipe.player.exoplayer;
|
|
||||||
|
|
||||||
import com.google.android.exoplayer.drm.MediaDrmCallback;
|
|
||||||
import com.google.android.exoplayer.drm.StreamingDrmSessionManager;
|
|
||||||
import com.google.android.exoplayer.util.Util;
|
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
|
||||||
import android.media.MediaDrm.KeyRequest;
|
|
||||||
import android.media.MediaDrm.ProvisionRequest;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Demo {@link StreamingDrmSessionManager} for smooth streaming test content.
|
|
||||||
*/
|
|
||||||
@TargetApi(18)
|
|
||||||
public class SmoothStreamingTestMediaDrmCallback implements MediaDrmCallback {
|
|
||||||
|
|
||||||
private static final String PLAYREADY_TEST_DEFAULT_URI =
|
|
||||||
"http://playready.directtaps.net/pr/svc/rightsmanager.asmx";
|
|
||||||
private static final Map<String, String> KEY_REQUEST_PROPERTIES;
|
|
||||||
static {
|
|
||||||
HashMap<String, String> keyRequestProperties = new HashMap<>();
|
|
||||||
keyRequestProperties.put("Content-Type", "text/xml");
|
|
||||||
keyRequestProperties.put("SOAPAction",
|
|
||||||
"http://schemas.microsoft.com/DRM/2007/03/protocols/AcquireLicense");
|
|
||||||
KEY_REQUEST_PROPERTIES = keyRequestProperties;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public byte[] executeProvisionRequest(UUID uuid, ProvisionRequest request) throws IOException {
|
|
||||||
String url = request.getDefaultUrl() + "&signedRequest=" + new String(request.getData());
|
|
||||||
return Util.executePost(url, null, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public byte[] executeKeyRequest(UUID uuid, KeyRequest request) throws Exception {
|
|
||||||
String url = request.getDefaultUrl();
|
|
||||||
if (TextUtils.isEmpty(url)) {
|
|
||||||
url = PLAYREADY_TEST_DEFAULT_URI;
|
|
||||||
}
|
|
||||||
return Util.executePost(url, request.getData(), KEY_REQUEST_PROPERTIES);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2014 The Android Open Source Project
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
package org.schabi.newpipe.player.exoplayer;
|
|
||||||
|
|
||||||
import com.google.android.exoplayer.drm.MediaDrmCallback;
|
|
||||||
import com.google.android.exoplayer.util.Util;
|
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
|
||||||
import android.media.MediaDrm.KeyRequest;
|
|
||||||
import android.media.MediaDrm.ProvisionRequest;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link MediaDrmCallback} for Widevine test content.
|
|
||||||
*/
|
|
||||||
@TargetApi(18)
|
|
||||||
public class WidevineTestMediaDrmCallback implements MediaDrmCallback {
|
|
||||||
|
|
||||||
private static final String WIDEVINE_GTS_DEFAULT_BASE_URI =
|
|
||||||
"https://proxy.uat.widevine.com/proxy";
|
|
||||||
|
|
||||||
private final String defaultUri;
|
|
||||||
|
|
||||||
public WidevineTestMediaDrmCallback(String contentId, String provider) {
|
|
||||||
String params = "?video_id=" + contentId + "&provider=" + provider;
|
|
||||||
defaultUri = WIDEVINE_GTS_DEFAULT_BASE_URI + params;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public byte[] executeProvisionRequest(UUID uuid, ProvisionRequest request) throws IOException {
|
|
||||||
String url = request.getDefaultUrl() + "&signedRequest=" + new String(request.getData());
|
|
||||||
return Util.executePost(url, null, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public byte[] executeKeyRequest(UUID uuid, KeyRequest request) throws IOException {
|
|
||||||
String url = request.getDefaultUrl();
|
|
||||||
if (TextUtils.isEmpty(url)) {
|
|
||||||
url = defaultUri;
|
|
||||||
}
|
|
||||||
return Util.executePost(url, request.getData(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -14,7 +14,6 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
|
||||||
android:id="@+id/root"
|
android:id="@+id/root"
|
||||||
android:focusable="true"
|
android:focusable="true"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
@ -42,75 +41,4 @@
|
|||||||
|
|
||||||
</com.google.android.exoplayer.AspectRatioFrameLayout>
|
</com.google.android.exoplayer.AspectRatioFrameLayout>
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:background="#88000000"
|
|
||||||
android:orientation="vertical">
|
|
||||||
|
|
||||||
|
|
||||||
<TextView android:id="@+id/player_state_view"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:paddingLeft="4dp"
|
|
||||||
android:paddingRight="4dp"
|
|
||||||
android:textSize="10sp"
|
|
||||||
tools:ignore="SmallSp"/>
|
|
||||||
|
|
||||||
<TextView android:id="@+id/debug_text_view"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:paddingLeft="4dp"
|
|
||||||
android:paddingRight="4dp"
|
|
||||||
android:textSize="10sp"
|
|
||||||
tools:ignore="SmallSp"/>
|
|
||||||
|
|
||||||
<LinearLayout android:id="@+id/controls_root"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:orientation="horizontal"
|
|
||||||
android:visibility="gone">
|
|
||||||
|
|
||||||
<Button android:id="@+id/video_controls"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/video"
|
|
||||||
style="@style/ExoPlayerButton"
|
|
||||||
android:visibility="gone"
|
|
||||||
android:onClick="showVideoPopup"/>
|
|
||||||
|
|
||||||
<Button android:id="@+id/audio_controls"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/audio"
|
|
||||||
style="@style/ExoPlayerButton"
|
|
||||||
android:visibility="gone"
|
|
||||||
android:onClick="showAudioPopup"/>
|
|
||||||
|
|
||||||
<Button android:id="@+id/text_controls"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/text"
|
|
||||||
style="@style/ExoPlayerButton"
|
|
||||||
android:visibility="gone"
|
|
||||||
android:onClick="showTextPopup"/>
|
|
||||||
|
|
||||||
<Button android:id="@+id/verbose_log_controls"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/logging"
|
|
||||||
style="@style/ExoPlayerButton"
|
|
||||||
android:onClick="showVerboseLogPopup"/>
|
|
||||||
|
|
||||||
<Button android:id="@+id/retry_button"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/retry"
|
|
||||||
android:visibility="gone"
|
|
||||||
style="@style/ExoPlayerButton"/>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</FrameLayout>
|
</FrameLayout>
|
||||||
|
Loading…
Reference in New Issue
Block a user