//
// 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;
}

第二种方法

.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中实现图片点击全屏预览的更多相关文章

  1. IOS 图片全屏预览

    如果你感觉累,那就对了那是因为你在走上坡路..这句话似乎有点道理的样子,时常提醒自己无论走到哪都不要忘记自己当初为什么出发.有时想想感觉有的东西可以记录一下,就把它记录下来吧,这次想写一下关于单张图片 ...

  2. JS 实现全屏预览 F11功能

    老是不通过,没办法,只能是重新发布了,反正我就是杠上了,大大小小写过很多前端特效,当然也经常在网上copy或者修改人家的代码,我觉得也挺好的,为什么?!因为我想这样,你能怎么办,打我?少废话,直接上代 ...

  3. 解决iOS中tabBarItem图片默认颜色的问题(指定代码渲染模式为以原样模式的方式显示出来)

    解决iOS中tabBarItem图片默认颜色的问题(指定代码渲染模式为以原样模式的方式显示出来) 解决办法:指定图片的渲染模式(imageWithRenderingMode为:UIImageRende ...

  4. 可嵌入图片视频jQuery全屏滑块

    分享一款可嵌入图片视频jQuery全屏滑块.这是一款可定制的滑块幻灯片代码,支持键盘箭头切换.效果图如下: 在线预览   源码下载 实现的代码. html代码:     <script type ...

  5. Android学习之Android 5.0分享动画实现微信点击全屏效果

    Android5.0过渡动画,请看 http://blog.csdn.net/qq_16131393/article/details/51112772 今天用分享动画实现微信点击全屏效果 本文源代码下 ...

  6. 图片无损放大软件PhotoZoom分屏预览功能 ,简直好用!

    PhotoZoom是一款智能放大图片软件,很多用户在初次使用PhotoZoom,发现图片所处的区域上方有四个不同方式的预览选项.因为很多初学者使用时不明白这四个按钮有什么作用,所以小编接下来讲解一下P ...

  7. 分离与继承的思想实现图片上传后的预览功能:ImageUploadView

    本文要介绍的是网页中常见的图片上传后直接在页面生成小图预览的实现思路,考虑到该功能有一定的适用性,于是把相关的逻辑封装成了一个ImageUploadView组件,实际使用效果可查看下一段的git效果图 ...

  8. web 图片上传实现本地预览

    在说上传之前先说说如何替换or美化浏览器自带的简陋上传按钮(自定义自己的上传按钮 如:img): 1.将自定义上传按钮上方添加 input file 框,实现input实现透明处理. 2.对自定义上传 ...

  9. java多图片上传--前端实现预览--图片压缩 、图片缩放,区域裁剪,水印,旋转,保持比例。

    java多图片上传--前端实现预览 前端代码: https://pan.baidu.com/s/1cqKbmjBSXOhFX4HR1XGkyQ 解压后: java后台: <!--文件上传--&g ...

随机推荐

  1. AngularJS(12)-BootStrap集成

    AngularJS 的首选样式表是 Bootstrap, Bootstrap 是目前最受欢迎的前端框架. <!DOCTYPE html> <html lang="en&qu ...

  2. (三)开始在OJ上添加签到功能

    在了解完OJ文件下的各个文件夹的主要作用后,我们开始往里面添加东西(其实只要知道各文件夹是干什么的后,添加东西也变得非常简单了) 一 在数据库中添加对应功能的字段. 我们这个学期才刚开数据库这门课,所 ...

  3. 给view 添加事件

    //绑定图片点击事件 UITapGestureRecognizer *g=[[UITapGestureRecognizeralloc]initWithTarget:selfaction:@select ...

  4. 虚拟局域网VLAN

    6.5.1配置路由器广域网端口的PPP封装 (1)配置路由器A: Router>enable Router#config Router_config#hostname Router-A Rout ...

  5. 1014. Waiting in Line (30)

    Suppose a bank has N windows open for service. There is a yellow line in front of the windows which ...

  6. redis 界面软件使用

    ubuntu 下下载安装包 sudo dpkg -i redis-desktop-manager_0.8.3-120_amd64.deb//安装 redis-desktop-manager //启动

  7. mysql中常用的公式及个人演示

    学生,院系表 -- phpMyAdmin SQL Dump-- version 4.1.9-- http://www.phpmyadmin.net---- Host: localhost-- Gene ...

  8. Qt html 界面混合编程

    Qt部分 项目文件.pro Qt += webenginewidgets webchannel 创建WebEngineView #include <QtWebEngineWidgets> ...

  9. 谈谈Android系统启动时的那点事儿

    Android系统完整的启动过程,从系统层次角度可分为Linux系统层.Android系统服务层.Zygote进程模型三个阶段:从开机到启动Home Launcher完成具体的任务细节可分为七个步骤, ...

  10. c++ 函数返回指针 及用法

    #include<string> #include<iostream> using namespace std; string fun1(int a) { string str ...