通过JavaScript钩子来获取UIWebView视频播放的状态

转自:http://blog.csdn.net/chenyong05314/article/details/42120917

http://dev.classmethod.jp/client-side/javascript/uiwebview-video-tag/

如有侵犯,请来信oiken@qq.com


场景是这样的

在UIWebview里面有一个视频,点击之后会弹出全屏的系统的视频播放器,这时候你可能需要在全屏的时候,或者在用户看完视频的时候需要做一些事情。

videofullscreenhandler.js

(function () {
    var scheme = 'videohandler://';
    var videos = document.getElementsByTagName('video');
    for (var i = 0; i < videos.length; i++) {
        videos[i].addEventListener('webkitbeginfullscreen', onBeginFullScreen, false);
        videos[i].addEventListener('webkitendfullscreen', onEndFullScreen, false);
    }
    function onBeginFullScreen() {
        window.location = scheme + 'video-beginfullscreen';
    }
    function onEndFullScreen() {
        window.location = scheme + 'video-endfullscreen';
    }
})();
在UIWebview的delegate里面做处理

#pragma mark - UIWebViewDelegate
- (void)webViewDidFinishLoad:(UIWebView *)webView {
     NSString *videoHandlerString = [[NSBundle mainBundle] myVideoFullScreenHandlerJavaScriptString];
    if (videoHandlerString) {
        [webView stringByEvaluatingJavaScriptFromString:videoHandlerString];
    }
}
 - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType  {   
     if ([request.URL.scheme isEqualToString:VideoHandlerScheme]) {
      NSLog(@"%@", request.URL);//在这里可以获得事件
     return NO;
    }
    return YES;
}
---------------------

日本人的文章讲得清楚些:

这个是得到播放和停止的通知

videoplayendhandler.js
( function () {
     var scheme = 'videohandler://' ;
 
     var videos = document.getElementsByTagName( 'video' );
 
     for ( var i = 0; i < videos.length; i++) {
         videos[i].addEventListener( 'play' , onPlay, false );
         videos[i].addEventListener( 'ended' , onEnded, false );
     }
 
     function onPlay() {
         window.location = scheme + 'video-play' ;
     }
 
     function onEnded() {
         window.location = scheme + 'video-ended' ;
     }
})();

MYWebViewController.m
/**
  *  ビデオハンドラのためのダミーURLスキーム
  */
static NSString * const VideoHandlerScheme = @"videohandler" ;
 
#pragma mark - Lifecycle methods
 
- ( void )viewDidLoad
{
     [ super viewDidLoad];
 
     NSString *htmlString =
     [[ NSBundle mainBundle] myVideoPageHTMLString];
     [ self .webView loadHTMLString:htmlString
                          baseURL:[[ NSBundle mainBundle] bundleURL]];
}
 
#pragma mark - UIWebViewDelegate
 
- ( void )webViewDidFinishLoad:(UIWebView *)webView
{
     NSString *videoHandlerString =
     [[ NSBundle mainBundle] myVideoPlayEndHandlerJavaScriptString];
 
     if (videoHandlerString) {
         [webView stringByEvaluatingJavaScriptFromString:videoHandlerString];
     }
}
 
- ( BOOL )webView:(UIWebView *)webView shouldStartLoadWithRequest:( NSURLRequest *)request
  navigationType:(UIWebViewNavigationType)navigationType
{   
     if ([request.URL.scheme isEqualToString:VideoHandlerScheme]) {
         NSLog ( @"%@" , request.URL); //こちらでイベントがフックできます。
         return NO ;
     }
 
     return YES ;
}

这个是得到进入和退出全屏播放的通知

videofullscreenhandler.js
( function () {
     var scheme = 'videohandler://' ;
 
     var videos = document.getElementsByTagName( 'video' );
 
     for ( var i = 0; i < videos.length; i++) {
         videos[i].addEventListener( 'webkitbeginfullscreen' , onBeginFullScreen, false );
         videos[i].addEventListener( 'webkitendfullscreen' , onEndFullScreen, false );
     }
 
     function onBeginFullScreen() {
         window.location = scheme + 'video-beginfullscreen' ;
     }
 
     function onEndFullScreen() {
         window.location = scheme + 'video-endfullscreen' ;
     }
})();


MYWebViewController.m
#pragma mark - UIWebViewDelegate
 
- ( void )webViewDidFinishLoad:(UIWebView *)webView
{
     NSString *videoHandlerString =
     [[ NSBundle mainBundle] myVideoFullScreenHandlerJavaScriptString];
 
     if (videoHandlerString) {
         [webView stringByEvaluatingJavaScriptFromString:videoHandlerString];
     }
}
 
- ( BOOL )webView:(UIWebView *)webView shouldStartLoadWithRequest:( NSURLRequest *)request
  navigationType:(UIWebViewNavigationType)navigationType
{   
     if ([request.URL.scheme isEqualToString:VideoHandlerScheme]) {
         NSLog ( @"%@" , request.URL); //こちらでイベントがフックできます。
         return NO ;
     }
 
     return YES ;
}

注意要吧uiwebView的参数allowsInlineMediaPlayback设置为YES,才会自动播放

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值