我目前在我们的应用程序中使用iOS-youtube-player-helper
库。有一个视图控制器,其YTPlayerView
的宽高比为16:9,这意味着它只占用了一部分屏幕。视频是在媒体中加载的,无论如何,我无法在720P或1080P中播放。我确信这些品质是可用的,它只是基于视频播放器高度强制质量的YTPlayerView
。因为这是一个库而不是直接iframe嵌入,我不能使用“vq”参数(在playerVars中指定vq似乎不起作用),并且将质量设置为小然后稍后更改它也不起作用(参考{{ 3}})
现在,由于UI设计问题,我无法让YTPlayerView
填满整个屏幕。那么,是否可以强制YTPlayerView
至少播放720P? (解决方法,更改库代码,......)
因为这是一个将在App Store上的应用程序(当然我们也不希望与谷歌有任何法律纠纷),请不要建议使用针对Youtube ToC的库,例如{{ 1}}
非常感谢
答案 0 :(得分:1)
我找到了一个解决方法,这对我很有用。
首先,问题取决于webView
内构建的YTPlayerView
大小。例如,如果你有一个320x200的playerView,尝试强制你的视频到720hd不起作用,因为iFrame youtube播放器类根据你的播放器尺寸重新切换到更好的分辨率(在这种情况下,因为你有320x200的小质量)。
您可以看到解释此问题的SO answer。
将YTPlayerView
课程导入项目后,您有两个文件:YTPlayerView.h
和YTPlayerView.m
YTPlayerView.m ( 更新也适用于iPad )
我已经更改了使用自定义大小(4k分辨率)初始化webview的功能,并且在最后一部分我添加了缩放内容并恢复原始帧的可能性,如下所示:
- (UIWebView *)createNewWebView {
CGRect frame = CGRectMake(0.0, 0.0, 4096.0, 2160.0); //4k resolution
UIWebView *webView = [[UIWebView alloc] initWithFrame:frame];
//UIWebView *webView = [[UIWebView alloc] initWithFrame:self.bounds];
webView.autoresizingMask = (UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight);
webView.scrollView.scrollEnabled = NO;
webView.scrollView.bounces = NO;
if ([self.delegate respondsToSelector:@selector(playerViewPreferredWebViewBackgroundColor:)]) {
webView.backgroundColor = [self.delegate playerViewPreferredWebViewBackgroundColor:self];
if (webView.backgroundColor == [UIColor clearColor]) {
webView.opaque = NO;
}
}
webView.scalesPageToFit = YES;
if ( UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad )
{
CGSize contentSize = webView.scrollView.contentSize;
CGSize viewSize = self.bounds.size;
float scale = viewSize.width / contentSize.width;
webView.scrollView.minimumZoomScale = scale;
webView.scrollView.maximumZoomScale = scale;
webView.scrollView.zoomScale = scale;
// center webView after scaling..
[webView setFrame:CGRectMake(0.0, self.frame.origin.y/3, 4096.0, 2160.0)];
} else {
webView.frame = self.bounds;
}
[webView reload];
return webView;
}
希望这有助于试图在他的项目中使用Youtube原创播放器。
P.S。:我所有的尝试都是通过快速项目和以下变量完成的:
var playerVars:Dictionary =
["playsinline":"1",
"autoplay":"1",
"modestbranding":"1",
"rel":"0",
"controls":"0",
"fs":"0",
"origin":"https://www.example.com",
"enablejsapi":"1",
"iv_load_policy":"3",
"showinfo":"0"]
使用功能:
self.playerView.load(withVideoId: "Rk6_hdRtJOE", playerVars: self.playerVars)
以及强制解决的以下方法:
self.playerView.loadVideo(byId: "Rk6_hdRtJOE", startSeconds: 0.0, suggestedQuality: YTPlaybackQuality.HD720)
关于iPad:
正如爱德华在评论中所报告的那样,iPad上存在一些问题,因为这些设备似乎不适用scalesPageToFit
。目标是检查设备是否是iPad,然后缩放(缩小)scrollView
以托管小视图边界。
我已经在我的iPad上测试了它的功能。让我知道。