美文网首页
WKWebView 富文本 显示图片视频 表格

WKWebView 富文本 显示图片视频 表格

作者: witcheryboy | 来源:发表于2019-05-10 13:10 被阅读0次
static NSString * const htmlHeadString = @"<body   style=\"word-wrap:break-word; font-family:Arial\"><head><style>img{max-width: 100%;height:auto;display:block;}</style><style>video{max-width: 100%;height:auto;display:block;}</style><meta name=\"viewport\" content=\"width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no\" /></head>\<style type=\"text/css\">\tr{display:flex;border-right:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0}\th{background:#f0f0f0;border-top:1px solid #e0e0e0}\td,th{flex:1;padding:5px;font-size:28rpx;border-left:1px solid #e0e0e0;word-break:break-all}</style>";
//js方法遍历图片添加点击事件 返回图片个数static NSString * const htmlJsGetImages =@"function getImages(){\var objs = document.getElementsByTagName(\"img\");\for(var i=0;i<objs.length;i++){\objs[i].onclick=function(){\document.location=\"myweb:imageClick:\"+this.src;\};\};\return objs.length;\}\function getImageRect(i){\var imgs = document.getElementsByTagName(\"img\");\var rect;\rect = imgs[i].getBoundingClientRect().left+\"::\";\rect = rect+imgs[i].getBoundingClientRect().top+\"::\";\rect = rect+imgs[i].width+\"::\";\rect = rect+imgs[i].height;\return rect;\}\function getImageData(i){\var imgs = document.getElementsByTagName(\"img\");\var img=imgs[i]; \var canvas=document.createElement(\"canvas\"); \var context=canvas.getContext(\"2d\"); \canvas.width=img.width; canvas.height=img.height; \context.drawImage(img,0,0,img.width,img.height); \return canvas.toDataURL(\"image/png\") \}\function pause() { \var audios = document.getElementsByTagName(\"audio\");\for (var i = 0; i < audios.length; i++) {\var audio = audios[i];\audio.pause();}\}\function getVideos () {\var videos = document.getElementsByTagName(\"video\");\for (var i = 0; i < videos.length; i++) {\var video = videos[i];\var url = video.src;\url = url + \"#t=1\";\video.src = url;}\}\document.documentElement.style.webkitUserSelect='none';\document.documentElement.style.webkitTouchCallout='none';\"; 
-(void)createWebView:(NSString *)coursewareDetail {

    self.imgSrcArrayM=    [selfreplaceImageUrl:ZLIFISNULL(coursewareDetail)]; 

    NSString *htmlStr =[NSString stringWithFormat:@"%@%@",htmlHeadString,ZLIFISNULL(coursewareDetail)];

    [self.webView loadHTMLString:[NSString stringWithFormat:@"

%@
",htmlStr]
                         baseURL:nil];

}

-(void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation{

    //注入js方法

    [webView evaluateJavaScript:htmlJsGetImages completionHandler:nil];

    [webView evaluateJavaScript:@"getImages()" completionHandler:nil];//必须调用注入js方法   

    [webView evaluateJavaScript:@"getVideos()" completionHandler:nil];//必须调用注入js方法

    //禁止长按 放大镜 选择文本

    [webView evaluateJavaScript:@"document.documentElement.style.webkitUserSelect='none';" completionHandler:nil];

    //禁止长按 连接弹出提示框跳转

    [webView evaluateJavaScript:@"document.documentElement.style.webkitTouchCallout='none';" completionHandler:nil];

}

//MARK:WKWebview 点击事件

-(void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction

decisionHandler:(void(^)(WKNavigationActionPolicy))decisionHandler {

    @try{

        //将url转换为string

        decisionHandler(WKNavigationActionPolicyAllow);

        NSString *requestString =  navigationAction.request.URL.absoluteString;

        if(requestString==nil){            return;        }

        //hasPrefix 判断创建的字符串内容是否以pic:字符开始

        if([requestString hasPrefix:@"myweb:imageClick:"]){

            // return NO;

            NSString *imageUrl =[requestString substringFromIndex:@"myweb:imageClick:".length];

            //预览图片

            NSInteger number =[self.imgSrcArrayM indexOfObject:imageUrl];

            NSString *str =[NSString stringWithFormat:@"getImageRect(%ld)",number];

            WS(weakSelf);

            [webView evaluateJavaScript:str  completionHandler:^(idResult,NSError * error){

                if(weakSelf.imgSrcArrayM.count>0){

                    // 图片总数

                    ZLPBViewController *imageBrowser =[[ZLPBViewController alloc]initWithFrame:SCREEN_BOUNDS];

                    imageBrowser.currentSelectedIamge =number;

                    imageBrowser.bigImageArray = weakSelf.imgSrcArrayM;

                    [imageBrowser showImages];

                }

            }];

        }

    }@catch(NSException *exception){

        NSLog(@"错误信息:%@",exception);

    }

}



//MARK:获得所有webview图片

- (NSMutableArray*)replaceImageUrl:(NSString*)content {

    NSMutableArray  * imgSrcArrayM = [NSMutableArrayarray];

    // 匹配<img>标签

    NSString *urlPattern = @"]+?src=[\"']?([^>'\"]+)[\"']?";

    NSError*error = [NSErrornew];

    NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:urlPattern options:NSRegularExpressionCaseInsensitive error:&error ];

    // match

    NSUInteger count = [regex numberOfMatchesInString:content options:NSMatchingReportProgress range:NSMakeRange(0, [content length])];// 匹配到的次数

    if(count >0) {

        NSArray* matches = [regex matchesInString:content options:NSMatchingReportCompletion range:NSMakeRange(0, [content length])];

        for(NSTextCheckingResult*matchinmatches) {

            NSIntegercount = [matchnumberOfRanges];// 匹配项

            for(NSIntegerindex =0;index < count;index++){

                NSRangehalfRange = [matchrangeAtIndex:index];

                if(index ==1) {

                    // 图片的src属性值

                    NSString*urlStr = [contentsubstringWithRange:halfRange];

                    // 保存图片URL

                    [imgSrcArrayMaddObject:urlStr];

                }

            }

        }

    }

    returnimgSrcArrayM;

}

相关文章

网友评论

      本文标题:WKWebView 富文本 显示图片视频 表格

      本文链接:https://www.haomeiwen.com/subject/glxaoqtx.html