iOS实现微信分享多张图片功能

 更新时间:2019年01月23日 16:50:27   作者:ZFJ_张福杰  
这篇文章主要为大家详细介绍了iOS实现微信分享多张图片功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

前言

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

UIActivityViewController

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

主要代码

OC代码

UIImage *imageToShare = [UIImage imageNamed:@"99687078.jpg"];
 UIImage *imageToShare1 = [UIImage imageNamed:@"2222.jpg"];
 NSArray *activityItems = @[imageToShare,imageToShare1];
 UIActivityViewController *activityVC = [[UIActivityViewController alloc]initWithActivityItems:activityItems applicationActivities:nil];
 [self presentViewController:activityVC animated:TRUE completion:nil];

swift代码

let imageToShare1 = UIImage.init(named: "99687078.jpg")
 let imageToShare2 = UIImage.init(named: "2222.jpg")
 let activityItems = [imageToShare1,imageToShare2]
 let activityVC = UIActivityViewController.init(activityItems: activityItems, applicationActivities: nil)
 self.present(activityVC, animated: true, completion: nil)

运行截图

注意

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

代码

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

#import "WeChatJPEGImager.h"
 
#define KCompressibilityFactor 1280.00
 
@implementation WeChatJPEGImager
 
#pragma mark - 压缩一张图片 最大宽高1280 类似于微信算法
- (UIImage *)getJPEGImagerImg:(UIImage *)image{
 CGFloat oldImg_WID = image.size.width;
 CGFloat oldImg_HEI = image.size.height;
 //CGFloat aspectRatio = oldImg_WID/oldImg_HEI;//宽高比
 if(oldImg_WID > KCompressibilityFactor || oldImg_HEI > KCompressibilityFactor){
 //超过设置的最大宽度 先判断那个边最长
 if(oldImg_WID > oldImg_HEI){
  //宽度大于高度
  oldImg_HEI = (KCompressibilityFactor * oldImg_HEI)/oldImg_WID;
  oldImg_WID = KCompressibilityFactor;
 }else{
  oldImg_WID = (KCompressibilityFactor * oldImg_WID)/oldImg_HEI;
  oldImg_HEI = KCompressibilityFactor;
 }
 }
 UIImage *newImg = [self imageWithImage:image scaledToSize:CGSizeMake(oldImg_WID, oldImg_HEI)];
 NSData *dJpeg = nil;
 if (UIImagePNGRepresentation(newImg)==nil) {
 dJpeg = UIImageJPEGRepresentation(newImg, 0.5);
 }else{
 dJpeg = UIImagePNGRepresentation(newImg);
 }
 return [UIImage imageWithData:dJpeg];
}
#pragma mark - 压缩多张图片 最大宽高1280 类似于微信算法
- (NSArray *)getJPEGImagerImgArr:(NSArray *)imageArr{
 NSMutableArray *newImgArr = [NSMutableArray new];
 for (int i = 0; i<imageArr.count; i++) {
 UIImage *newImg = [self getJPEGImagerImg:imageArr[i]];
 [newImgArr addObject:newImg];
 }
 return newImgArr;
}
#pragma mark - 压缩一张图片 自定义最大宽高
- (UIImage *)getJPEGImagerImg:(UIImage *)image compressibilityFactor:(CGFloat)compressibilityFactor{
 CGFloat oldImg_WID = image.size.width;
 CGFloat oldImg_HEI = image.size.height;
 //CGFloat aspectRatio = oldImg_WID/oldImg_HEI;//宽高比
 if(oldImg_WID > compressibilityFactor || oldImg_HEI > compressibilityFactor){
 //超过设置的最大宽度 先判断那个边最长
 if(oldImg_WID > oldImg_HEI){
  //宽度大于高度
  oldImg_HEI = (compressibilityFactor * oldImg_HEI)/oldImg_WID;
  oldImg_WID = compressibilityFactor;
 }else{
  oldImg_WID = (compressibilityFactor * oldImg_WID)/oldImg_HEI;
  oldImg_HEI = compressibilityFactor;
 }
 }
 UIImage *newImg = [self imageWithImage:image scaledToSize:CGSizeMake(oldImg_WID, oldImg_HEI)];
 NSData *dJpeg = nil;
 if (UIImagePNGRepresentation(newImg)==nil) {
 dJpeg = UIImageJPEGRepresentation(newImg, 0.5);
 }else{
 dJpeg = UIImagePNGRepresentation(newImg);
 }
 return [UIImage imageWithData:dJpeg];
}
#pragma mark - 压缩多张图片 自定义最大宽高
- (NSArray *)getJPEGImagerImgArr:(NSArray *)imageArr compressibilityFactor:(CGFloat)compressibilityFactor{
 NSMutableArray *newImgArr = [NSMutableArray new];
 for (int i = 0; i<imageArr.count; i++) {
 UIImage *newImg = [self getJPEGImagerImg:imageArr[i] compressibilityFactor:compressibilityFactor];
 [newImgArr addObject:newImg];
 }
 return newImgArr;
}
#pragma mark - 根据宽高压缩图片
- (UIImage *)imageWithImage:(UIImage *)image scaledToSize:(CGSize)newSize{
 UIGraphicsBeginImageContext(newSize);
 [image drawInRect:CGRectMake(0,0,newSize.width,newSize.height)];
 UIImage* newImage = UIGraphicsGetImageFromCurrentImageContext();
 UIGraphicsEndImageContext();
 return newImage;
}

Demo下载地址:iOS实现微信分享多张图片

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 分析IOS RunLoop的事件循环机制

    分析IOS RunLoop的事件循环机制

    RunLoop是与线程相关的基础架构中的一部分,它是一个处理事件的循环(线程进入这个循环,运行事件处理程序来响应传入的事件),RunLoop的目的是当有事件需要处理时,线程是活跃的、忙碌的,当没有事件后,线程进入休眠。
    2021-06-06
  • 浅析iOS应用开发中线程间的通信与线程安全问题

    浅析iOS应用开发中线程间的通信与线程安全问题

    这篇文章主要介绍了浅析iOS应用开发中线程间的通信与线程安全问题,谈到了包括互斥锁的使用等设计要点,需要的朋友可以参考下
    2015-11-11
  • iOS逆向工程使用LLDB的USB连接调试第三方App

    iOS逆向工程使用LLDB的USB连接调试第三方App

    这篇文章主要介绍了iOS逆向工程使用LLDB的USB连接调试第三方App,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • iOS通过代理逆向传值的方式详解

    iOS通过代理逆向传值的方式详解

    在iOS开发中传值是几乎每个App都会用到的,对于传统的顺向传值应该说是比较简单的,但是逆向传值往往会用到代理模式来实现,很多同学在这一块有迷惑,迷惑的不是怎么逆向传值,而是不理解代理模式,下面这篇文章就给大家分析一下iOS通过代理逆向传值的方式。
    2016-12-12
  • 深入学习iOS7自定义导航转场动画

    深入学习iOS7自定义导航转场动画

    这篇文章主要为大家详细介绍了iOS7自定义导航转场动画的相关资料,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • iOS实现应用悬浮窗效果

    iOS实现应用悬浮窗效果

    这篇文章主要为大家详细介绍了iOS实现应用悬浮窗效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • iOS自定义UICollectionViewLayout实现瀑布流布局

    iOS自定义UICollectionViewLayout实现瀑布流布局

    这篇文章主要为大家详细介绍了iOS自定义UICollectionViewLayout实现瀑布流布局,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • iOS UILabel根据内容自动调整高度

    iOS UILabel根据内容自动调整高度

    这篇文章主要为大家详细介绍了iOS UILabel根据内容自动调整高度,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • 解决iOS11图片下拉放大出现信号栏白条的bug问题

    解决iOS11图片下拉放大出现信号栏白条的bug问题

    这篇文章主要介绍了iOS11图片下拉放大出现信号栏白条的bug问题,需要的朋友参考下吧
    2017-09-09
  • iOS中图片的解压缩到渲染过程详解

    iOS中图片的解压缩到渲染过程详解

    这篇文章主要给大家介绍了关于iOS中图片的解压缩到渲染过程的相关资料,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03

最新评论