iOS-微信分享多张图片(UIActivityViewController多图分享和多图分享失败)
前言
微信分享到朋友圈,可分享的类型有:文字类型、图片类型、音乐类型、视频类型和网页类型,但是我们在做图片分享的时候发现微信给的API只能分享一张图片,达不到一些APP的需求,而产品汪或者Boss想要分享多张图片,比如前段时间我做的一个APP,是电商类APP,想把商品的图片都分享到朋友圈,查看微信的API根本没有提供API,在这里我们只能用iOS系统自带的分享了。
UIActivityViewController
UIActivityViewController是在iOS 6开始支持的,同样是不能在Apple TV的开发中使用。而且UIActivityViewController是直接继承UIViewController的,这意味着我们需要自己来展示和解散视图。
主要代码
OC代码
- <span style="font-size:18px;">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];</span>
swift代码
- <span style="font-size:18px;">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)</span>
运行截图
注意
我们在分享多张图片到朋友圈的时候会发现,我们在不做任何处理的时候,直接从手机相册调取多张图片分享的时候,分享失败。具体什么原因我研究了一下,发现分享的数据总共大小有限制;在这里举个例子,比如电梯,电梯限定的重量是固定的,所以不管你乘坐多少人,乘坐的人比较胖,那就乘坐的人比较少,如果乘坐的人比较瘦,那就可以多坐几个;所以UIActivityViewController分享多张图片到朋友圈的时候,我根据图片数量的多少,然后把图片压缩到指定宽高,比如一张图片,我就压缩成和微信压缩图片一样的大小1280,如果9张我就压缩成500;
代码
压缩图片的方法在下面粘出,其中compressibilityFactor为图片宽高的最大值;
- <span style="font-size:18px;">#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;
- }</span>
Demo下载地址
http://download.csdn.net/detail/u014220518/9702030
相关阅读
http://blog.csdn.NET/u014220518/article/details/58136932
来源:http://blog.csdn.net/u014220518/article/details/53465631
iOS-微信分享多张图片(UIActivityViewController多图分享和多图分享失败)的更多相关文章
- IOS微信分享功能简单实现
PS:此文以简单实现功能为主,不足之前还望指点,大神勿喷. 在此之前如何申请微信认证的Key就不说了,公司一般会有人搞 1.首先下载微信SDK:微信SDK下载地址(更多关于微信SDK信息文档请访问官方 ...
- APP分享多张图片到微信和朋友圈
产品需求: 微信分享多图至好友,朋友圈.由于微信禁用了分享9图至朋友圈功能,这里分享微信只是将图片保存至本地,具体让用户手动分享. 问题分析: 微信没有提供分享多图的SDK,因此我们实现调用系统自带的 ...
- android 实现微信分享多张图片的功能
昨天公司老大通知客户改需求了,原来的微信分享改成分享多张图片,然后屁颠屁颠跑到微信平台看了以后 心里千万只草泥马狂奔而过,微信平台没有提供分享多张的SDK有木有啊,我们只能自己调用系统自带的分享功能实 ...
- vue history模式 ios微信分享坑
vue history模式 ios微信分享坑 问题分析:因为苹果分享会是调取签名失败是因为:苹果在微信中浏览器机制和安卓不同,有IOS缓存问题,和IOS对单页面的优化问题,通俗点说安卓进行页面跳转分享 ...
- vue history模式 ios微信分享 踩过的坑
背景:教育项目,整体依赖于微信环境,涉及到微信分享.微信二次分享 问题:vue使用history模式在iso微信下分享设置出错(签名认证错误.分享设置失败) 问题发现路径 1.按照微信公众号官方文档设 ...
- iOS微信第三方登录实现
iOS微信第三方登录实现 一.接入微信第三方登录准备工作.移动应用微信登录是基于OAuth2.0协议标准构建的微信OAuth2.0授权登录系统.在进行微信OAuth2.0授权登录接入之前,在微信开 ...
- iOS启动图和开屏广告图,类似网易
iOS启动图和开屏广告图,类似网易 启动图是在iOS开发过程中必不可少的一个部分,很多app在启动图之后会有一张自定义的开屏广告图,点击该广告图可以跳转到广告图对应的页面.今天呢,和大家分享一下如何添 ...
- 第九篇 :微信公众平台开发实战Java版之如何实现自定义分享内容
第一部分:微信JS-SDK介绍 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统 ...
- IOS 微信
原文:http://blog.csdn.net/ysy441088327/article/details/8441608 按照常例,列一些网址先: 微信开放平台首页: http://open.weix ...
随机推荐
- 2016ICPC-大连 Convex (几何)
We have a special convex that all points have the same distance to origin point. As you know we can ...
- 什么是虚拟DOM?为啥虚拟DOM可以提升性能?
现在流行的框架无论是React还是vue,都采用的是虚拟DOM 采用虚拟DOM的好处是,当数据变化的时候,无需像Backbone那样整体重新渲染,而是局部刷新变化部分 所谓虚拟DOM,其实就说用Jav ...
- REST是什么?
REST -- REpresentational State Transfer 直接翻译:表现层状态转移. @Ivony 老师的一句话概括很精辟: 用URL定位资源,用HTTP动词(GET,POS ...
- 目录文件管理及vim
一.查看(七种看) cat tac nl more less ====================== head tail tail -f 看动态更新尾部的信息 ================= ...
- insserv: warning: script 'busybox-httpd' missing LSB tags and overrides
/********************************************************************************* * insserv: warnin ...
- c日志宏
仅供参考,不推荐 #ifdef _DEBUG #define LOGDEBUG(format, ...)\ {\ FILE *fp = fopen("nccli.log", &qu ...
- SEO : 建站注意
1.url格式.尽可能的短一些,实践证明,较短的url格式还是比较利于搜索引擎收录的. 2.网站前台要纯静态.虽然搜索引擎对静态页面和动态页面并没有本质上的差别对待,但是实践告诉我们静态页面对服务器的 ...
- 牛客HJ浇花。
我也不知道这是什么类型的题,算是简单模拟吧.但是有个方法很赞. 开两个数组,一个模拟花,一个记录不同浇花次数花的数量: 要找浇水的次数,那么记每次浇水的开头和结尾就行了,a—b;那么f[a]++;f[ ...
- powerdesigner基本使用
parent sonPK主键 FK外键 n ------> 1 alter table muniubox.cpa_accounting_book add constraint FK_Refere ...
- redux笔记 进阶
1 拆分UI组件和容器组件 import React from 'react' const AppUI = (props) =>{ return ( <div className=&quo ...