亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解IOS圖片壓縮處理

 更新時(shí)間:2016年07月28日 17:05:06   投稿:daisy  
在日常IOS開發(fā)中,感覺圖片尺寸太大,想壓縮成小一點(diǎn)像素的。那么該如何做呢?本文通過“壓縮”兩個(gè)概念及實(shí)例來告訴大家如何進(jìn)行圖片壓縮處理才是最好的。

前言

 1、確圖片的壓縮的概念:

“壓” 是指文件體積變小,但是像素?cái)?shù)不變,長(zhǎng)寬尺寸不變,那么質(zhì)量可能下降。

“縮” 是指文件的尺寸變小,也就是像素?cái)?shù)減少,而長(zhǎng)寬尺寸變小,文件體積同樣會(huì)減小。

 

 2、圖片壓的處理

對(duì)于“壓”的功能,我們可以使用UIImageJPEGRepresentationUIImagePNGRepresentation方法實(shí)現(xiàn),

如代碼:

//圖片壓
- (void)_imageCompression{
  UIImage *image = [UIImage imageNamed:@"HD"];
  //第一個(gè)參數(shù)是圖片對(duì)象,第二個(gè)參數(shù)是壓的系數(shù),其值范圍為0~1。
  NSData * imageData = UIImageJPEGRepresentation(image, 0.7);
  UIImage * newImage = [UIImage imageWithData:imageData];
}

2.1關(guān)于PNG和JPEG格式壓縮

UIImageJPEGRepresentation函數(shù)需要兩個(gè)參數(shù):圖片的引用和壓縮系數(shù)而UIImagePNGRepresentation只需要圖片引用作為參數(shù).

UIImagePNGRepresentation(UIImage *image)要比UIImageJPEGRepresentation(UIImage* image, 1.0)返回的圖片數(shù)據(jù)量大很多.

同樣的一張照片, 使用UIImagePNGRepresentation(image)返回的數(shù)據(jù)量大小為200K,而 UIImageJPEGRepresentation(image, 1.0)返回的數(shù)據(jù)量大小只為150K,比前者少了50K.

如果對(duì)圖片的清晰度要求不是極高,建議使用UIImageJPEGRepresentation,可以大幅度降低圖片數(shù)據(jù)量.比如,剛才拍攝的圖片,通過調(diào)用UIImageJPEGRepresentation(image, 1.0)讀取數(shù)據(jù)時(shí),返回的數(shù)據(jù)大小為140K,但更改壓縮系數(shù)為0.5再讀取數(shù)據(jù)時(shí),返回的數(shù)據(jù)大小只有11K,大大壓縮了圖片的數(shù)據(jù)量,而且清晰度并沒有相差多少,圖片的質(zhì)量并沒有明顯的降低。因此,在讀取圖片數(shù)據(jù)內(nèi)容時(shí),建議優(yōu)先使用UIImageJPEGRepresentation,并可根據(jù)自己的實(shí)際使用場(chǎng)景,設(shè)置壓縮系數(shù),進(jìn)一步降低圖片數(shù)據(jù)量大小。

提示:壓縮系數(shù)不宜太低,通常是0.3~0.7,過小則可能會(huì)出現(xiàn)黑邊等。

3、圖片“縮”處理

通過[image drawInRect:CGRectMake(0, 0, targetWidth, targetHeight)]可以進(jìn)行圖片“縮”的功能。

 

/**
 * 圖片壓縮到指定大小
 * @param targetSize 目標(biāo)圖片的大小
 * @param sourceImage 源圖片
 * @return 目標(biāo)圖片
 */
 - (UIImage*)imageByScalingAndCroppingForSize:(CGSize)targetSize withSourceImage:(UIImage *)sourceImage
{
UIImage *newImage = nil;
CGSize imageSize = sourceImage.size;
CGFloat width = imageSize.width;
CGFloat height = imageSize.height;
CGFloat targetWidth = targetSize.width;
CGFloat targetHeight = targetSize.height;
CGFloat scaleFactor = 0.0;
CGFloat scaledWidth = targetWidth;
CGFloat scaledHeight = targetHeight;
CGPoint thumbnailPoint = CGPointMake(0.0,0.0);
if (CGSizeEqualToSize(imageSize, targetSize) == NO)
{
  CGFloat widthFactor = targetWidth / width;
  CGFloat heightFactor = targetHeight / height;
  if (widthFactor > heightFactor)
    scaleFactor = widthFactor; // scale to fit height
  else
    scaleFactor = heightFactor; // scale to fit width
  scaledWidth= width * scaleFactor;
  scaledHeight = height * scaleFactor;
  // center the image
  if (widthFactor > heightFactor)
  {
    thumbnailPoint.y = (targetHeight - scaledHeight) * 0.5;
  }
  else if (widthFactor < heightFactor)
  {
    thumbnailPoint.x = (targetWidth - scaledWidth) * 0.5;
  }
}
UIGraphicsBeginImageContext(targetSize); // this will crop
CGRect thumbnailRect = CGRectZero;
thumbnailRect.origin = thumbnailPoint;
thumbnailRect.size.width= scaledWidth;
thumbnailRect.size.height = scaledHeight;

[sourceImage drawInRect:thumbnailRect];
newImage = UIGraphicsGetImageFromCurrentImageContext();
if(newImage == nil)
  NSLog(@"could not scale image");

//pop the context to get back to the default
UIGraphicsEndImageContext();

 return newImage;
}

這個(gè)UIImageJPEGRepresentation(image, 0.0),UIImagePNGRepresentation(image); 是1的功能。
這個(gè) [sourceImage drawInRect:CGRectMake(0,0,targetWidth, targetHeight)] 是2的功能。

總結(jié)

所以,這倆得結(jié)合使用來滿足需求,不然你一味的用1,導(dǎo)致,圖片模糊的不行,但是尺寸還是很大。
以上就是在IOS中壓縮圖片處理的詳細(xì)介紹及實(shí)例,希望對(duì)大家學(xué)習(xí)IOS開發(fā)有所幫助。

相關(guān)文章

  • IOS客戶端接入微信支付

    IOS客戶端接入微信支付

    對(duì)于一個(gè)ios的app,如果有一些虛擬的商品或者服務(wù)需要通過在線支付來收費(fèi)的話,一般有幾種主流的選擇。如果是通過APP調(diào)用支付平臺(tái)APP的思路的話,一個(gè)是調(diào)起支付寶客戶端,一個(gè)則是調(diào)起微信支付。本文給大家分享ios客戶端接入微信支付,需要的朋友可以參考下
    2015-09-09
  • 實(shí)例講解iOS音樂播放器DOUAudioStreamer用法

    實(shí)例講解iOS音樂播放器DOUAudioStreamer用法

    本篇文章給大家通過實(shí)例講解了iOS音樂播放器DOUAudioStreamer用法以及分享了實(shí)例代碼,一起學(xué)習(xí)參考下吧。
    2017-12-12
  • iOS開發(fā)中使app獲取本機(jī)通訊錄的實(shí)現(xiàn)代碼實(shí)例

    iOS開發(fā)中使app獲取本機(jī)通訊錄的實(shí)現(xiàn)代碼實(shí)例

    這篇文章主要介紹了iOS開發(fā)中使app獲取本機(jī)通訊錄的實(shí)現(xiàn)代碼實(shí)例,主要用到了AddressBook.framework和AddressBookUI.framework,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2016-01-01
  • iOS如何為圓角添加陰影效果示例代碼

    iOS如何為圓角添加陰影效果示例代碼

    最近一個(gè)項(xiàng)目中需要用到投影的效果,還要是圓角,通過查找相關(guān)的資料終于解決了,所以覺著有必要分享出來,下面這篇文章主要給大家介紹了關(guān)于iOS如何為圓角添加陰影效果的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-10-10
  • iOS實(shí)現(xiàn)簡(jiǎn)易抽屜效果、雙邊抽屜效果

    iOS實(shí)現(xiàn)簡(jiǎn)易抽屜效果、雙邊抽屜效果

    這篇文章主要為大家詳細(xì)介紹了兩款iOS抽屜效果,簡(jiǎn)易抽屜效果、以及雙邊抽屜效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-02-02
  • iOS中利用CAEmitterLayer實(shí)現(xiàn)粒子動(dòng)畫詳解

    iOS中利用CAEmitterLayer實(shí)現(xiàn)粒子動(dòng)畫詳解

    粒子效果應(yīng)該對(duì)現(xiàn)在很多人來說并不陌生,我們之前也分享了一些相關(guān)文章,下面這篇文章主要給大家介紹了關(guān)于iOS中利用CAEmitterLayer實(shí)現(xiàn)粒子動(dòng)畫的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友們下面來一起看看吧。
    2017-06-06
  • iOS中多網(wǎng)絡(luò)請(qǐng)求的線程安全詳解

    iOS中多網(wǎng)絡(luò)請(qǐng)求的線程安全詳解

    這篇文章主要給大家介紹了關(guān)于iOS中多網(wǎng)絡(luò)請(qǐng)求的線程安全的相關(guān)資料文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • iOS開發(fā)一個(gè)好看的ActionSheet

    iOS開發(fā)一個(gè)好看的ActionSheet

    本篇文章通過代碼分享和圖文形式教給大家用IOS寫一個(gè)好看的ActionSheet過程以及注意事項(xiàng),需要的朋友參考下吧。
    2018-01-01
  • iOS開發(fā)中文件的上傳和下載功能的基本實(shí)現(xiàn)

    iOS開發(fā)中文件的上傳和下載功能的基本實(shí)現(xiàn)

    這篇文章主要介紹了iOS開發(fā)中文件的上傳和下載功能的基本實(shí)現(xiàn),并且下載方面講到了大文件的多線程斷點(diǎn)下載,需要的朋友可以參考下
    2015-11-11
  • iOS實(shí)現(xiàn)全局懸浮按鈕

    iOS實(shí)現(xiàn)全局懸浮按鈕

    這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)全局懸浮按鈕,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論