【iOS】截屏燎悍、保存圖片到相冊(cè)

為了簡(jiǎn)便我們的開發(fā),通常會(huì)建立一個(gè)分類來(lái)處理我們的程序俄删,廢話不多說(shuō),直接上代碼:

#import <UIKit/UIKit.h>

typedef enum : NSUInteger {
    ImageRotationAngleZero = 0,//逆時(shí)針旋轉(zhuǎn)0°
    ImageRotationAngleM_PI_2 = 90,//逆時(shí)針旋轉(zhuǎn)90°
    ImageRotationAngleM_PI = 180,//逆時(shí)針旋轉(zhuǎn)180°
    ImageRotationAngle3M_PI_2 = 270//逆時(shí)針旋轉(zhuǎn)270°
} ImageRotationAngle;

@interface UIImage (SnipImage)

/**
 縮放并保存圖片到相冊(cè)

 @param imagePath 圖片地址
 */
+ (void)scaleAndSaveImage:(NSString *)imagePath;

/**
 截屏并保存
 */
+ (void)snipAndSaveImage;

@end

#import "UIImage+SnipImage.h"

@implementation UIImage (SnipImage)

//截屏并裁剪保存圖片
+ (void)snipAndSaveImage{
    CGSize imageSize = [[UIScreen mainScreen] bounds].size;
    
    UIGraphicsBeginImageContextWithOptions(imageSize, NO, 0);
    
    CGContextRef context = UIGraphicsGetCurrentContext();
    
    for (UIWindow *window in [[UIApplication sharedApplication] windows]) {
        if (![window respondsToSelector:@selector(screen)] || [window screen] == [UIScreen mainScreen]) {
            CGContextSaveGState(context);
            
            CGContextTranslateCTM(context, [window center].x, [window center].y);
            
            CGContextConcatCTM(context, [window transform]);
            
            CGContextTranslateCTM(context,
                                  -[window bounds].size.width * [[window layer] anchorPoint].x,
                                  -[window bounds].size.height * [[window layer] anchorPoint].y);
            
            [[window layer] renderInContext:context];
            
            CGContextRestoreGState(context);
        }
    }
    
    UIImage *snipImage = UIGraphicsGetImageFromCurrentImageContext();
    
    UIGraphicsEndImageContext();
    
    UIImage *saveImage = [self scaleImage:snipImage];
    UIImageWriteToSavedPhotosAlbum(saveImage,self, nil, nil);
}

//根據(jù)圖片地址裁剪并保存圖片
+ (void)scaleAndSaveImage:(NSString *)imagePath{
    UIImage *image = [UIImage imageWithContentsOfFile:imagePath];
    
    UIImage *saveImage = [self scaleImage:image];
    
    UIImageWriteToSavedPhotosAlbum(saveImage,self, nil, nil);
}

//裁剪圖片(此處容易有坑 *所有的尺寸應(yīng)該是分辨率)
+ (UIImage *)scaleImage:(UIImage *)image{
    CGFloat screenPX_width = [UIScreen mainScreen].bounds.size.width*2;
    CGFloat screenPX_height = [UIScreen mainScreen].bounds.size.height*2;
    
    //裁剪區(qū)域根據(jù)需求自己處理
    CGFloat scaleImage_offset = 10;
    CGFloat scaleImage_height = screenPX_height-30*2;
    CGFloat scaleImage_width = screenPX_width * 0.635;
    CGFloat scaleImage_x = (screenPX_width - scaleImage_width)/2+scaleImage_offset;
    CGFloat scaleImage_y = 30;
    
    UIImage *scaleImage = [UIImage imageWithCGImage:CGImageCreateWithImageInRect(image.CGImage, CGRectMake(scaleImage_x, scaleImage_y, scaleImage_width, scaleImage_height))];
    UIImage *saveImage = [self rotationImage:scaleImage angle:270];
    return saveImage;
}

//旋轉(zhuǎn)圖片到指定角度
+ (UIImage *)rotationImage:(UIImage *)image angle:(ImageRotationAngle)angle{
    long double rotate = 0.0;
    CGRect rect;
    float translateX = 0;
    float translateY = 0;
    float scaleX = 1.0;
    float scaleY = 1.0;
    
    switch (angle) {
        case ImageRotationAngleZero:
            return image;
            break;
        
        case ImageRotationAngleM_PI_2:
            rotate = M_PI_2;
            rect = CGRectMake(0, 0, image.size.height, image.size.width);
            translateX = 0;
            translateY = -rect.size.width;
            scaleY = rect.size.width/rect.size.height;
            scaleX = rect.size.height/rect.size.width;
            break;
            
        case ImageRotationAngleM_PI:
            rotate = M_PI;
            rect = CGRectMake(0, 0, image.size.width, image.size.height);
            translateX = -rect.size.width;
            translateY = -rect.size.height;
            break;
            
        case ImageRotationAngle3M_PI_2:
            rotate = 3 * M_PI_2;
            rect = CGRectMake(0, 0, image.size.height, image.size.width);
            translateX = -rect.size.height;
            translateY = 0;
            scaleY = rect.size.width/rect.size.height;
            scaleX = rect.size.height/rect.size.width;
            break;
            
        default:
            break;
    }
    
    UIGraphicsBeginImageContext(rect.size);
    CGContextRef context = UIGraphicsGetCurrentContext();
    CGContextTranslateCTM(context, 0.0, rect.size.height);
    CGContextScaleCTM(context, 1.0, -1.0);
    CGContextRotateCTM(context, rotate);
    CGContextTranslateCTM(context, translateX, translateY);
    
    CGContextScaleCTM(context, scaleX, scaleY);
    CGContextDrawImage(context, CGRectMake(0, 0, rect.size.width, rect.size.height), image.CGImage);
    
    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
    return newImage;
}

@end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末片任,一起剝皮案震驚了整個(gè)濱河市蚂踊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泼橘,老刑警劉巖炬灭,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件米愿,死亡現(xiàn)場(chǎng)離奇詭異鼻吮,居然都是意外死亡椎木,警方通過(guò)查閱死者的電腦和手機(jī)香椎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門馍惹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)玛界,“玉大人脚仔,你說(shuō)我怎么就攤上這事鲤脏。” “怎么了窥突?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)称近。 經(jīng)常有香客問(wèn)我,道長(zhǎng)衡未,這世上最難降的妖魔是什么缓醋? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任送粱,我火速辦了婚禮竭鞍,結(jié)果婚禮上偎快,老公的妹妹穿的比我還像新娘晒夹。我一直安慰自己丐怯,他們只是感情好读跷,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著丐枉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪弯院。 梳的紋絲不亂的頭發(fā)上泪掀,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音祝辣,去河邊找鬼蝙斜。 笑死娩鹉,一個(gè)胖子當(dāng)著我的面吹牛弯予,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播呼寸,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼米绕,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蝶柿!你這毒婦竟也來(lái)了交汤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤允华,失蹤者是張志新(化名)和其女友劉穎寥掐,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡歇攻,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年掉伏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缝呕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡斧散,死狀恐怖供常,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情鸡捐,我是刑警寧澤栈暇,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布,位于F島的核電站箍镜,受9級(jí)特大地震影響源祈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜色迂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一香缺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧歇僧,春花似錦图张、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至侥钳,卻和暖如春适袜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背舷夺。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工苦酱, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留售貌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓疫萤,卻偏偏與公主長(zhǎng)得像趁矾,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子给僵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,264評(píng)論 25 707
  • 安德森說(shuō),作為演講者详拙,你要做的第一件事就是找到一種方法帝际,解除觀眾的武裝。 如果想讓你的演講產(chǎn)生影響力饶辙,就必須與觀眾...
    kafkaliu閱讀 198評(píng)論 0 0
  • 家裝e站天津站90平米二居室現(xiàn)代風(fēng)格弃揽。這是一套現(xiàn)代風(fēng)格的裝修案例脯爪,業(yè)主希望營(yíng)造出清新、時(shí)尚的空間矿微,設(shè)計(jì)師通過(guò)壁畫掛...
    JZ子龍閱讀 139評(píng)論 0 0
  • 新的React Router 從 React 汲取了很多思想和理念痕慢,它所提供的路由都可以看成是一個(gè)組件。 本次升級(jí)...
    LYF閑閑閑閑閱讀 553評(píng)論 0 0