欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么在iOS中對圖片進行壓縮-創(chuàng)新互聯(lián)

今天就跟大家聊聊有關(guān)怎么在iOS中對圖片進行壓縮,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)是專業(yè)的武勝網(wǎng)站建設(shè)公司,武勝接單;提供成都做網(wǎng)站、網(wǎng)站制作,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行武勝網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

兩種壓縮圖片的方法:壓縮圖片質(zhì)量(Quality),壓縮圖片尺寸(Size)。

壓縮圖片質(zhì)量

NSData *data = UIImageJPEGRepresentation(image, compression);
UIImage *resultImage = [UIImage imageWithData:data];

通過 UIImage 和 NSData 的相互轉(zhuǎn)化,減小 JPEG 圖片的質(zhì)量來壓縮圖片。UIImageJPEGRepresentation:: 第二個參數(shù) compression 取值 0.0~1.0,值越小表示圖片質(zhì)量越低,圖片文件自然越小。

壓縮圖片尺寸

UIGraphicsBeginImageContext(size);
[image drawInRect:CGRectMake(0, 0, size.width, size.height)];
resultImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();

給定所需的圖片尺寸 size,resultImage 即為原圖 image 繪制為 size 大小的圖片。

壓縮圖片使圖片文件小于指定大小

如果對圖片清晰度要求不高,要求圖片的上傳、下載速度快的話,上傳圖片前需要壓縮圖片。壓縮到什么程度要看具體情況,但一般會設(shè)定一個圖片文件大值,例如 100 KB??梢杂蒙显V兩種方法來壓縮圖片。假設(shè)圖片轉(zhuǎn)化來的 NSData 對象為 data,通過data.length即可得到圖片的字節(jié)大小。

壓縮圖片質(zhì)量

比較容易想到的方法是,通過循環(huán)來逐漸減小圖片質(zhì)量,直到圖片稍小于指定大小(maxLength)。

+ (UIImage *)compressImageQuality:(UIImage *)image toByte:(NSInteger)maxLength {
 CGFloat compression = 1;
 NSData *data = UIImageJPEGRepresentation(image, compression);
 while (data.length > maxLength && compression > 0) {
  compression -= 0.02;
  data = UIImageJPEGRepresentation(image, compression); // When compression less than a value, this code dose not work
 }
 
 UIImage *resultImage = [UIImage imageWithData:data];
 return resultImage;
}

這樣循環(huán)次數(shù)多,效率低,耗時長。

可以通過二分法來優(yōu)化。

+ (UIImage *)compressImageQuality:(UIImage *)image toByte:(NSInteger)maxLength {
 CGFloat compression = 1;
 NSData *data = UIImageJPEGRepresentation(image, compression);
 if (data.length < maxLength) return image;
 CGFloat max = 1;
 CGFloat min = 0;
 for (int i = 0; i < 6; ++i) {
  compression = (max + min) / 2;
  data = UIImageJPEGRepresentation(image, compression);
  if (data.length < maxLength * 0.9) {
   min = compression;
  } else if (data.length > maxLength) {
   max = compression;
  } else {
   break;
  }
 }
 UIImage *resultImage = [UIImage imageWithData:data];
 return resultImage;
}

當(dāng)圖片大小小于 maxLength,大于 maxLength * 0.9 時,不再繼續(xù)壓縮。最多壓縮 6 次,1/(2^6) = 0.015625 < 0.02,也能達到每次循環(huán) compression 減小 0.02 的效果。這樣的壓縮次數(shù)比循環(huán)減小 compression 少,耗時短。需要注意的是,當(dāng)圖片質(zhì)量低于一定程度時,繼續(xù)壓縮沒有效果。也就是說,compression 繼續(xù)減小,data 也不再繼續(xù)減小。壓縮圖片質(zhì)量的優(yōu)點在于,盡可能保留圖片清晰度,圖片不會明顯模糊;缺點在于,不能保證圖片壓縮后小于指定大小。

壓縮圖片尺寸

與之前類似,比較容易想到的方法是,通過循環(huán)逐漸減小圖片尺寸,直到圖片稍小于指定大小(maxLength)。具體代碼省略。同樣的問題是循環(huán)次數(shù)多,效率低,耗時長。可以用二分法來提高效率,具體代碼省略。這里介紹另外一種方法,比二分法更好,壓縮次數(shù)少,而且可以使圖片壓縮后剛好小于指定大小(不只是 < maxLength, > maxLength * 0.9)。

+ (UIImage *)compressImageSize:(UIImage *)image toByte:(NSUInteger)maxLength {
 UIImage *resultImage = image;
 NSData *data = UIImageJPEGRepresentation(resultImage, 1);
 NSUInteger lastDataLength = 0;
 while (data.length > maxLength && data.length != lastDataLength) {
  lastDataLength = data.length;
  CGFloat ratio = (CGFloat)maxLength / data.length;
  CGSize size = CGSizeMake((NSUInteger)(resultImage.size.width * sqrtf(ratio)), (NSUInteger)(resultImage.size.height * sqrtf(ratio))); // Use NSUInteger to prevent white blank
  UIGraphicsBeginImageContext(size);
  // Use image to draw (drawInRect:), image is larger but more compression time
  // Use result image to draw, image is smaller but less compression time
  [resultImage drawInRect:CGRectMake(0, 0, size.width, size.height)];
  resultImage = UIGraphicsGetImageFromCurrentImageContext();
  UIGraphicsEndImageContext();
  data = UIImageJPEGRepresentation(resultImage, 1);
 }
 return resultImage;
}

[resultImage drawInRect:CGRectMake(0, 0, size.width, size.height)];是用新圖 resultImage 繪制,也可以用原圖 image 來繪制。用原圖繪制,壓縮后圖片更接近指定大小,但是壓縮次數(shù)較多,耗時較長。一張大小為 6064 KB 的圖片,壓縮圖片尺寸,原圖繪制與新圖繪制結(jié)果如下

指定大小(KB)原圖繪制壓縮后大小(KB)原圖繪制壓縮次數(shù)新圖繪制壓縮后大小(KB)新圖繪制壓縮次數(shù)
50049864983
30029942963
100995983
50496483

兩種繪制方法壓縮后大小很接近,與指定大小也很接近,但原圖繪制壓縮次數(shù)可達到新圖繪制壓縮次數(shù)的兩倍。建議使用新圖繪制,減少壓縮次數(shù)。壓縮后圖片明顯比壓縮質(zhì)量模糊。

需要注意的是繪制尺寸的代碼CGSize size = CGSizeMake((NSUInteger)(resultImage.size.width * sqrtf(ratio)), (NSUInteger)(resultImage.size.height * sqrtf(ratio)));,每次繪制的尺寸 size,要把寬 width 和 高 height 轉(zhuǎn)換為整數(shù),防止繪制出的圖片有白邊。

壓縮圖片尺寸可以使圖片小于指定大小,但會使圖片明顯模糊(比壓縮圖片質(zhì)量模糊)。

兩種圖片壓縮方法結(jié)合

如果要保證圖片清晰度,建議選擇壓縮圖片質(zhì)量。如果要使圖片一定小于指定大小,壓縮圖片尺寸可以滿足。對于后一種需求,還可以先壓縮圖片質(zhì)量,如果已經(jīng)小于指定大小,就可得到清晰的圖片,否則再壓縮圖片尺寸。

+ (UIImage *)compressImage:(UIImage *)image toByte:(NSUInteger)maxLength {
 // Compress by quality
 CGFloat compression = 1;
 NSData *data = UIImageJPEGRepresentation(image, compression);
 if (data.length < maxLength) return image;
 
 CGFloat max = 1;
 CGFloat min = 0;
 for (int i = 0; i < 6; ++i) {
  compression = (max + min) / 2;
  data = UIImageJPEGRepresentation(image, compression);
  if (data.length < maxLength * 0.9) {
   min = compression;
  } else if (data.length > maxLength) {
   max = compression;
  } else {
   break;
  }
 }
 UIImage *resultImage = [UIImage imageWithData:data];
 if (data.length < maxLength) return resultImage;
 
 // Compress by size
 NSUInteger lastDataLength = 0;
 while (data.length > maxLength && data.length != lastDataLength) {
  lastDataLength = data.length;
  CGFloat ratio = (CGFloat)maxLength / data.length;
  CGSize size = CGSizeMake((NSUInteger)(resultImage.size.width * sqrtf(ratio)), (NSUInteger)(resultImage.size.height * sqrtf(ratio))); // Use NSUInteger to prevent white blank
  UIGraphicsBeginImageContext(size);
  [resultImage drawInRect:CGRectMake(0, 0, size.width, size.height)];
  resultImage = UIGraphicsGetImageFromCurrentImageContext();
  UIGraphicsEndImageContext();
  data = UIImageJPEGRepresentation(resultImage, compression);
 }
 
 return resultImage;
}

看完上述內(nèi)容,你們對怎么在iOS中對圖片進行壓縮有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝大家的支持。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站aaarwkj.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)頁標(biāo)題:怎么在iOS中對圖片進行壓縮-創(chuàng)新互聯(lián)
地址分享:http://aaarwkj.com/article44/cdpihe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、商城網(wǎng)站、全網(wǎng)營銷推廣、品牌網(wǎng)站建設(shè)外貿(mào)網(wǎng)站建設(shè)做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
在线观看一区二区三区国产视频| 91精品国产91久久综合桃花| 五月婷久久精品国产亚洲av| 五月婷婷丁香视频在线| 国产精品免费视频能看的| 欧美av在线免费观看| 久久免费欧美日韩亚洲| 日韩有码中文字幕av| 亚洲一区二区天堂av| 男人的天堂av东京热一区| 亚洲五月综合激情综合久久| 高颜值紧身牛仔裤国产精品| 亚洲美女国产精选999| 免费一区二区不卡去日本| 日本午夜一区二区在线观看| 粉嫩极品美女国产精品| 国产成人亚洲精品专区高清| 亚洲欧美日韩一区91| 日本岛国大片一区二区在线观看| 国产精品神马午夜福利| 久久综合婷婷亚洲色图| 欧美熟妇在线视频你懂的| 午夜视频在线观看91| 亚洲国产男同日韩小鲜肉| 亚洲精品一区国产精品av| 2020年最新国产三级网站| 亚洲国产第一av导航| 四季一区二区三区av| 国产熟女真实乱精品视频| 久久精品国产普通话对白| 日韩暴露一区二区三区| 欧美日韩一区二区午夜福利| 中文字幕亚洲精品99| 久久91超碰青草在哪里看| 久亚洲精品九九久久99| 乱码人妻精品一区二区三区| 在线观看91高清视频| 精品少妇人妻av免费久久久| 日本特黄高清免费大片| 国产欧美日韩一区二区三区不卡 | 国产精品一区波多野结衣|