在iOS開(kāi)發(fā)的Quartz2D使用中實(shí)現(xiàn)圖片剪切和截屏功能
圖片剪切
一、使用Quartz2D完成圖片剪切
1.把圖片顯示在自定義的view中
先把圖片繪制到view上。按照原始大小,把圖片繪制到一個(gè)點(diǎn)上。
代碼:
- (void)drawRect:(CGRect)rect
{
UIImage *image2=[UIImage imageNamed:@"me"];
[image2 drawAtPoint:CGPointMake(100, 100)];
}
顯示:
2.剪切圖片讓圖片圓形展示
思路:先畫一個(gè)圓,讓圖片顯示在圓的內(nèi)部,超出的部分不顯示。
注意:顯示的范圍只限于指定的剪切范圍,無(wú)論往上下文中繪制什么東西,只要超出了這個(gè)范圍的都不會(huì)顯示。
代碼:
- (void)drawRect:(CGRect)rect
{
//畫圓,以便以后指定可以顯示圖片的范圍
//獲取圖形上下文
CGContextRef ctx=UIGraphicsGetCurrentContext();
CGContextAddEllipseInRect(ctx, CGRectMake(100, 100, 50, 50));
//指定上下文中可以顯示內(nèi)容的范圍就是圓的范圍
CGContextClip(ctx);
UIImage *image2=[UIImage imageNamed:@"me"];
[image2 drawAtPoint:CGPointMake(100, 100)];
}
顯示:
3.剪切圖片讓圖片三角形展示
代碼:
- (void)drawRect:(CGRect)rect
{
//畫三角形,以便以后指定可以顯示圖片的范圍
//獲取圖形上下文
CGContextRef ctx=UIGraphicsGetCurrentContext();
// CGContextAddEllipseInRect(ctx, CGRectMake(100, 100, 50, 50));
CGContextMoveToPoint(ctx, 100, 100);
CGContextAddLineToPoint(ctx, 60, 150);
CGContextAddLineToPoint(ctx, 140, 150);
CGContextClosePath(ctx);
//注意:指定范圍(也就是指定剪切的方法一定要在繪制范圍之前進(jìn)行調(diào)用)
//指定上下文中可以顯示內(nèi)容的范圍就是圓的范圍
CGContextClip(ctx);
UIImage *image2=[UIImage imageNamed:@"me"];
[image2 drawAtPoint:CGPointMake(100, 100)];
}
顯示:
截屏
一、簡(jiǎn)單說(shuō)明
在程序開(kāi)發(fā)中,有時(shí)候需要截取屏幕上的某一塊內(nèi)容,比如捕魚達(dá)人游戲。如圖:
二、代碼示例
storyboard界面搭建
代碼:
//
// YYViewController.m
// 01-截屏
//
// Created by apple on 14-6-12.
// Copyright (c) 2014年 itcase. All rights reserved.
//
#import "YYViewController.h"
#import "MBProgressHUD+NJ.h"
@interface YYViewController ()
@property (weak, nonatomic) IBOutlet UIView *contentView;
- (IBAction)BtnClick:(UIButton *)sender;
@end
@implementation YYViewController
- (void)viewDidLoad
{
[super viewDidLoad];
}
- (IBAction)BtnClick:(UIButton *)sender {
//延遲兩秒保存
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
//獲取圖形上下文
// UIGraphicsBeginImageContext(self.view.frame.size);
UIGraphicsBeginImageContext(self.contentView.frame.size);
//將view繪制到圖形上下文中
// [self.view.layer renderInContext:UIGraphicsGetCurrentContext()];
[self.contentView.layer renderInContext:UIGraphicsGetCurrentContext()];
//將截屏保存到相冊(cè)
UIImage *newImage=UIGraphicsGetImageFromCurrentImageContext();
UIImageWriteToSavedPhotosAlbum(newImage,self, @selector(image:didFinishSavingWithError:contextInfo:), nil);
});
}
- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo
{
if (error) {
[MBProgressHUD showError:@"保存失敗,請(qǐng)檢查是否擁有相關(guān)的權(quán)限"];
}else
{
// [MBProgressHUD showMessage:@"保存成功!"];
[MBProgressHUD showSuccess:@"保存成功!"];
}
}
@end
把截取的圖片保存到手機(jī)的相冊(cè)中:
說(shuō)明:把整個(gè)屏幕畫到一張圖片里
1.創(chuàng)建一個(gè)bitmap的上下文
2.將屏幕繪制帶上下文中
3.從上下文中取出繪制好的圖片
4.保存圖片到相冊(cè)
補(bǔ)充:把圖片寫入到文件的代碼
//3.從上下文中取出繪制好的圖片
UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
NSData *data = UIImagePNGRepresentation(newImage);
NSString *path = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"abc.png"];
NSLog(@"%@", path);
[data writeToFile:path atomically:YES];
三、補(bǔ)充
保存成功和保存失敗之后應(yīng)該做些事情?
系統(tǒng)推薦的方法:
- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo
{
if (error) {
[MBProgressHUD showError:@"保存失敗,請(qǐng)檢查是否擁有相關(guān)的權(quán)限"];
}else
{
// [MBProgressHUD showMessage:@"保存成功!"];
[MBProgressHUD showSuccess:@"保存成功!"];
}
}
如果圖片成功保存的話,那么就提示保存成功。
如果保存失敗,那么提示失敗
提示:保存失敗常見(jiàn)有兩個(gè)原因:1是內(nèi)存不夠,2是手機(jī)內(nèi)部的權(quán)限不允許。
說(shuō)明:如果當(dāng)一個(gè)應(yīng)用程序想要訪問(wèn)通訊錄或相冊(cè),用戶已經(jīng)明確拒絕過(guò),那么以后再要訪問(wèn)的話會(huì)直接拒絕。這個(gè)時(shí)候,可以提示用戶去開(kāi)啟權(quán)限。
- iOS錄屏和截屏監(jiān)聽(tīng)的實(shí)現(xiàn)代碼
- IOS 開(kāi)發(fā)之ios視頻截屏的實(shí)現(xiàn)代碼
- iOS 對(duì)當(dāng)前webView進(jìn)行截屏的方法
- 利用Python為iOS10生成圖標(biāo)和截屏
- 教你用Python腳本快速為iOS10生成圖標(biāo)和截屏
- iOS使用WebView生成長(zhǎng)截圖的第3種解決方案
- iOS 對(duì)view進(jìn)行截圖的示例代碼
- 關(guān)于iOS截圖你應(yīng)該知道的那些事兒
- IOS實(shí)現(xiàn)手動(dòng)截圖并保存
- iOS捕捉截屏事件并展示截圖效果
相關(guān)文章
iOS開(kāi)發(fā)————詳解適配iOS10問(wèn)題
ios10已經(jīng)推出一段時(shí)間了,這篇文章主要介紹了iOS開(kāi)發(fā)————詳解適配iOS10,有興趣的可以了解一下。2016-12-12iOS APP實(shí)現(xiàn)微信H5支付示例總結(jié)
這篇文章主要介紹了iOS APP實(shí)現(xiàn)微信H5支付示例總結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02IOS UI學(xué)習(xí)教程之設(shè)置UITextField各種屬性
這篇文章主要為大家詳細(xì)介紹了IOS UI學(xué)習(xí)教程之設(shè)置UITextField各種屬性,感興趣的小伙伴們可以參考一下2016-03-03iOS開(kāi)發(fā)中用imageIO漸進(jìn)加載圖片及獲取exif的方法
這篇文章主要介紹了iOS開(kāi)發(fā)中中用imageIO漸進(jìn)加載圖片及獲取exif的方法,代碼演示為傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-09-09iOS中使用UItableviewcell實(shí)現(xiàn)團(tuán)購(gòu)和微博界面的示例
這篇文章主要介紹了iOS中使用UItableviewcell實(shí)現(xiàn)團(tuán)購(gòu)和微博界面的示例,開(kāi)發(fā)語(yǔ)言基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-01-01iOS開(kāi)發(fā)之手勢(shì)識(shí)別實(shí)例
本篇文章主要介紹了iOS開(kāi)發(fā)之手勢(shì)識(shí)別實(shí)例,具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11iOS自定義可展示、交互的scrollView滾動(dòng)條
這篇文章主要為大家詳細(xì)介紹了iOS自定義可展示、交互的scrollView滾動(dòng)條,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04剖析iOS開(kāi)發(fā)中Cocos2d-x的內(nèi)存管理相關(guān)操作
這篇文章主要介紹了剖析iOS開(kāi)發(fā)中Cocos2d-x的內(nèi)存管理相關(guān)操作,Cocos2d-x是開(kāi)發(fā)游戲的利器,需要的朋友可以參考下2015-10-10iOS多線程應(yīng)用開(kāi)發(fā)中使用NSOperation類的基本方法
這篇文章主要介紹了iOS多線程應(yīng)用開(kāi)發(fā)中使用NSOperation類的基本方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-11-11