iOS YTPlayerView强制视频质量

时间:2017-01-05 06:40:35

标签: ios youtube youtube-iframe-api ytplayerview

我目前在我们的应用程序中使用iOS-youtube-player-helper库。有一个视图控制器,其YTPlayerView的宽高比为16:9,这意味着它只占用了一部分屏幕。视频是在媒体中加载的,无论如何,我无法在720P或1080P中播放。我确信这些品质是可用的,它只是基于视频播放器高度强制质量的YTPlayerView。因为这是一个库而不是直接iframe嵌入,我不能使用“vq”参数(在playerVars中指定vq似乎不起作用),并且将质量设置为小然后稍后更改它也不起作用(参考{{ 3}})

现在,由于UI设计问题,我无法让YTPlayerView填满整个屏幕。那么,是否可以强制YTPlayerView至少播放720P? (解决方法,更改库代码,......)

因为这是一个将在App Store上的应用程序(当然我们也不希望与谷歌有任何法律纠纷),请不要建议使用针对Youtube ToC的库,例如{{ 1}}

非常感谢

1 个答案:

答案 0 :(得分:1)

我找到了一个解决方法,这对我很有用。

首先,问题取决于webView内构建的YTPlayerView大小。例如,如果你有一个320x200的playerView,尝试强制你的视频到720hd不起作用,因为iFrame youtube播放器类根据你的播放器尺寸重新切换到更好的分辨率(在这种情况下,因为你有320x200的小质量)。

您可以看到解释此问题的SO answer

YTPlayerView课程导入项目后,您有两个文件:YTPlayerView.hYTPlayerView.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上测试了它的功能。让我知道。