- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含 YouTubePlayerSupportFragment 的 fragment .此 fragment 位于 ViewPager 内。
播放器在我的 Galaxy S3 Android 手机 (4.3/API 18) 和我的虚拟机 (4.3/API 18) 上运行良好。但是在我尝试过的所有其他手机上,播放器都会显示 初始化 YouTube 播放器时发生错误
消息并抛出 onInitializationFailure有一个 UNKNOWN_ERROR
原因。
我已经检查了 LogCat,我的应用程序或 youtube 绝对没有其他错误/警告。
它不适用于以下设备:
我完全不知道为什么它对某些人有效而对其他人却无效。
fragment 代码如下:
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
文件中的内容:
# 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>;
}
关于安卓 YouTube API “An error occurred while initializing YouTube player”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30428535/
我想将 EditText 始终设置为 LTR,我该怎么做?android:textDirection 似乎确实是答案,我无法让项目使用该指令进行编译 最佳答案 为 editText 使用引力 andr
我希望我的应用在每次打开时都显示登录屏幕。使用 android:clearTaskOnLaunch="true" 一切正常。但是有一个错误,只有在手机关机并且应用程序首先使用小部件启动时才会发生。 I
实际上我的要求是我想将动态文件加载到像图像一样的网页中。视频,音频等,它来自 Assets 或应用程序自己的文件目录,这不是问题。 我尝试使用以下两种方式。 方式一 这是我的 html 文件在 ass
我正在触发一个 DatePickerDialog,在 api 22 (Android 5.1) 之前它一直在工作并显示良好,我在上面设置混合和最大日期(最小 = 当前日期,最大 = 从当前日期开始的
我有一个 ListView ,我在其中将标题 View 添加到该列表。一切都很好,但是当滚动列表 headerview 也随着列表移动时,所以我想避免 headerview 滚动,我的意思是当我列表到
虽然我在android上做过一些app,但我还是一头雾水。是否可以使用 SDK 4.0 中的功能,并在 android 2.1 或更低版本上运行该应用程序? 我尝试了你们提到的方法,但出现错误 - F
您好,我正在开发小型 android 应用程序,我想在其中显示带有一些元素的简单 gridview。它工作正常。唯一的问题是即使有空间,它也总是只显示两列。它平均将屏幕分成 2 列并仅显示两个元素。如
我正在使用 Android 2.3.3 API 构建一个应用程序。我需要识别方向的变化并执行一些操作。所以我在 Android Manifest 中添加了以下内容, android:configCha
我正在尝试在“点击”包含特定 MIME 类型的 nfc 标签时开始一项 Activity 。我制作了一个 mime 类型为“text/plain”的标签,并将其添加到 list 中:
我可以将一些数据保存到文件中 val byteArrayOutputStream = ByteArrayOutputStream() byteArrayOutputStream.wri
我正在尝试解析一个包含复杂阿拉伯字母的 XML 文件.. 当我在 android 2.3.7 上测试时,并不是所有的阿拉伯字母都被支持,仍然有一些复杂的显示为方 block .. 但是在 androi
我需要编写一个方法来确定设备是平板电脑还是手机。我不需要根据这个显示不同的用户界面。我只需要有关设备的信息,以便将来我可以将其发送到指标。 在互联网上,我找到了很多方法来确定设备是否是平板电脑。我已经
我正在玩文字转语音,让我的测试应用程序更有趣。它适用于模拟器,但不适用于我的手机,因为我的默认语言环境不是英语。 但是,文本是英文的,所以 tts 当然应该使用英文。据我所知,我可以实现一个自动安装,
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
这个问题在这里已经有了答案: I lost my .keystore file? (12 个回答) 4年前关闭。 当我以前的操作系统损坏并安装新的(7 月 3 日)时,以前的 android_key_
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
在我的 v27\style.xml 中,我有以下代码来设置白色导航栏: @color/colorPrimary @color/colorPrimaryDark @color/
我想通过发送电子邮件 startActivity(Intent.createChooser(new Intent(android.content.Intent.ACTION_SEND))) 我知道要将
我实现了一个自定义 ListView ,它看起来像 Twitter 时间线。 adapter = new MyClickableListAdapter(this, R.layout.timeline,
我有一个显示启动画面的自定义对话框; mSplashDialog = new Dialog(MyActivity.this,R.layout.splash); mSplashDialog.setCon
我是一名优秀的程序员,十分优秀!