当前位置: 移动技术网 > IT编程>移动开发>IOS > 【IOS】使用手势对UIImageView进行缩放、旋转和移动

【IOS】使用手势对UIImageView进行缩放、旋转和移动

2017年12月30日  | 移动技术网IT编程  | 我要评论

众神之源,宝宝用硅胶奶瓶好吗,鲤鱼旗

因为项目需要,需要对图片进行一些操作。本着拿来主义的原则~上网找了方法。

代码:

view plaincopy

//添加所有的手势

-(void)addGestureRecognizerToView:(UIView*)view

{

//旋转手势

UIRotationGestureRecognizer*rotationGestureRecognizer=[[UIRotationGestureRecognizeralloc]initWithTarget:selfaction:@selector(rotateView:)];

[viewaddGestureRecognizer:rotationGestureRecognizer];

//缩放手势

UIPinchGestureRecognizer*pinchGestureRecognizer=[[UIPinchGestureRecognizeralloc]initWithTarget:selfaction:@selector(pinchView:)];

[viewaddGestureRecognizer:pinchGestureRecognizer];

//移动手势

UIPanGestureRecognizer*panGestureRecognizer=[[UIPanGestureRecognizeralloc]initWithTarget:selfaction:@selector(panView:)];

[viewaddGestureRecognizer:panGestureRecognizer];

}

//处理旋转手势

-(void)rotateView:(UIRotationGestureRecognizer*)rotationGestureRecognizer

{

UIView*view=rotationGestureRecognizer.view;

if(rotationGestureRecognizer.state==UIGestureRecognizerStateBegan||rotationGestureRecognizer.state==UIGestureRecognizerStateChanged){

view.transform=CGAffineTransformRotate(view.transform,rotationGestureRecognizer.rotation);

[rotationGestureRecognizersetRotation:0];

}

}

//处理缩放手势

-(void)pinchView:(UIPinchGestureRecognizer*)pinchGestureRecognizer

{

UIView*view=pinchGestureRecognizer.view;

if(pinchGestureRecognizer.state==UIGestureRecognizerStateBegan||pinchGestureRecognizer.state==UIGestureRecognizerStateChanged){

view.transform=CGAffineTransformScale(view.transform,pinchGestureRecognizer.scale,pinchGestureRecognizer.scale);

pinchGestureRecognizer.scale=1;

}

}

//处理拖拉手势

-(void)panView:(UIPanGestureRecognizer*)panGestureRecognizer

{

UIView*view=panGestureRecognizer.view;

if(panGestureRecognizer.state==UIGestureRecognizerStateBegan||panGestureRecognizer.state==UIGestureRecognizerStateChanged){

CGPointtranslation=[panGestureRecognizertranslationInView:view.superview];

[viewsetCenter:(CGPoint){view.center.x+translation.x,view.center.y+translation.y}];

[panGestureRecognizersetTranslation:CGPointZeroinView:view.superview];

}

}

这样只需要简单调用

view plaincopy

[selfaddGestureRecognizerToView:view];

//如果处理的是图片,别忘了

[imageViewsetUserInteractionEnabled:YES];

[imageViewsetMultipleTouchEnabled:YES];

大功告成。view plaincopy

@interfaceYourViewController:UIViewController

{

CGFloatlastScale;

CGRectoldFrame;//保存图片原来的大小

CGRectlargeFrame;//确定图片放大最大的程度

}

然后在viewDidLoad里面加上

view plaincopy

-(void)viewDidLoad

{

[superviewDidLoad];

showImgView=[[UIImageViewalloc]initWithFrame:CGRectMake(0,0,320,480)];

[showImgViewsetMultipleTouchEnabled:YES];

[showImgViewsetUserInteractionEnabled:YES];

[showImgViewsetImage:[UIImageimageNamed:@"1.jpg"]];

oldFrame=showImgView.frame;

largeFrame=CGRectMake(0-screenSize.width,0-screenSize.height,3*oldFrame.size.width,3*oldFrame.size.height);

[selfaddGestureRecognizerToView:showImgView];

[self.viewaddSubview:showImgView];

这样就实现了

但是,这样是不够的。

因为里边的缩放和移动等没有做相应的判断。

因为代码很简洁,所以扩展也非常方便。

我修改了缩放的代码,增加了限制,其他的类似

view plaincopy

//处理缩放手势

-(void)pinchView:(UIPinchGestureRecognizer*)pinchGestureRecognizer

{

UIView*view=pinchGestureRecognizer.view;

if(pinchGestureRecognizer.state==UIGestureRecognizerStateBegan||pinchGestureRecognizer.state==UIGestureRecognizerStateChanged){

view.transform=CGAffineTransformScale(view.transform,pinchGestureRecognizer.scale,pinchGestureRecognizer.scale);

if(showImgView.frame.size.width showImgView.frame=oldFrame;

//让图片无法缩得比原图小

}

if(showImgView.frame.size.width>3*oldFrame.size.width){

showImgView.frame=largeFrame;

}

pinchGestureRecognizer.scale=1;

}

}

这样就好了。保证了图片的最大和最小比例。


如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网