美文网首页
ios view转image

ios view转image

作者: 单身21年的小琛琛 | 来源:发表于2016-10-31 11:36 被阅读0次

    关于view转image其实挺简单的

    //将view转换成image,
    - (UIImage *)setImageWithView:(UIView *)view{
        UIGraphicsBeginImageContextWithOptions(view.frame.size, YES, 0.0);  //图形上下文设置
        UIGraphicsBeginImageContext(view.frame.size); //开启位图
        [view drawViewHierarchyInRect:view.frame afterScreenUpdates:YES];//在这里将view重写进上下文中
        UIImage *image = UIGraphicsGetImageFromCurrentImageContext();//赋值
        UIGraphicsEndImageContext();//结束
        return image;
    }
    

    可能很多人觉得view转image有什么用啊

    0.gif

    我在写倒计时的动画,想做一个中间翻叠的动画,看了很多代码,发现了
    view在翻转的时候,只能根据一个点的位置进行翻转,这样就不能做出中间翻叠的效果,所有就只有把一个view变成2张image才能进行下去,下面如何写代码有写,自己看吧:

    //将image分成2份
    -(NSArray *)setImageArrWithImage:(UIImage *)image{
        //创建2个位图
        CGImageRef newImageRef1 = CGImageCreateWithImageInRect(image.CGImage, CGRectMake(0, 0, image.size.width, image.size.height/2.0));
        CGImageRef newImageRef2 = CGImageCreateWithImageInRect(image.CGImage, CGRectMake(0, image.size.height/2.0,image.size.width,image.size.height));
        
        UIImage *image1 = [UIImage imageWithCGImage:newImageRef1];
        UIImage *image2 = [UIImage imageWithCGImage:newImageRef2];
        
        CGImageRelease(newImageRef1);
        CGImageRelease(newImageRef2);
        return @[image1,image2];
    }
    

    那如何进行翻转呢,那就更简单了

    [UIView animateWithDuration:2 animations:^{
            CATransform3D transform = CATransform3DIdentity;
            transform.m34 = -10 /1000;
            CGFloat angle = - 100 / 360.0 * 2 * M_PI;;
            view1.layer.transform = CATransform3DRotate(transform, angle,   1, 0, 0);
        }];
    

    写的时候大家注意一下,我这里只翻转了view1,view2跟view1合起来才是一个完整的view

    在翻转的时候默认是根据view1的中心点来的这点就比较恶心了
    这时候 我们要重设view1的中心点,layer.anchorPoint 就是这恶心的属性

    开心.png

    当你设置之后如果发现视图的位置不对了,你要重设frame的位置,至于为什么 我也不知道

    相关文章

      网友评论

          本文标题:ios view转image

          本文链接:https://www.haomeiwen.com/subject/vrxputtx.html