欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS應(yīng)用開發(fā)中對UIImage進行截取和縮放的方法詳解

 更新時間:2016年04月23日 09:13:58   作者:李剛  
這篇文章主要介紹了iOS應(yīng)用開發(fā)中對UIImage進行截取和縮放的方法,分別講解了如何截取指定區(qū)域大小的UIImage以及縮放到指定大小和等比縮放的具體操作過程,需要的朋友可以參考下

截取UIImage指定大小區(qū)域
最近遇到這樣的需求:從服務(wù)器獲取到一張照片,只需要顯示他的左半部分,或者中間部分等等。也就是截取UIImage指定大小區(qū)域。

UIImage擴展:

我的解決方案是對UIImage進行擴展。通過CGImageRef和CGImage完成截取,調(diào)用的方法是:CGImageCreateWithImageInRect。擴展類叫UIImage+Crop,具體代碼如下:

UIImage+Crop.h

#import <UIKit/UIKit.h>

typedef NS_ENUM(NSInteger, XYCropImageStyle){
  XYCropImageStyleRight        =0,   // 右半部分
  XYCropImageStyleCenter       =1,   // 中間部分
  XYCropImageStyleLeft        =2,   // 左半部分
  XYCropImageStyleRightOneOfThird   =3,   // 右側(cè)三分之一部分
  XYCropImageStyleCenterOneOfThird  =4,   // 中間三分之一部分
  XYCropImageStyleLeftOneOfThird   =5,   // 左側(cè)三分之一部分
  XYCropImageStyleRightQuarter    =6,   // 右側(cè)四分之一部分
  XYCropImageStyleCenterRightQuarter =7,   // 中間右側(cè)四分之一部分
  XYCropImageStyleCenterLeftQuarter  =8,   // 中間左側(cè)四分之一部分
  XYCropImageStyleLeftQuarter     =9,   // 左側(cè)四分之一部分
};

@interface UIImage (Crop)
- (UIImage *)imageByCroppingWithStyle:(XYCropImageStyle)style;

@end
UIImage+Crop.m

#import "UIImage+Crop.h"

@implementation UIImage (Crop)

- (UIImage *)imageByCroppingWithStyle:(XYCropImageStyle)style
{
  CGRect rect;
  switch (style) {
    case XYCropImageStyleLeft:
      rect = CGRectMake(0, 0, self.size.width/2, self.size.height);
      break;
    case XYCropImageStyleCenter:
      rect = CGRectMake(self.size.width/4, 0, self.size.width/2, self.size.height);
      break;
    case XYCropImageStyleRight:
      rect = CGRectMake(self.size.width/2, 0, self.size.width/2, self.size.height);
      break;
    case XYCropImageStyleLeftOneOfThird:
      rect = CGRectMake(0, 0, self.size.width/3, self.size.height);
      break;
    case XYCropImageStyleCenterOneOfThird:
      rect = CGRectMake(self.size.width/3, 0, self.size.width/3, self.size.height);
      break;
    case XYCropImageStyleRightOneOfThird:
      rect = CGRectMake(self.size.width/3*2, 0, self.size.width/3, self.size.height);
      break;
    case XYCropImageStyleLeftQuarter:
      rect = CGRectMake(0, 0, self.size.width/4, self.size.height);
      break;
    case XYCropImageStyleCenterLeftQuarter:
      rect = CGRectMake(self.size.width/4, 0, self.size.width/4, self.size.height);
      break;
    case XYCropImageStyleCenterRightQuarter:
      rect = CGRectMake(self.size.width/4*2, 0, self.size.width/4, self.size.height);
      break;
    case XYCropImageStyleRightQuarter:
      rect = CGRectMake(self.size.width/4*3, 0, self.size.width/4, self.size.height);
      break;
    default:
      break;
  }
  CGImageRef imageRef = self.CGImage;
  CGImageRef imagePartRef = CGImageCreateWithImageInRect(imageRef, rect);
  UIImage *cropImage = [UIImage imageWithCGImage:imagePartRef];
  CGImageRelease(imagePartRef);
  return cropImage;
}

實際運用:

簡單測試一下,看看有沒有實現(xiàn)我們想要的效果。首先,先加載一個完整的UIImageView。這個應(yīng)該不難。代碼如下:

UIImageView *imgView = [[UIImageView alloc] init];
imgView.frame = CGRectMake((SCREEN.width - 226) / 2, 100, 226, 106);
UIImage *image = [UIImage imageNamed:@"ganggang"];
imgView.image = image;
[self.view addSubview:imgView];

運行一下:

201642391121594.png (640×1136)

要對UIImage進行裁剪,首先導入頭文件:

#import "UIImage+Crop.h"

在上面UIImage *image = [UIImage imageNamed:@"ganggang"];這段代碼之后加上下面這句:

image = [image imageByCroppingWithStyle:XYCropImageStyleLeft];

XYCropImageStyleLeft是截取照片的左半部分。效果如下:

201642391201105.png (640×1136)

截取成功,還可以截取其他區(qū)域的,只需要傳入不同的XYCropImageStyle即可實現(xiàn)。

UIImage等比縮放
前面講了截取UIImage指定大小區(qū)域,很方便的截取UIImage。今天要和大家分享的是UIImage的縮放。

兩種縮放:

  • 縮放到指定大小,也就是指定的size.
  • 等比縮放。

1.縮放到指定大小

- (UIImage*)imageCompressWithSimple:(UIImage*)image scaledToSize:(CGSize)size
{
  UIGraphicsBeginImageContext(size);
  [image drawInRect:CGRectMake(0,0,size.width,size.height)];
  UIImage* newImage = UIGraphicsGetImageFromCurrentImageContext();
  UIGraphicsEndImageContext();
  return newImage;
}

2.等比縮放

(1)通過縮放系數(shù):

- (UIImage*)imageCompressWithSimple:(UIImage*)image scale:(float)scale
{
  CGSize size = image.size;
  CGFloat width = size.width;
  CGFloat height = size.height;
  CGFloat scaledWidth = width * scale;
  CGFloat scaledHeight = height * scale;
  UIGraphicsBeginImageContext(size); // this will crop
  [image drawInRect:CGRectMake(0,0,scaledWidth,scaledHeight)];
  UIImage* newImage= UIGraphicsGetImageFromCurrentImageContext();
  UIGraphicsEndImageContext();
  return newImage;
}

scale是縮放系數(shù) 。

(2)通過計算得到縮放系數(shù)

- (UIImage*)imageByScalingAndCroppingForSize:(CGSize)targetSize
{

  UIImage *sourceImage = [UIImage imageNamed:@"test.jpg"];
  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;

}

相關(guān)文章

  • 在iOS中實現(xiàn)谷歌滅霸彩蛋的完整示例

    在iOS中實現(xiàn)谷歌滅霸彩蛋的完整示例

    這篇文章主要給大家介紹了關(guān)于如何在iOS中實現(xiàn)谷歌滅霸彩蛋的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05
  • iOS SwiftUI 顏色漸變填充效果的實現(xiàn)

    iOS SwiftUI 顏色漸變填充效果的實現(xiàn)

    這篇文章主要介紹了iOS SwiftUI 顏色漸變填充效果的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • 99%?iOS開發(fā)都不知道的KVO崩潰分析詳解

    99%?iOS開發(fā)都不知道的KVO崩潰分析詳解

    這篇文章主要為大家介紹了99%?iOS開發(fā)都不知道的KVO崩潰分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • UILabel顯示定時器文本跳動問題的解決方法

    UILabel顯示定時器文本跳動問題的解決方法

    這篇文章主要給大家介紹了關(guān)于UILabel顯示定時器文本跳動問題的解決方法,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • MacOS系統(tǒng)下Unity啟動黑屏的解決方法

    MacOS系統(tǒng)下Unity啟動黑屏的解決方法

    最近發(fā)現(xiàn)了一個問題,unity一打開就黑屏,通過查找相關(guān)的資料終于解決了,所以下面這篇文章主要給大家介紹了關(guān)于在MacOS系統(tǒng)下Unity啟動黑屏的解決方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2018-01-01
  • 淺談iOS開發(fā)中static變量的三大作用

    淺談iOS開發(fā)中static變量的三大作用

    下面小編就為大家?guī)硪黄獪\談iOS開發(fā)中static變量的三大作用。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • IOS圖片無限輪播器的實現(xiàn)原理

    IOS圖片無限輪播器的實現(xiàn)原理

    這篇文章主要介紹了IOS圖片無限輪播器的實現(xiàn)原理的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • 詳解iOS之關(guān)于double/float數(shù)據(jù)計算精度問題

    詳解iOS之關(guān)于double/float數(shù)據(jù)計算精度問題

    本篇文章主要介紹了iOS之關(guān)于double/float數(shù)據(jù)計算精度問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • iOS自定義日期選擇器

    iOS自定義日期選擇器

    這篇文章主要為大家詳細介紹了iOS自定義日期選擇器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • iOS UIImageView圖片自動拉伸功能

    iOS UIImageView圖片自動拉伸功能

    這篇文章主要介紹了iOS UIImageView圖片自動拉伸功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評論