UIView 指定位置截圖

#import "UIImage+Snapshot.h"

@implementation UIImage (Snapshot)

+ (UIImage *)getKeyWindowSnapshot
{
    UIWindow *screenWindow = [[UIApplication sharedApplication] keyWindow];
    return [self getSnapshotFromView:screenWindow atFrame:screenWindow.bounds];
}

+ (UIImage *)getSnapshotFromKeyWindowAtFrame:(CGRect)frame
{
    UIWindow *screenWindow = [[UIApplication sharedApplication] keyWindow];
    return [self getSnapshotFromView:screenWindow atFrame:frame];
}

+ (UIImage *)getSnapshotFromView:(UIView *)view atFrame:(CGRect)frame
{
    if (!view || CGRectEqualToRect(CGRectZero, view.bounds)) {
        return nil;
    }
    // 1、先根據(jù) view专控,生成 整個(gè) view 的截圖
    UIGraphicsBeginImageContextWithOptions(view.bounds.size, YES, 0);  //NO拘泞,YES 控制是否透明
    if ([view respondsToSelector:@selector(drawViewHierarchyInRect:afterScreenUpdates:)]) {
        [view drawViewHierarchyInRect:view.bounds afterScreenUpdates:NO];
    } else {
        [view.layer renderInContext:UIGraphicsGetCurrentContext()];
    }
    UIImage *wholeImage = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    
    // 如果 frame 和 bounds 一樣符匾,只要返回 wholeImage 就好真竖。
    if (CGRectEqualToRect(frame, view.bounds)) {
        return wholeImage;
    }
    
    // 2、根據(jù) view 的圖片宣虾。生成指定位置大小的圖片骤宣。
    CGFloat screenScale = [[UIScreen mainScreen] scale];
    CGRect imageToExtractFrame = CGRectApplyAffineTransform(frame, CGAffineTransformMakeScale(screenScale, screenScale));
    CGImageRef imageRef = CGImageCreateWithImageInRect([wholeImage CGImage], imageToExtractFrame);
    
    wholeImage = nil;
    
    UIImage *image = [UIImage imageWithCGImage:imageRef
                                         scale:screenScale
                                   orientation:UIImageOrientationUp];
    CGImageRelease(imageRef);
    return image;
}

@end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市锌蓄,隨后出現(xiàn)的幾起案子升筏,更是在濱河造成了極大的恐慌,老刑警劉巖瘸爽,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件您访,死亡現(xiàn)場離奇詭異,居然都是意外死亡剪决,警方通過查閱死者的電腦和手機(jī)灵汪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來柑潦,“玉大人享言,你說我怎么就攤上這事∩恚” “怎么了览露?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長譬胎。 經(jīng)常有香客問我差牛,道長命锄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任偏化,我火速辦了婚禮脐恩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘侦讨。我一直安慰自己驶冒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布韵卤。 她就那樣靜靜地躺著骗污,像睡著了一般。 火紅的嫁衣襯著肌膚如雪怜俐。 梳的紋絲不亂的頭發(fā)上身堡,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天,我揣著相機(jī)與錄音拍鲤,去河邊找鬼贴谎。 笑死,一個(gè)胖子當(dāng)著我的面吹牛季稳,可吹牛的內(nèi)容都是我干的擅这。 我是一名探鬼主播,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼景鼠,長吁一口氣:“原來是場噩夢啊……” “哼仲翎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起铛漓,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤溯香,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后浓恶,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體玫坛,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年包晰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了湿镀。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,566評論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伐憾,死狀恐怖勉痴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情树肃,我是刑警寧澤蒸矛,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響雏掠,放射性物質(zhì)發(fā)生泄漏廓脆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一磁玉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧驾讲,春花似錦蚊伞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至谓晌,卻和暖如春掠拳,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背纸肉。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工溺欧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人柏肪。 一個(gè)月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓姐刁,卻偏偏與公主長得像,于是被迫代替她去往敵國和親烦味。 傳聞我的和親對象是個(gè)殘疾皇子聂使,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評論 2 348

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