zoukankan      html  css  js  c++  java
  • iOS-微信分享多张图片(UIActivityViewController多图分享和多图分享失败)

    前言

    微信分享到朋友圈,可分享的类型有:文字类型、图片类型、音乐类型、视频类型和网页类型,但是我们在做图片分享的时候发现微信给的API只能分享一张图片,达不到一些APP的需求,而产品汪或者Boss想要分享多张图片,比如前段时间我做的一个APP,是电商类APP,想把商品的图片都分享到朋友圈,查看微信的API根本没有提供API,在这里我们只能用iOS系统自带的分享了。

    UIActivityViewController

    UIActivityViewController是在iOS 6开始支持的,同样是不能在Apple TV的开发中使用。而且UIActivityViewController是直接继承UIViewController的,这意味着我们需要自己来展示和解散视图。

    主要代码

    OC代码

    [objc] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. <span style="font-size:18px;">UIImage *imageToShare = [UIImage imageNamed:@"99687078.jpg"];  
    2.     UIImage *imageToShare1 = [UIImage imageNamed:@"2222.jpg"];  
    3.     NSArray *activityItems = @[imageToShare,imageToShare1];  
    4.     UIActivityViewController *activityVC = [[UIActivityViewController alloc]initWithActivityItems:activityItems applicationActivities:nil];  
    5.     [self presentViewController:activityVC animated:TRUE completion:nil];</span>  

    swift代码

    [objc] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. <span style="font-size:18px;">let imageToShare1 = UIImage.init(named: "99687078.jpg")  
    2.         let imageToShare2 = UIImage.init(named: "2222.jpg")  
    3.         let activityItems = [imageToShare1,imageToShare2]  
    4.         let activityVC = UIActivityViewController.init(activityItems: activityItems, applicationActivities: nil)  
    5.         self.present(activityVC, animated: true, completion: nil)</span>  

    运行截图

    注意

    我们在分享多张图片到朋友圈的时候会发现,我们在不做任何处理的时候,直接从手机相册调取多张图片分享的时候,分享失败。具体什么原因我研究了一下,发现分享的数据总共大小有限制;在这里举个例子,比如电梯,电梯限定的重量是固定的,所以不管你乘坐多少人,乘坐的人比较胖,那就乘坐的人比较少,如果乘坐的人比较瘦,那就可以多坐几个;所以UIActivityViewController分享多张图片到朋友圈的时候,我根据图片数量的多少,然后把图片压缩到指定宽高,比如一张图片,我就压缩成和微信压缩图片一样的大小1280,如果9张我就压缩成500;

    代码

    压缩图片的方法在下面粘出,其中compressibilityFactor为图片宽高的最大值;

    [objc] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. <span style="font-size:18px;">#import "WeChatJPEGImager.h"  
    2.   
    3. #define KCompressibilityFactor 1280.00  
    4.   
    5. @implementation WeChatJPEGImager  
    6.   
    7. #pragma mark - 压缩一张图片 最大宽高1280 类似于微信算法  
    8. - (UIImage *)getJPEGImagerImg:(UIImage *)image{  
    9.     CGFloat oldImg_WID = image.size.width;  
    10.     CGFloat oldImg_HEI = image.size.height;  
    11.     //CGFloat aspectRatio = oldImg_WID/oldImg_HEI;//宽高比  
    12.     if(oldImg_WID > KCompressibilityFactor || oldImg_HEI > KCompressibilityFactor){  
    13.         //超过设置的最大宽度 先判断那个边最长  
    14.         if(oldImg_WID > oldImg_HEI){  
    15.             //宽度大于高度  
    16.             oldImg_HEI = (KCompressibilityFactor * oldImg_HEI)/oldImg_WID;  
    17.             oldImg_WID = KCompressibilityFactor;  
    18.         }else{  
    19.             oldImg_WID = (KCompressibilityFactor * oldImg_WID)/oldImg_HEI;  
    20.             oldImg_HEI = KCompressibilityFactor;  
    21.         }  
    22.     }  
    23.     UIImage *newImg = [self imageWithImage:image scaledToSize:CGSizeMake(oldImg_WID, oldImg_HEI)];  
    24.     NSData *dJpeg = nil;  
    25.     if (UIImagePNGRepresentation(newImg)==nil) {  
    26.         dJpeg = UIImageJPEGRepresentation(newImg, 0.5);  
    27.     }else{  
    28.         dJpeg = UIImagePNGRepresentation(newImg);  
    29.     }  
    30.     return [UIImage imageWithData:dJpeg];  
    31. }  
    32. #pragma mark - 压缩多张图片 最大宽高1280 类似于微信算法  
    33. - (NSArray *)getJPEGImagerImgArr:(NSArray *)imageArr{  
    34.     NSMutableArray *newImgArr = [NSMutableArray new];  
    35.     for (int i = 0; i<imageArr.count; i++) {  
    36.         UIImage *newImg = [self getJPEGImagerImg:imageArr[i]];  
    37.         [newImgArr addObject:newImg];  
    38.     }  
    39.     return newImgArr;  
    40. }  
    41. #pragma mark - 压缩一张图片 自定义最大宽高  
    42. - (UIImage *)getJPEGImagerImg:(UIImage *)image compressibilityFactor:(CGFloat)compressibilityFactor{  
    43.     CGFloat oldImg_WID = image.size.width;  
    44.     CGFloat oldImg_HEI = image.size.height;  
    45.     //CGFloat aspectRatio = oldImg_WID/oldImg_HEI;//宽高比  
    46.     if(oldImg_WID > compressibilityFactor || oldImg_HEI > compressibilityFactor){  
    47.         //超过设置的最大宽度 先判断那个边最长  
    48.         if(oldImg_WID > oldImg_HEI){  
    49.             //宽度大于高度  
    50.             oldImg_HEI = (compressibilityFactor * oldImg_HEI)/oldImg_WID;  
    51.             oldImg_WID = compressibilityFactor;  
    52.         }else{  
    53.             oldImg_WID = (compressibilityFactor * oldImg_WID)/oldImg_HEI;  
    54.             oldImg_HEI = compressibilityFactor;  
    55.         }  
    56.     }  
    57.     UIImage *newImg = [self imageWithImage:image scaledToSize:CGSizeMake(oldImg_WID, oldImg_HEI)];  
    58.     NSData *dJpeg = nil;  
    59.     if (UIImagePNGRepresentation(newImg)==nil) {  
    60.         dJpeg = UIImageJPEGRepresentation(newImg, 0.5);  
    61.     }else{  
    62.         dJpeg = UIImagePNGRepresentation(newImg);  
    63.     }  
    64.     return [UIImage imageWithData:dJpeg];  
    65. }  
    66. #pragma mark - 压缩多张图片 自定义最大宽高  
    67. - (NSArray *)getJPEGImagerImgArr:(NSArray *)imageArr compressibilityFactor:(CGFloat)compressibilityFactor{  
    68.     NSMutableArray *newImgArr = [NSMutableArray new];  
    69.     for (int i = 0; i<imageArr.count; i++) {  
    70.         UIImage *newImg = [self getJPEGImagerImg:imageArr[i] compressibilityFactor:compressibilityFactor];  
    71.         [newImgArr addObject:newImg];  
    72.     }  
    73.     return newImgArr;  
    74. }  
    75. #pragma mark - 根据宽高压缩图片  
    76. - (UIImage *)imageWithImage:(UIImage *)image scaledToSize:(CGSize)newSize{  
    77.     UIGraphicsBeginImageContext(newSize);  
    78.     [image drawInRect:CGRectMake(0,0,newSize.width,newSize.height)];  
    79.     UIImage* newImage = UIGraphicsGetImageFromCurrentImageContext();  
    80.     UIGraphicsEndImageContext();  
    81.     return newImage;  
    82. }</span>  

    Demo下载地址

    http://download.csdn.net/detail/u014220518/9702030

    相关阅读

    iOS-微信朋友圈图片压缩算法

    http://blog.csdn.NET/u014220518/article/details/58136932

    来源:http://blog.csdn.net/u014220518/article/details/53465631

  • 相关阅读:
    css3线性渐变
    php的%s
    面向对象
    excel导入导出
    保存Excel
    保存word
    图片预览
    验证日期输入格式
    级联菜单
    中级前端知识点提要
  • 原文地址:https://www.cnblogs.com/jifeng/p/6813799.html
Copyright © 2011-2022 走看看