首页 > 系统 > iOS > 正文

iOS扫描二维码实现手势拉近拉远镜头

2020-07-26 02:20:26
字体:
来源:转载
供稿:网友

在做扫码需求,往往会有放大镜头需求。

苹果提供了AVCaptureConnection中,videoScaleAndCropFactor:缩放裁剪系数,使用该属性,可以实现拉近拉远镜头。再结合手势UIPinchGestureRecognizer,就很简单实现手势拉近拉远镜头。

手势代码

///记录开始的缩放比例@property(nonatomic,assign)CGFloat beginGestureScale;///最后的缩放比例@property(nonatomic,assign)CGFloat effectiveScale;- (void)cameraInitOver{ if (self.isVideoZoom) {  UIPinchGestureRecognizer *pinch = [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(pinchDetected:)];  pinch.delegate = self;  [self.view addGestureRecognizer:pinch]; }}- (void)pinchDetected:(UIPinchGestureRecognizer*)recogniser{ self.effectiveScale = self.beginGestureScale * recogniser.scale; if (self.effectiveScale < 1.0){  self.effectiveScale = 1.0; } [self.scanObj setVideoScale:self.effectiveScale];}- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer{ if ( [gestureRecognizer isKindOfClass:[UIPinchGestureRecognizer class]] ) {  _beginGestureScale = _effectiveScale; } return YES;}

拉近拉远镜头代码

- (void)setVideoScale:(CGFloat)scale{ [_input.device lockForConfiguration:nil]; AVCaptureConnection *videoConnection = [self connectionWithMediaType:AVMediaTypeVideo fromConnections:[[self stillImageOutput] connections]]; CGFloat maxScaleAndCropFactor = ([[self.stillImageOutput connectionWithMediaType:AVMediaTypeVideo] videoMaxScaleAndCropFactor])/16; if (scale > maxScaleAndCropFactor)  scale = maxScaleAndCropFactor; CGFloat zoom = scale / videoConnection.videoScaleAndCropFactor; videoConnection.videoScaleAndCropFactor = scale; [_input.device unlockForConfiguration]; CGAffineTransform transform = _videoPreView.transform; [CATransaction begin]; [CATransaction setAnimationDuration:.025];  _videoPreView.transform = CGAffineTransformScale(transform, zoom, zoom); [CATransaction commit];}

有一点需要注意:the videoScaleAndCropFactor property may be set to a value in the range of 1.0 to videoMaxScaleAndCropFactor,videoScaleAndCropFactor这个属性取值范围是1.0-videoMaxScaleAndCropFactor,如果你设置超出范围会崩溃哦!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表