iOS在应用中截图,压缩,分享

       最近项目有一个需求,就是需要在应用内截一张图(超出屏幕的也要截到),然后把截出来的图分享出去,只分享图片。

       首先我要解决第一个问题,就是在应用内截图,我在网上找到了对应的解决方法,代码如下

//根据一个View生成一个image

- (UIImage*)screenshotForView:(UIView*)view {

    UIImage*image =nil;

    //判断View类型(一般不是滚动视图或者其子类的话内容不会超过一屏,当然如果超过了也可以通过修改frame来实现绘制)

    if ([view.class isSubclassOfClass:[UIScrollView class]]) {

        UIScrollView*scrView = (UIScrollView*)view;

        CGPointtempContentOffset = scrView.contentOffset;

        CGRecttempFrame = scrView.frame;

        scrView.contentOffset = CGPointZero;

        scrView.frame = CGRectMake(0, 0, scrView.contentSize.width, scrView.contentSize.height);

        image = [selfscreenshotForView:scrViewsize:scrView.frame.size];

        scrView.contentOffset= tempContentOffset;

        scrView.frame= tempFrame;

    }else{

        image = [selfscreenshotForView:viewsize:view.frame.size];

    }

    returnimage;

}

- (UIImage*)screenshotForView:(UIView*)view size:(CGSize)size {

    UIImage*image =nil;

    UIGraphicsBeginImageContextWithOptions(size, YES, [UIScreen mainScreen].scale);

    [view.layer renderInContext:UIGraphicsGetCurrentContext()];

    image =UIGraphicsGetImageFromCurrentImageContext();

    UIGraphicsEndImageContext();

    returnimage;

}

       调screenshotForView这个方法就可以获取到截来的图,我用的是MOB分享,分享类型SSDKContentTypeImage,只传图片,内容和标题都不传,分享到微信后,发现图片有6M多,需要压缩,然后通过下面的代码实现了压缩,压缩到了900多kb,但是分辨率也下降了,基本满足了需求

- (NSData*)resetSizeOfImageData:(UIImage*)sourceImage maxSize:(NSInteger)maxSize {

    //先判断当前质量是否满足要求,不满足再进行压缩

    __blockNSData*finallImageData =UIImageJPEGRepresentation(sourceImage,1.0);

    NSUIntegersizeOrigin  = finallImageData.length;

    NSUIntegersizeOriginKB = sizeOrigin /1000;

    if(sizeOriginKB <= maxSize) {

        returnfinallImageData;

    }

    //获取原图片宽高比

    CGFloatsourceImageAspectRatio = sourceImage.size.width/ sourceImage.size.height;

    //先调整分辨率

    CGSizedefaultSize =CGSizeMake(1024,1024/ sourceImageAspectRatio);

    UIImage* newImage = [selfnewSizeImage:defaultSizeimage:sourceImage];

    finallImageData    =UIImageJPEGRepresentation(newImage,1.0);

    //保存压缩系数

    NSMutableArray*compressionQualityArr = [NSMutableArrayarray];

    CGFloatavg  =1.0/250;

    CGFloatvalue = avg;

    for(inti =250; i >=1; i --) {

        value = i * avg;

        [compressionQualityArraddObject:@(value)];

    }

    /*

     调整大小

     说明:压缩系数数组compressionQualityArr是从大到小存储。

     */

    //思路:使用二分法搜索

    finallImageData = [selfhalfFuntion:compressionQualityArrimage:newImagesourceData:finallImageDatamaxSize:maxSize];

    //如果还是未能压缩到指定大小,则进行降分辨率

    while(finallImageData.length==0) {

        //每次降100分辨率

        CGFloatreduceWidth  =100.0;

        CGFloatreduceHeight =100.0/ sourceImageAspectRatio;

        if(defaultSize.width- reduceWidth <=0|| defaultSize.height- reduceHeight <=0) {

            break;

        }

        defaultSize =CGSizeMake(defaultSize.width- reduceWidth, defaultSize.height- reduceHeight);

        UIImage*image = [selfnewSizeImage:defaultSize

                                      image:[UIImageimageWithData:UIImageJPEGRepresentation(newImage, [[compressionQualityArrlastObject]floatValue])]];

        finallImageData = [selfhalfFuntion:compressionQualityArrimage:imagesourceData:UIImageJPEGRepresentation(image,1.0)maxSize:maxSize];

    }

    returnfinallImageData;

}

#pragma mark 调整图片分辨率/尺寸(等比例缩放)

- (UIImage*)newSizeImage:(CGSize)size image:(UIImage*)sourceImage {

    CGSizenewSize    =CGSizeMake(sourceImage.size.width, sourceImage.size.height);

    CGFloattempHeight = newSize.height/ size.height;

    CGFloattempWidth  = newSize.width/ size.width;

    if(tempWidth >1.0&& tempWidth > tempHeight) {

        newSize =CGSizeMake(sourceImage.size.width/ tempWidth, sourceImage.size.height/ tempWidth);

    }elseif(tempHeight >1.0&& tempWidth < tempHeight) {

        newSize =CGSizeMake(sourceImage.size.width/ tempHeight, sourceImage.size.height/ tempHeight);

    }

    UIGraphicsBeginImageContext(newSize);

    [sourceImagedrawInRect:CGRectMake(0,0, newSize.width, newSize.height)];

    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();

    UIGraphicsEndImageContext();

    returnnewImage;

}

#pragma mark 二分法

- (NSData*)halfFuntion:(NSArray*)arr image:(UIImage*)image sourceData:(NSData*)finallImageData maxSize:(NSInteger)maxSize {

    NSData*tempData = [NSDatadata];

    NSUIntegerstart =0;

    NSUIntegerend  = arr.count-1;

    NSUIntegerindex =0;

    NSUIntegerdifference =NSIntegerMax;

    while(start <= end) {

        index = start + (end - start) /2;

        finallImageData =UIImageJPEGRepresentation(image, [arr[index]floatValue]);

        NSUIntegersizeOrigin  = finallImageData.length;

        NSUIntegersizeOriginKB = sizeOrigin /1024;

        NSLog(@"当前降到的质量:%ld", (unsignedlong)sizeOriginKB);

        NSLog(@"\nstart:%zd\nend:%zd\nindex:%zd\n压缩系数:%lf", start, end, (unsignedlong)index, [arr[index] floatValue]);

        if(sizeOriginKB > maxSize) {

            start = index +1;

        }elseif(sizeOriginKB < maxSize) {

            if(maxSize - sizeOriginKB < difference) {

                difference = maxSize - sizeOriginKB;

                tempData  = finallImageData;

            }

            if(index <=0) {

                break;

            }

            end = index -1;

        }else{

            break;

        }

    }

    returntempData;

}

      这样我就实现了截图,压缩和分享

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容