Android YouTube API“初始化 YouTube 播放器时发生错误”

2024-02-08

我有一个包含以下内容的片段YouTubePlayerSupportFragment https://developers.google.com/youtube/android/player/reference/com/google/android/youtube/player/YouTubePlayerSupportFragment。该片段位于 ViewPager 内。

该播放器在我的 Galaxy S3 Android 手机 (4.3 / API 18) 和我的虚拟机 (4.3 / API 18) 上运行良好。 但在我尝试过的所有其他手机上,播放器都会显示An error occurred while initializing YouTube player消息并抛出初始化失败时 https://developers.google.com/youtube/android/player/reference/com/google/android/youtube/player/YouTubePlayer.OnInitializedListener#onInitializationFailure(com.google.android.youtube.player.YouTubePlayer.Provider,%20com.google.android.youtube.player.YouTubeInitializationResult)UNKNOWN_ERROR reason.

我检查了 LogCat,我的应用程序或 YouTube 绝对没有其他错误/警告。

它不适用于以下设备:

  • 安卓 4.2.1 - Youtube 10.18.55
  • 安卓 4.4.2 - Youtube 10.18.55
  • Android 5.1 - Youtube 以上要求

我完全不知道为什么它对某些人有效而对另一些人无效。

这是片段的代码:

    public class RoomFragmentVideo extends PlugFragment implements
    YouTubePlayer.OnInitializedListener, YouTubePlayer.PlayerStateChangeListener {
            private static String CLASS_DBG_NAME = "RoomFragmentVideo";

            private static final int RECOVERY_DIALOG_REQUEST = 1;

            private YouTubePlayerSupportFragment youTubePlayer ;
            private int playerInitialized;
            private YouTubePlayer player;

            static PlugFragment init(Bundle args) {
                     RoomFragmentVideo roomFrag = new RoomFragmentVideo();
                     // Supply val input as an argument.
                     roomFrag.setArguments(args);
                     Log.d(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - ","Created with args Room: "  + ((String)args.get(RoomFragmentChat.ARG_ROOM)));
                     return roomFrag;
            }

            @Override
            public void onCreate(Bundle savedInstanceState) {
             super.onCreate(savedInstanceState);
             thisActivity = (AppCompatActivity) this.getActivity();
            }

            @Override
            public View onCreateView(LayoutInflater inflater, ViewGroup container,
             Bundle savedInstanceState) {
                     View rootview = inflater.inflate(R.layout.fragment_roomvideo, container,false);
                     youTubePlayer = YouTubePlayerSupportFragment.newInstance();
                     FragmentTransaction transaction = getChildFragmentManager().beginTransaction();
                     transaction.add(R.id.youtube_fragment, youTubePlayer).commit();
                     youTubePlayer.initialize(YouTubeDeveloperKey.DEVELOPER_KEY, this);
                     return rootview;

            }

            protected YouTubePlayer.Provider getYouTubePlayerProvider() {
                return youTubePlayer;
            }

            @Override
            public void onActivityResult(int requestCode, int resultCode, Intent data) {
                if (requestCode == RECOVERY_DIALOG_REQUEST) {
                  getYouTubePlayerProvider().initialize(YouTubeDeveloperKey.DEVELOPER_KEY, this);
                }
            }         

            @Override
            public void onInitializationFailure(YouTubePlayer.Provider provider,
                          YouTubeInitializationResult errorReason) {
                    if (errorReason.isUserRecoverableError()) {
                          errorReason.getErrorDialog(this.getActivity(), 1).show();
                          Log.e(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - YouTube" ,"[Recoverable] Reason : " + errorReason.toString());
                    }
                    else {
                            //String errorMessage = String.format(getString(R.string.error_player), errorReason.toString());
                            String errorMessage = "Video couldnt load";
                            Toast.makeText(this.getActivity(), errorMessage, Toast.LENGTH_LONG).show();
                            Log.e(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - YouTube" ,"[Unrecoverable] Reason : " + errorReason.toString() + " Message: " + errorMessage);
                            playerInitialized = -1; 
                    }

            }

            @Override
            public void onInitializationSuccess(YouTubePlayer.Provider provider, YouTubePlayer player,
                          boolean wasRestored) {
                            this.player = player;
                            player.setPlayerStyle(PlayerStyle.CHROMELESS);
                            player.loadVideo(this.videoID);
                            playerInitialized = 1;
            }

            @Override
            public void onPause(){
                    super.onPause();
                    Log.v(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - " , "onPause");
            }

            @Override
            public void onResume(){
                    super.onResume();
                    Log.v(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - " , "onResume");
            }

            @Override
            public void onStop(){
                    super.onStop();
                    player = null;
                    playerInitialized = -2;
                    Log.v(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - " , "onStop");
            }

            @Override
            public void setUserVisibleHint (boolean isVisibleToUser){
                    super.setUserVisibleHint(isVisibleToUser);
                    if(isVisibleToUser){
                            this.resume();
                    }
                    Log.v(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - " , "setUserVisibleHint, status: " + isVisibleToUser);
            }

            @Override
            public void onAdStarted() {
                    return;                
            }

            @Override
            public void onError(ErrorReason arg0) {
                    Log.e(Constants.APP_DBG_LOG + CLASS_DBG_NAME + " - " +"YoutubePlayer", arg0.name());
                    Toast.makeText(thisActivity, "YoutubePlayer error: " + arg0.name(), Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onLoaded(String arg0) {
                    return;
            }

            @Override
            public void onLoading() {
                    return;
            }

            @Override
            public void onVideoEnded() {
                    return;
            }

            @Override
            public void onVideoStarted() {
                    return;

            }
    }

这是 XML:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >

       <FrameLayout
            android:id="@+id/youtube_fragment"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="bottom"
            android:visibility="visible" />

    </LinearLayout>

我究竟做错了什么 ?

多谢 !


问题实际上是 proguard。 这是我添加到的内容proguard-project.txt file:

# keep youtube / google
-keep class com.google.api.services.** { *; }
-keep class com.google.android.youtube.player.** { *; }
# Needed by google-api-client to keep generic types and @Key annotations accessed via reflection
-keepclassmembers class * {
  @com.google.api.client.util.Key <fields>;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Android YouTube API“初始化 YouTube 播放器时发生错误” 的相关文章

  • 如何在android中显示对话框之外的图像?

    我试图在对话框片段的顶部显示配置文件图像 一半在图像之外 我在下面附加了示例对话框 就像那样 并尝试了旧 Stackoverflow 解决方案中的所有 FrameLayout 协作 但我无法存档此内容 请给我正确的解决方案 谢谢 Updat
  • 当满足条件时,如何以编程方式更改 ImageButton src 目标?

    我有一个学校项目 我正在尝试开发一个手电筒应用程序 对于开 关 ImageButton 我想要 4 个自定义图像 如果手电筒关闭 turn on png 默认 turn on pressing png 按下状态 true 如果手电筒打开 t
  • 在 gradle 中,我应该排除分支下的所有依赖项还是只排除根就足够了?

    我已将以下自定义任务添加到我的build gradlefile 为了打印出依赖项的依赖项 This part is useful for finding conflict resolution s between dependencies
  • 如何通过我的活动在 Android 中设置铃声?

    我正在尝试找到一种方法来通过 Android 活动中的代码设置新的默认铃声 我已经将铃声下载到bytearray 最后 我设法将默认铃声设置为我下载的铃声 下面不包含下载代码 仅包含将其设置为默认铃声所需的代码 File k new Fil
  • 为什么反射会减慢Android手机的速度

    我多次读到反射会降低手机性能 这有多真实 例如 在我的例子中 我从 Web 服务获取一些参数 这些参数与我在 Android 应用程序中的类的参数同名 所以我只是使用java字段和反射设置这些参数的值 它似乎并没有降低性能 有人可以向我解释
  • 需要 Android webview window.open() 和 window.close() 的信息

    我正在开发一个安卓应用程序 这是我网站的 WebView 该网站包含一个弹出按钮 单击该按钮后 将打开一个新窗口并显示内容 该链接可以来自外部站点 然而 当我实现此操作时 新选项卡正在打开 之后它会弹出以打开浏览器 尽管在 Web 视图中打
  • ExpandableListview OnGroupClickListener 未触发

    我正在关注这个 以编程方式折叠 ExpandableListView 中的组 https stackoverflow com questions 4314777 programmatically collapse a group in ex
  • Internet Explorer 和 Firefox 上的 YouTube IFrame API

    更多的是 答案 而不是 问题 但在其他地方没有找到这个 所以我将其发布在这里 我在所有版本的 IE 和 Firefox 中初始化 iFrame API 时遇到困难 需要进行一些自定义实现 基本上 它会加载 API 但不会创建玩家对象 经过一
  • React Native Expo StackNavigator 重叠通知栏

    我正在尝试为我的 React Native Expo 应用程序实现导航栏 这里有一个问题 dependencies expo 18 0 3 react 16 0 0 alpha 12 react native 0 45 1 react na
  • 透明 9patch 图像:显示出线条

    我得到了一个透明的 9 补丁图像 其中有 9 条补丁线显示槽 This is the output 显然我不希望水平线可见 这就是我创建 9patch 的方式 This is the final image that is used in
  • 选项卡主机内的 Android Fragment 视图状态 [重复]

    这个问题在这里已经有答案了 可能的重复 使用 Fragment 为 Android 中的每个选项卡单独的返回堆栈 https stackoverflow com questions 6987334 separate back stack f
  • MIUI 权限被拒绝活动 KeyguardLocked

    当应用程序处于后台且屏幕被锁定时 我无法启动活动 没有异常或警告 只是不调用 onCreate 我一直在与这个问题作斗争 我想我终于找到了它的根源 日志中有一行 D com android server am ExtraActivityMa
  • 当 minifyEnabled 为 true 时 Android 应用程序崩溃

    我正在使用多模块应用程序 并且该应用程序崩溃时minifyEnabled true in the installed模块的build gradle 以下是从游戏控制台检索到的反混淆堆栈跟踪 FATAL EXCEPTION Controlle
  • 如何为我的 Android Market APK 创建证书?

    我想将我的第一个 APK 应用程序上传到 Android Market 但我收到了此错误 顺便说一下 在 stackoverflow 中搜索时并没有引导我找到正确的链接 市场不接受使用调试证书签名的 APK 创建有效期至少 50 年的新证书
  • 哪个视图最亮?

    在Android中 哪个是轻量级视图 例如 View Textview Edittext 等 在某些情况下 我们需要使用视图来填充区域而不向用户显示视图 同时屏幕加载速度应该很快 您可以使用空间 android widget Space S
  • 如何在android中通过蓝牙向配对设备发送短信?

    在我的应用程序中 我想通过蓝牙发送和接收短信 我可以在列表视图中看到配对设备名称和地址的列表 但是当我尝试向配对设备发送文本时 什么也没有发生 在其他设备中没有收到文本 这是我向配对设备发送消息的代码 private void sendDa
  • Android 标记如何实现拖放?

    你好 我正在 Android 中开发 MapView 应用程序 我有三个标记 我希望稍后能够使用 Google Map API getlocation function 为了尝试一下 我想使用拖放功能移动标记 然后检查位置 任何人都可以通过
  • 如何更改操作栏背景和文本颜色

    我正在使用本教程中的导航抽屉 http www androidhive info 2013 11 android sliding menu using navigation drawer http www androidhive info
  • 将对象从手机共享到 Android Wear

    我创建了一个应用程序 在此应用程序中 您拥有包含 2 个字符串 姓名和年龄 和一个位图 头像 的对象 所有内容都保存到 sqlite 数据库中 现在我希望可以在我的智能手表上访问这些对象 所以我想实现的是你可以去启动 启动应用程序并向左和向
  • LifeCycleAware Fragment 中的片段生命周期事件

    我有一个生命周期感知片段和一个LifecycleObserver class public class MyFragment extends Fragment Override public void onCreate Nullable B

随机推荐