#android #video #youtube #amazon-fire-tv
#Android #Видео #YouTube #amazon-fire-tv
Вопрос:
Я разрабатываю приложение, которое берет идентификаторы видео YouTube из серверной части и должно автоматически воспроизводить видео из очереди без вмешательства пользователя. Но это проблемы, с которыми я столкнулся при разных подходах.
-
Использование API Youtube: — Это не поддерживается FireTV, и мое приложение не одобрено в магазине Amazon.
-
Использование Webview:-
-
Когда я использую URL-адрес видео как «https://www.youtube.com/watch?v=ajMpIN6BvQE «видео с YouTube начинают воспроизводиться автоматически. Но я вижу рекомендации к видео и не могу избавиться от этих рекомендаций автоматически
-
Когда я использую URL-адрес видео как «https://www.youtube-nocookie.com/embed/ajMpIN6BvQE «он перестал показывать рекомендации, но проблема здесь в том, что я не могу воспроизводить видео автоматически. Это заставляет пользователя явно нажимать на кнопку воспроизведения. ниже приведен код, который я использовал
import android.app.Activity; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Bundle; import android.view.View; import android.webkit.WebChromeClient; import android.webkit.WebSettings; import android.webkit.WebView; import android.webkit.WebViewClient; import android.widget.FrameLayout; public class WebViewActivity extends Activity { WebView webView; WebChromeClient.CustomViewCallback customViewCallback; @SuppressLint("SetJavaScriptEnabled") @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_webview); webView = findViewById(R.id.webView); webView.setWebViewClient(new WebViewClient()); ChromeClient chromeClient = new ChromeClient(); webView.setWebChromeClient(chromeClient); WebSettings webSettings = webView.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setAllowFileAccess(true); webSettings.setAppCacheEnabled(true); // webView.loadUrl("https://www.youtube-nocookie.com/embed/ajMpIN6BvQE"); webView.loadUrl("https://www.youtube.com/watch?v=ajMpIN6BvQE"); webSettings.setMediaPlaybackRequiresUserGesture(false); webView.setWebViewClient(new WebViewClient() { @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); } @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); } }); } @Override public void onPause() { webView.onPause(); super.onPause(); } @Override public void onDestroy() { webView.destroy(); super.onDestroy(); } @Override public void onStop() { super.onStop(); } @Override protected void onRestart() { super.onRestart(); } public void onBackPressed() { webView.stopLoading(); finish(); } @Override protected void onStart() { super.onStart(); } public class ChromeClient extends WebChromeClient { protected FrameLayout mFullscreenContainer; private View mCustomView; private WebChromeClient.CustomViewCallback mCustomViewCallback; private int mOriginalOrientation; private int mOriginalSystemUiVisibility; ChromeClient() { } public Bitmap getDefaultVideoPoster() { if (mCustomView == null) { return null; } return BitmapFactory.decodeResource(getApplicationContext().getResources(), 2130837573); } @Override public void onHideCustomView() { ((FrameLayout) getWindow().getDecorView()).removeView(this.mCustomView); this.mCustomView = null; getWindow().getDecorView().setSystemUiVisibility(this.mOriginalSystemUiVisibility); setRequestedOrientation(this.mOriginalOrientation); this.mCustomViewCallback.onCustomViewHidden(); this.mCustomViewCallback = null; } @Override public void onShowCustomView(View paramView, WebChromeClient.CustomViewCallback paramCustomViewCallback) { if (this.mCustomView != null) { onHideCustomView(); return; } this.mCustomView = paramView; this.mOriginalSystemUiVisibility = getWindow().getDecorView().getSystemUiVisibility(); this.mOriginalOrientation = getRequestedOrientation(); this.mCustomViewCallback = paramCustomViewCallback; ((FrameLayout) getWindow().getDecorView()).addView(this.mCustomView, new FrameLayout.LayoutParams(-1, -1)); getWindow().getDecorView().setSystemUiVisibility(3846 | View.SYSTEM_UI_FLAG_LAYOUT_STABLE); } }}
Ответ №1:
Я могу найти решение с помощью https://developers.google.com/youtube/iframe_api_reference . Добавлен код Javascript и включено взаимодействие между Java script с собственным Android.