实现长按识别webview中的二维码
来源:互联网 发布:网络114网 编辑:程序博客网 时间:2024/06/10 09:53
@property (nonatomic,copy) NSString *imgURL; UIWebView *_web; NSInteger _gesState;- (void)webViewDidFinishLoad:(UIWebView *)webView{ [MBProgressHUD hideHUD]; //实现图片长按识别功能 static NSString* const kTouchJavaScriptString= @"document.ontouchstart=function(event){\ x=event.targetTouches[0].clientX;\ y=event.targetTouches[0].clientY;\ document.location=\"myweb:touch:start:\"+x+\":\"+y;};\ document.ontouchmove=function(event){\ x=event.targetTouches[0].clientX;\ y=event.targetTouches[0].clientY;\ document.location=\"myweb:touch:move:\"+x+\":\"+y;};\ document.ontouchcancel=function(event){\ document.location=\"myweb:touch:cancel\";};\ document.ontouchend=function(event){\ document.location=\"myweb:touch:end\";};"; [webView stringByEvaluatingJavaScriptFromString:kTouchJavaScriptString];//注入js方法}- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{ // add by zcj 实现图片长按识别功能 NSString *requestString = request.URL.absoluteString; NSArray *components = [requestString componentsSeparatedByString:@":"]; if ([components count] > 1 && [(NSString *)[components objectAtIndex:0] isEqualToString:@"myweb"]) { if([(NSString *)[components objectAtIndex:1] isEqualToString:@"touch"]) { //NSLog(@"you are touching!"); if ([(NSString *)[components objectAtIndex:2] isEqualToString:@"start"]) { _gesState = UIGestureRecognizerStateBegan; float ptX =[[components objectAtIndex:3]floatValue]; float ptY =[[components objectAtIndex:4]floatValue]; NSString *js = [NSString stringWithFormat:@"document.elementFromPoint(%f, %f).tagName", ptX, ptY]; NSString * tagName = [_web stringByEvaluatingJavaScriptFromString:js]; if ([tagName isEqualToString:@"IMG"]) { self.imgURL = [NSString stringWithFormat:@"document.elementFromPoint(%f, %f).src", ptX, ptY]; } if (self.imgURL) { [self performSelector:@selector(handleLongTouch) withObject:nil afterDelay:1.0]; } } else if ([(NSString *)[components objectAtIndex:2] isEqualToString:@"move"]) { _gesState = UIGestureRecognizerStateChanged; } } else if ([(NSString*)[components objectAtIndex:2]isEqualToString:@"end"]) { _gesState = UIGestureRecognizerStateEnded; } }// ]end return YES;}- (void)handleLongTouch { if (self.imgURL && _gesState == UIGestureRecognizerStateBegan) { UIAlertController *alertController = [UIAlertController alertControllerWithTitle:nil message:nil preferredStyle:UIAlertControllerStyleActionSheet]; NSString *urlToSave = [_web stringByEvaluatingJavaScriptFromString:self.imgURL]; NSData* data = [NSData dataWithContentsOfURL:[NSURL URLWithString:urlToSave]]; UIImage* image = [UIImage imageWithData:data]; NSDictionary *options = [[NSDictionary alloc] initWithObjectsAndKeys: @"CIDetectorAccuracy", @"CIDetectorAccuracyHigh",nil]; CIDetector *detector = nil; if ([[UIDevice currentDevice].systemVersion floatValue] >= 8.0) detector = [CIDetector detectorOfType:CIDetectorTypeQRCode context:nil options:options]; NSArray *features = [detector featuresInImage:[CIImage imageWithCGImage:image.CGImage]] ; // 识别图中二维码 UIAlertAction *judgeCode = [UIAlertAction actionWithTitle:@"识别图中二维码" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) { CIQRCodeFeature *feature = [features objectAtIndex:0]; NSString *scannedResult = feature.messageString; if ([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:scannedResult]]){ [[UIApplication sharedApplication] openURL:[NSURL URLWithString:scannedResult]]; }else{ [MBProgressHUD showError:@"无法识别的网址"]; } }]; // 保存图片到手机 UIAlertAction *saveImage = [UIAlertAction actionWithTitle:@"保存到手机" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) { UIImageWriteToSavedPhotosAlbum(image, self, @selector(image:didFinishSavingWithError:contextInfo:), nil); }]; // 取消 UIAlertAction *cancell = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) { }]; if (features.count >= 1) { [alertController addAction:judgeCode]; } [alertController addAction:saveImage]; [alertController addAction:cancell]; [self presentViewController:alertController animated:YES completion:nil]; }}
阅读全文
0 0
- 实现长按识别webview中的二维码
- 长按二维码识别
- Android的二维码功能实现以及长按识别二维码
- android webView使用js/css实现夜间模式 长按识别图片以及二维码,网页可以上传图片
- android webview长按识别图片 ,利用zxing识别图片是否是二维码
- 安卓webView实现长按二维码的自动识别功能
- 安卓webView实现长按二维码的自动识别功能
- 安卓webView实现长按二维码的自动识别功能
- 长按二维码不识别
- 生成二维码,长按识别二维码
- iOS之长按识别二维码/生成二维码/扫描二维码
- Android 基于google Zxing实现二维码的生成,识别和长按识别的效果
- Android 长按识别图中二维码
- iOS长按识别图中二维码
- 柳丁_长按二维码识别测试
- 微信生成二维码长按识别
- 二维码的生成以及长按识别
- 长按识别图中二维码
- 移动 VR 究竟有多少坑?高通、ARM、谷歌、Unity Technologies 的专家们这么看 | SIGGRAPH 2017 圆桌对话精选
- 【Node.js-5】multer的三种上传情况:单个文件,多个同名文件,多个不同名文件
- Docker安装
- 链式队列创建
- OC基础-02-类和对象
- 实现长按识别webview中的二维码
- js封装函数
- mac下如何激活Intelliji idea
- js简单实现短信验证码界面
- Central Europe Regional Contest 2016 C.Convex Contour
- 系统管理员应该知道的 20 条 Linux 命令
- luoguP1073 最优贸易
- linux下查看多某个IP的寻址路由信息
- C语言之递归篇