• [转载]有关UIScrollView zoom的一点心得


    转自:http://thenewself.blog.163.com/blog/static/198501330201221862929331/

    实现UIScrollView的缩放,必须使maximumZoomScale(默认1.0)和minimumZoomScale(默认1.0)不同 ,并且需要在delegate中的viewForZoomingInScrollView: 方法中返回需要所放的view。实现以上即可进行缩放。

    要修改缩放过程中的一些行为,可以修该delegate中的scrollViewWillBeginZooming:withView:  和scrollViewDidZoom:(此方法为每次拖动时随时调用)和scrollViewDidEndZooming:withView:atScale:(此方法为每次放缩完毕时调用)的函数内容。
    注意:
    viewForZoomingInScrollView方法返回的view是scrollview确定contentsize的view。contentsize的大小与该view的frame.size相同;在放缩的同时scrollview会自动设定zoomscale属性的大小,与每次放缩结束的scrollViewDidEndZooming:withView:atScale 中的scale相同。每次放缩过程中,所放缩的view的bound不会改变而frame会改变(这同修改view的transform属性的效果相同)放缩会改变frame,改变view在父视图的位置,而不会改变bound大小。推测放缩也是通过affinetransform进行改变。所以对需要固定位置的view,需要在每次scrollViewDidZoom中修改view的位置,例如如下代码实现固定ImageView始终在整个content的居中位置:

    -(void)scrollViewDidZoom:(UIScrollView *)scrollView{

        CGFloat xcenter = scrollView.center.x , ycenter = scrollView.center.y;

    //目前contentsize的width是否大于原scrollview的contentsize,如果大于,设置imageview中心x点为contentsize的一半,以固定imageview在该contentsize中心。如果不大于说明图像的宽还没有超出屏幕范围,可继续让中心x点为屏幕中点,此种情况确保图像在屏幕中心。

        xcenter = scrollView.contentSize.width > scrollView.frame.size.width ?

                                                    scrollView.contentSize.width/2 : xcenter;

    //同上,此处修改y值

        ycenter = scrollView.contentSize.height > scrollView.frame.size.height ?

                                                    scrollView.contentSize.height/2 : ycenter;

        [[scrollView viewWithTag:imageview] setCenter:CGPointMake(xcenter, ycenter)];

    }


    设置scrollview的bouncesZoom属性可以确保view的放缩比例超出设置比例范围时自动进行反弹。


    使图片自适应屏幕大小,以确保图片在屏幕正中的方法:

        float x_scale = scrollView.frame.size.width/selectedImage.size.width;

        float y_scale = scrollView.frame.size.height/selectedImage.size.height;

        CGFloat scale = x_scale < y_scale ? x_scale : y_scale;

        imageView.transform = CGAffineTransformMakeScale(scale, scale);

  • 相关阅读:
    渐变
    阴影
    html+css
    background用法
    语言特点
    h5c3介绍
    js的组成
    第九章 查找文件或者命令
    第八章 查看文件内容命令
    第七章 文件管理之基础命令
  • 原文地址:https://www.cnblogs.com/cnsec/p/11515864.html
Copyright © 2020-2023  润新知