Проблема с воспроизведением видео с YouTube в Fire TV

Я разрабатываю приложение, которое берет идентификатор видео YouTube из бэкэнда, и оно должно автоматически воспроизводить видео из очереди без вмешательства пользователя. Но это проблемы, с которыми я столкнулся при разных подходах.

  1. Использование API Youtube: - FireTV не поддерживает это, и мое приложение не одобрено в магазине Amazon.

  2. Использование веб-просмотра: -

  • Когда я использую 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);
      }
    
    }}
    

person Bala Saikrupa Puram    schedule 23.09.2020    source источник


Ответы (1)


Я могу найти решение с помощью https://developers.google.com/youtube/iframe_api_reference. Добавлен код Javascript и включено взаимодействие между скриптом Java и родным Android.

person Bala Saikrupa Puram    schedule 21.10.2020