资讯专栏INFORMATION COLUMN

[分享]iOS开发-图片点击点击放大

Brenner / 761人阅读

摘要:图片点击放大再次点击返回原视图完美封装一个类一句代码即可调用完美实现创建了一个专门用于放大图片的类以下为文件浏览头像头像所在的以下为文件引入此类之后为自己需要放大的添加手势局部放大调用方法分享来源

图片点击放大,再次点击返回原视图.完美封装,一个类一句代码即可调用.IOS完美实现

创建了一个专门用于放大图片的类,以下为.h文件

#import



 

@interface

SJAvatarBrowser : NSObject

 //@brief  浏览头像

 //@param  oldImageView    头像所在的imageView


+(void)showImage:(UIImageView*)avatarImageView;

 

@end

以下为.m文件

#import

"SJAvatarBrowser.h"

static

CGRect oldframe;

@implementation

SJAvatarBrowser

+(void)showImage:(UIImageView *)avatarImageView{

    UIImage *image=avatarImageView.image;

    UIWindow *window=[UIApplication sharedApplication].keyWindow;

    UIView *backgroundView=[[UIView alloc]initWithFrame:CGRectMake(0,
0,
    [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height)];

    oldframe=[avatarImageView convertRect:avatarImageView.bounds toView:window];

    backgroundView.backgroundColor=[UIColor blackColor];

    backgroundView.alpha=0;
    UIImageView *imageView=[[UIImageView alloc]initWithFrame:oldframe];

    imageView.image=image;

    imageView.tag=1;

    [backgroundView addSubview:imageView];

    [window addSubview:backgroundView];

     

    UITapGestureRecognizer *tap=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(hideImage:)];

    [backgroundView addGestureRecognizer: tap];

     

    [UIView animateWithDuration:0.3 animations:^{

    imageView.frame=CGRectMake(0,([UIScreen
 mainScreen].bounds.size.height-image.size.height*[UIScreen mainScreen].bounds.size.width/image.size.width)/2,
 [UIScreen mainScreen].bounds.size.width, image.size.height*[UIScreen mainScreen].bounds.size.width/image.size.width);

     backgroundView.alpha=1;

    } completion:^(BOOL finished) {

         

    }];

}


+(void)hideImage:(UITapGestureRecognizer*)tap{

    UIView *backgroundView=tap.view;

    UIImageView *imageView=(UIImageView*)[tap.view viewWithTag:1];

    [UIView animateWithDuration:0.3 animations:^{

        imageView.frame=oldframe;

        backgroundView.alpha=0;

} completion:^(BOOL finished) {

        [backgroundView removeFromSuperview];

   }];
}

@end 


引入此类之后,为自己需要放大的imageView添加tap手势

UITapGestureRecognizer
 *tap  = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(magnifyImage)];

 

[self.imageView addGestureRecognizer:tap];





-(void)magnifyImage

{

    NSLog(@"局部放大");

    [SJAvatarBrowser
 showImage:self.imageView];//调用方法

}


分享来源:
http://blog.csdn.net/ssrrxx11...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/16105.html

相关文章

  • 移动web开发问题和优化小结

    摘要:如何让我们所开发的手机页面能有更好的交互体验,就是这篇文章的主旨移动开发问题和优化小结。关于和鼠标事件的延迟说明,我引用叶小钗大神博客里面的一张图片,如下在手机上,的延迟将近。 1.前言 到目前为止,互联网行业里,手机越来越智能化,移动端占有的比例越来越高,尤其实在电商,新闻,广告,游戏领域。用户要求越来越高,网站功能越来越好,效果越来越炫酷,这就要求我们产品质量越来越高,web前端开...

    galaxy_robot 评论0 收藏0
  • 移动web开发问题和优化小结

    摘要:如何让我们所开发的手机页面能有更好的交互体验,就是这篇文章的主旨移动开发问题和优化小结。关于和鼠标事件的延迟说明,我引用叶小钗大神博客里面的一张图片,如下在手机上,的延迟将近。 1.前言 到目前为止,互联网行业里,手机越来越智能化,移动端占有的比例越来越高,尤其实在电商,新闻,广告,游戏领域。用户要求越来越高,网站功能越来越好,效果越来越炫酷,这就要求我们产品质量越来越高,web前端开...

    ysl_unh 评论0 收藏0
  • Agora iOS SDK-多人聊天

    摘要:瀑布流分屏显示最好的方式是采用瀑布流,这样比较方便的能够适应的变化。是向提供布局信息,也包括对于视图的布局信息。非常适合有视频聊天开发需求的开发者。 在上一篇Agora iOS SDK-开始聊天介绍了如何使用Agora SDK进行一对一的聊天,这篇主要介绍下如何使用Agora iOS进行多人聊天,需要实现的功能: 随着加入人数的变化,而显示不同的UI,主要是分屏 在多屏显示的情况下,...

    MSchumi 评论0 收藏0
  • HTML

    摘要:的新特性文件类型声明仅有一型。新的技术新的属性用于与用于用于。 1.html5的新特性 文件类型声明()仅有一型:。新的解析顺序:不再基于SGML。绘画 canvas;用于媒介回放的 video 和 audio 元素;语意化更好的内容元素:article、footer、header、nav、section;表单控件:calendar、date、time、email、url、search...

    liangdas 评论0 收藏0
  • HTML

    摘要:的新特性文件类型声明仅有一型。新的技术新的属性用于与用于用于。 1.html5的新特性 文件类型声明()仅有一型:。新的解析顺序:不再基于SGML。绘画 canvas;用于媒介回放的 video 和 audio 元素;语意化更好的内容元素:article、footer、header、nav、section;表单控件:calendar、date、time、email、url、search...

    luckyw 评论0 收藏0

发表评论

0条评论

Brenner

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<