IOS中实现图片点击全屏预览

 更新时间:2015年11月14日 08:59:16   投稿:hebedich  
IOS作为一款智能手机系统,在查看图片的时候,如果能够实现全屏,对用户来说有很好的视觉体验,其实实现起来非常的简单,下面我就结合一个简单的代码给大家来分享一下,,需要的朋友可以参考下

如果你感觉累,那就对了那是因为你在走上坡路。。这句话似乎有点道理的样子,时常提醒自己无论走到哪都不要忘记自己当初为什么出发。有时想想感觉有的东西可以记录一下,就把它记录下来吧,这次想写一下关于单张图片点击全屏预览的问题,网上查了一些大神写的有的功能确实很强大但自己暂时想要的只是简单的功能就好,还有些方法自己也没弄出想要的效果,最后写了一个比较简单的点击单张图片的全屏预览和双指捏合缩小放大,可能有时要对图片做一些处理,这里放大后只是显示同一张图片并未做处理,下面直接贴出代码

//
// ViewController.m
// XWZoomImageView
//
// Created by xiao on 15/11/13.
// Copyright © 2015年 xiao. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()<UIScrollViewDelegate>
@property (weak, nonatomic) IBOutlet UIImageView *picView;
@property (weak, nonatomic) UIScrollView *scrollView;
@property (weak, nonatomic) UIImageView *lastImageView;
@property (nonatomic, assign)CGRect originalFrame;
@property (nonatomic, assign)BOOL isDoubleTap;
@end

@implementation ViewController

- (void)viewDidLoad {
 [super viewDidLoad];
 
 self.picView.userInteractionEnabled = YES;
 //添加单击手势
 UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(showZoomImageView:)];

 [self.picView addGestureRecognizer:tap];
 
}

-(void)showZoomImageView:(UITapGestureRecognizer *)tap
{
 if (![(UIImageView *)tap.view image]) {
  return;
 }
 //scrollView作为背景
 UIScrollView *bgView = [[UIScrollView alloc] init];
 bgView.frame = [UIScreen mainScreen].bounds;
 bgView.backgroundColor = [UIColor blackColor];
 UITapGestureRecognizer *tapBg = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapBgView:)];
 [bgView addGestureRecognizer:tapBg];
 
 UIImageView *picView = (UIImageView *)tap.view;
 
 UIImageView *imageView = [[UIImageView alloc] init];
 imageView.image = picView.image;
 imageView.frame = [bgView convertRect:picView.frame fromView:self.view];
 [bgView addSubview:imageView];
 
 [[[UIApplication sharedApplication] keyWindow] addSubview:bgView];
 
 self.lastImageView = imageView;
 self.originalFrame = imageView.frame;
 self.scrollView = bgView;
 //最大放大比例
 self.scrollView.maximumZoomScale = 1.5;
 self.scrollView.delegate = self;
 
 [UIView animateWithDuration:0.5 animations:^{
  CGRect frame = imageView.frame;
  frame.size.width = bgView.frame.size.width;
  frame.size.height = frame.size.width * (imageView.image.size.height / imageView.image.size.width);
  frame.origin.x = 0;
  frame.origin.y = (bgView.frame.size.height - frame.size.height) * 0.5;
  imageView.frame = frame;
 }];
}

-(void)tapBgView:(UITapGestureRecognizer *)tapBgRecognizer
{
 self.scrollView.contentOffset = CGPointZero;
 [UIView animateWithDuration:0.5 animations:^{
  self.lastImageView.frame = self.originalFrame;
  tapBgRecognizer.view.backgroundColor = [UIColor clearColor];
 } completion:^(BOOL finished) {
  [tapBgRecognizer.view removeFromSuperview];
  self.scrollView = nil;
  self.lastImageView = nil;
 }];
}

//返回可缩放的视图
-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
{
 return self.lastImageView;
}

最后同样带上一张图片吧,大致是这样子

再给大家分享一则IOS中点击图片后放大的代码

.h文件-----------------------------------------------------------------
#import
@interface ZoomImage : NSObject
/**
 *@brief点击图片放大,再次点击缩小
 *
 *@param oldImageView 头像所在的imageView
 */
+(void)showImage:(UIImageView*)avatarImageView;
@end
.m文件-----------------------------------------------------------------
#import "ZoomImage.h"
static CGRect oldframe;
@implementation ZoomImage
+(void)showImage:(UIImageView*)avatarImageView
{
 UIImage *image =avatarImageView.image;
 // 获得根窗口
 UIWindow *window =[UIApplication sharedApplication].keyWindow;
 UIView *backgroundView =[[UIView alloc]initWithFrame:CGRectMake(0, 0, WIDTH, HEIGHT)];
 oldframe =[avatarImageView convertRect:avatarImageView.bounds toView:window];
 backgroundView.backgroundColor =[UIColor blackColor];
 backgroundView.alpha =0.5;
 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;
 }];
}
+(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];
 }];
}

相关文章

  • 零基础学习iOS直播之播放

    零基础学习iOS直播之播放

    对于直播来说,客户端主要做两件事情,推流和播放。本篇主要对播放进行详细介绍,需要的朋友一起来看下吧
    2016-12-12
  • iOS简单抽屉效果的实现方法

    iOS简单抽屉效果的实现方法

    这篇文章主要为大家详细介绍了iOS简单抽屉效果的实现方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • ios动态设置lbl文字标签的高度

    ios动态设置lbl文字标签的高度

    本文给大家分享的是ios动态设置lbl文字标签的高度宽度的方法,一共给大家汇总了3种方法,小伙伴们根据自己的项目需求自由选择。
    2015-05-05
  • iOS当多个网络请求完成后执行下一步的方法详解

    iOS当多个网络请求完成后执行下一步的方法详解

    在多线程中,有时候我们会遇到一个界面同时有多个网络请求(比如a,b,c,d四个网络请求),在这四个个请求结束后,在请求到数据去做其他操作(UI更新等),下面这篇文章主要给大家介绍了关于iOS当多个网络请求完成后执行下一步的相关资料,需要的朋友可以参考下。
    2017-12-12
  • iOS实现支付宝蚂蚁森林随机按钮及抖动效果

    iOS实现支付宝蚂蚁森林随机按钮及抖动效果

    这篇文章主要为大家详细介绍了iOS实现支付宝蚂蚁森林随机按钮及抖动效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • iOS系统的底层通知框架库示例详解

    iOS系统的底层通知框架库示例详解

    这篇文章主要给大家介绍了关于iOS系统的底层通知框架库的相关资料,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • iOS应用开发中对UIImage进行截取和缩放的方法详解

    iOS应用开发中对UIImage进行截取和缩放的方法详解

    这篇文章主要介绍了iOS应用开发中对UIImage进行截取和缩放的方法,分别讲解了如何截取指定区域大小的UIImage以及缩放到指定大小和等比缩放的具体操作过程,需要的朋友可以参考下
    2016-04-04
  • iOS8调用相机报警告Snapshotting a view的解决方法

    iOS8调用相机报警告Snapshotting a view的解决方法

    这篇文章主要介绍了iOS8调用相机报警告Snapshotting a view……的解决方法 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • iOS 高效的分页加载实现示例

    iOS 高效的分页加载实现示例

    本篇文章主要介绍了iOS 高效的分页加载实现示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • iOS为UIView设置阴影效果

    iOS为UIView设置阴影效果

    现在很多的开发者们都会在开发的时候加阴影效果,所以这篇文章跟大家分享下iOS为UIView设置阴影效果的实现过程,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-09-09

最新评论