【问题标题】:Issue with playing youtube videos in Fire TV在 Fire TV 中播放 youtube 视频的问题
【发布时间】:2020-09-23 12:38:10
【问题描述】:

我正在开发一个应用程序,它从后端获取 youtube 视频 ID,它应该自动播放队列中的视频,而无需用户干预。但这些是我在采用不同方法时面临的挑战。

  1. 使用 Youtube API:- FireTV 不支持此功能,并且我的应用未在亚马逊商店获得批准。

  2. 使用 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);
      }
    
    }}
    

【问题讨论】:

    标签: android video youtube amazon-fire-tv


    【解决方案1】:

    我可以通过https://developers.google.com/youtube/iframe_api_reference 实现解决方案。添加了Javascript代码并启用了Java脚本与Native android之间的交互。

    【讨论】:

      猜你喜欢
      • 2011-11-29
      • 2013-11-20
      • 1970-01-01
      • 2022-01-04
      • 2014-05-01
      • 2012-08-09
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多