iOS中實現(xiàn)imageView任意角度旋轉(zhuǎn)的方法
前言
在實際的開發(fā)中我們可能會遇到這種情況: 需要對圖片進行一定角度的旋轉(zhuǎn)。對于這種需要,我們可能會用UIView的transform進行旋轉(zhuǎn),但是這樣做其實只是對承載imageView的view進行了一定角度的旋轉(zhuǎn),而imageView并沒有旋轉(zhuǎn)。所有這樣的做法并不好。
如果需要實現(xiàn)對imageView實現(xiàn)一定角度的旋轉(zhuǎn),具體步驟是:
1.將image轉(zhuǎn)成context。
2.對context進行一定角度的旋轉(zhuǎn)。
3.將旋轉(zhuǎn)后的context 轉(zhuǎn)化成image。
經(jīng)過這三個步驟,我們就能夠?qū)崿F(xiàn)將圖片真正的做到旋轉(zhuǎn)。
好了,直接上代碼:
#import"UIImage+RotateImageTool.h" #import<QuartzCore/QuartzCore.h> #import<Accelerate/Accelerate.h> @implementationUIImage (RotateImageTool) -(UIImage*)rotateImageWithDegree:(CGFloat)degree{ //將image轉(zhuǎn)化成context //獲取圖片像素的寬和高 size_t width =self.size.width*self.scale; size_t height =self.size.height*self.scale; //顏色通道為8因為0-255經(jīng)過了8個顏色通道的變化 //每一行圖片的字節(jié)數(shù)因為我們采用的是ARGB/RGBA所以字節(jié)數(shù)為width * 4 size_t bytesPerRow =width *4; //圖片的透明度通道 CGImageAlphaInfo info =kCGImageAlphaPremultipliedFirst; //配置context的參數(shù): CGContextRef context =CGBitmapContextCreate(nil, width, height,8, bytesPerRow,CGColorSpaceCreateDeviceRGB(),kCGBitmapByteOrderDefault|info); if(!context) { return nil; } //將圖片渲染到圖形上下文中 CGContextDrawImage(context,CGRectMake(0,0, width, height),self.CGImage); uint8_t* data = (uint8_t*)CGBitmapContextGetData(context); //旋轉(zhuǎn)欠的數(shù)據(jù) vImage_Buffer src = { data,height,width,bytesPerRow}; //旋轉(zhuǎn)后的數(shù)據(jù) vImage_Buffer dest= { data,height,width,bytesPerRow}; //背景顏色 Pixel_8888 backColor = {0,0,0,0}; //填充顏色 vImage_Flags flags = kvImageBackgroundColorFill; //旋轉(zhuǎn)context vImageRotate_ARGB8888(&src, &dest,nil, degree *M_PI/180.f, backColor, flags); //將conetxt轉(zhuǎn)換成image CGImageRef imageRef =CGBitmapContextCreateImage(context); UIImage* rotateImage =[UIImageimageWithCGImage:imageRefscale:self.scaleorientation:self.imageOrientation]; returnrotateImage; }
代碼中有詳細的注釋,在這里我就不過多的解釋了。感興趣的可以到github上面下載哦。
下載地址:github.com/15221532825/ImageTool (本地下載)
附:iOS ImageView的Image自適應縮放顯示全套處理方法
// retina屏幕圖片顯示問題 [_detailImageView setContentScaleFactor:[[UIScreen mainScreen] scale]]; // 不規(guī)則圖片顯示 _detailImageView.contentMode = UIViewContentModeScaleAspectFill; _detailImageView.autoresizingMask = UIViewAutoresizingFlexibleHeight; // 圖片大于或小于顯示區(qū)域 _detailImageView.clipsToBounds = YES;
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
使用SDLocalize實現(xiàn)高效完成iOS多語言工作
這篇文章主要介紹了使用SDLocalize實現(xiàn)高效完成iOS多語言工作的相關(guān)資料,需要的朋友可以參考下2022-10-10支持Xcode10和適配iPhone XS Max、iPhone XR的方法
這篇文章主要介紹了支持Xcode10和適配iPhone XS Max、iPhone XR的方法,文中通過示例代碼以及圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-10-102016 cocoapods的安裝和使用方法以及版本升級遇到的問題
CocoaPods是一個負責管理iOS項目中第三方開源庫的工具,通過CocoaPods,我們可以將第三方的依賴庫統(tǒng)一管理起來,配置和更新只需要通過簡單的幾行命令即可完成,需要的朋友可以參考下2016-09-09iOS Webview自適應實際內(nèi)容高度的4種方法詳解
這篇文章主要介紹了iOS Webview自適應實際內(nèi)容高度的4種方法詳解,本文介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下2016-09-09iOS開發(fā)中Subview的事件響應以及獲取subview的方法
這篇文章主要介紹了iOS開發(fā)中Subview的事件響應以及獲取subview的方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-09-09