生活随笔
收集整理的這篇文章主要介紹了
iOS_截屏并裁剪
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
截圖使用場景:
iOS 7中的代碼代段
// 使用上下文截圖,并使用指定的區域裁剪,模板代碼
- (void)screenShot
{// 將要被截圖的view,即窗體的根控制器的view(必須不含狀態欄,默認ios7中控制器是包括了狀態欄的)BeyondViewController *beyondVC = self.view.window.rootViewController;// 背景圖片 總的大小CGSize size = beyondVC.view.frame.size;// 開啟上下文,使用參數之后,截出來的是原圖(YES 0.0 質量高)UIGraphicsBeginImageContextWithOptions(size, YES, 0.0);// 裁剪的關鍵代碼,要裁剪的矩形范圍CGRect rect = CGRectMake(0, -20, size.width, size.height + 20 );//注:iOS7以后renderInContext:由drawViewHierarchyInRect:afterScreenUpdates:替代[beyondVC.view drawViewHierarchyInRect:rect afterScreenUpdates:NO];// 從上下文中,取出UIImageUIImage *snapshot = UIGraphicsGetImageFromCurrentImageContext();// 加入截取好的圖片到圖片數組[_cutImages addObject:snapshot];// 千萬記得,結束上下文(移除棧頂上下文)UIGraphicsEndImageContext();}
iOS 6中的代碼片段
// 使用上下文截圖,模板代碼
- (void)screenShot3
{// 將要被截圖的view,窗體的根控制器的view(iOS6,默認控制器不含狀態欄)BeyondViewController *beyondVC = self.view.window.rootViewController;UIView *cutView = beyondVC.view;// 開啟上下文,使用參數之后,截出來的是原圖(YES 0.0 質量高)UIGraphicsBeginImageContextWithOptions(cutView.frame.size, YES, 0.0);// 將cutView的圖層渲染到上下文中[cutView.layer renderInContext:UIGraphicsGetCurrentContext()];// 取出UIImageUIImage *image = UIGraphicsGetImageFromCurrentImageContext();// 加入截取好的圖片到圖片數組[_cutImages addObject:image];// 千萬記得,結束上下文UIGraphicsEndImageContext();
}
轉載于:https://www.cnblogs.com/wzjhoutai/p/6898824.html
總結
以上是生活随笔為你收集整理的iOS_截屏并裁剪的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。