UIImage分類擴(kuò)展(壓縮圖片/截圖/獲取啟動頁/base64轉(zhuǎn)換等)

很多UIImage的方法可以寫成分類卸耘,方便調(diào)用澜搅。

  • 將圖片鏈接轉(zhuǎn)為UIImage
/**
 根據(jù)url生成圖片

 @param fileURL 圖片url
 @return 圖片
 */
+(UIImage *) getImageFromURL:(NSString *)fileURL{
    UIImage * result;
    NSData * data = [NSData dataWithContentsOfURL:[NSURL URLWithString:fileURL]];
    result = [UIImage imageWithData:data];
    return result;
}
  • 圖片轉(zhuǎn)base64字符串
/**
 圖片轉(zhuǎn)成base64

 @param image 圖片
 @return base64
 */
+ (NSString *)imageToString:(UIImage *)image{
    NSData *imagedata = UIImagePNGRepresentation(image);
    NSString *image64 = [imagedata base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
    return image64;
}
  • base64字符串轉(zhuǎn)圖片
/**
 根據(jù)base64轉(zhuǎn)成圖片

 @param base64Image base64
 @return 圖片
 */
+(UIImage*)stringToImage:(NSString*)base64Image{
    NSData *decodedImageData = [[NSData alloc] initWithBase64EncodedString:base64Image options:NSDataBase64DecodingIgnoreUnknownCharacters];
    UIImage *decodedImage = [UIImage imageWithData:decodedImageData];
     NSData *imgData = UIImagePNGRepresentation(decodedImage);
    UIImage *img = [UIImage imageWithData:imgData];
    return img;
}
  • 通過顏色值轉(zhuǎn)圖片
/**
 根據(jù)顏色生成圖片

 @param color 顏色
 @param rect 圖片尺寸
 @return 圖片
 */
+ (UIImage *)cl_imageWithColor:(NSString *)color andRect:(CGRect)rect{
    UIGraphicsBeginImageContext(rect.size);
    CGContextRef context = UIGraphicsGetCurrentContext();
    if (color.length == 0 ) {//背景透明色
         CGContextSetFillColorWithColor(context, [[UIColor clearColor] CGColor]);
    }else{
         CGContextSetFillColorWithColor(context, [hexStringToColor(color) CGColor]);
    }
    CGContextFillRect(context, rect);
    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    return image;
}
  • 視圖生成圖片
/**
 根據(jù)視圖生成圖片

 @param view 視圖
 @param size 視圖尺寸
 @return 圖片
 */
+ (UIImage *)makeImageWithView:(UIView *)view withSize:(CGSize)size
{
    /*第一個參數(shù)表示區(qū)域大小伍俘。
     第二個參數(shù)表示是否是非透明的。如果需要顯示半透明效果勉躺,需要傳NO癌瘾,否則傳YES。
     第三個參數(shù)就是屏幕密度了饵溅,關(guān)鍵就是第三個參數(shù) [UIScreen mainScreen].scale妨退。
     另:第二個參數(shù)改為yes,可以解決圖片保存相冊的右側(cè)和底部的白邊問題*/
    UIGraphicsBeginImageContextWithOptions(size, NO, 0.0);
    CGContextSetFillColorWithColor(UIGraphicsGetCurrentContext(), [[UIColor clearColor] CGColor]);
    [view.layer renderInContext:UIGraphicsGetCurrentContext()];
    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    return image;
}
  • gif圖片轉(zhuǎn)數(shù)組
/**
 將gif的data數(shù)據(jù)轉(zhuǎn)成u圖片數(shù)組

 @param data gif的data數(shù)據(jù)
 @return 圖片數(shù)組
 */
+( NSMutableArray*) praseGIFDataToImageArray:(NSData *)data{
    NSMutableArray *frames = [[NSMutableArray alloc] init];
    CGImageSourceRef src = CGImageSourceCreateWithData((CFDataRef)data, NULL);    CGFloat animationTime = 0.f;
    if (src) {
        size_t l = CGImageSourceGetCount(src);
        frames = [NSMutableArray arrayWithCapacity:l];
        for (size_t i = 0; i < l; i++) {
            CGImageRef img = CGImageSourceCreateImageAtIndex(src, i, NULL);
            NSDictionary *properties = (NSDictionary *)CFBridgingRelease(CGImageSourceCopyPropertiesAtIndex(src, i, NULL));
            NSDictionary *frameProperties = [properties objectForKey:(NSString *)kCGImagePropertyGIFDictionary];
            NSNumber *delayTime = [frameProperties objectForKey:(NSString *)kCGImagePropertyGIFUnclampedDelayTime];
            animationTime += [delayTime floatValue];
            if (img) {
                [frames addObject:[UIImage imageWithCGImage:img]];
                CGImageRelease(img);
            }
        }
        CFRelease(src);
    }
    return frames;
}
  • 對某個view進(jìn)行截圖蜕企,截屏
/**
 截屏

 @param view 截屏的視圖
 @return 圖片
 */
+(UIImage *)captureImageFromView:(UIView *)view {
    CGRect viewRect = [view bounds];
    CGFloat scale = 1.0;
    if ([[UIScreen mainScreen]respondsToSelector:@selector(scale)]) {
        CGFloat tmp = [[UIScreen mainScreen]scale];
        if (tmp > 1.5) {
            scale = 2.0;
        }
        if (tmp > 2.5) {
            scale=3.0;
        }
    }
    if (scale > 1.5) {
        UIGraphicsBeginImageContextWithOptions(viewRect.size, NO, scale);
    } else {
        UIGraphicsBeginImageContext(viewRect.size);
    }
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    [view.layer renderInContext:ctx];
    UIImage * image = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    return image;
}
  • 獲取啟動頁的圖片
/**
 獲取啟動頁

 @return 啟動頁圖片
 */
+(UIImage*)getLauchImage{
    CGSize viewSize = [UIScreen mainScreen].bounds.size;
    NSString *viewOrientation = @"Portrait";
    UIImage *lauchImage = nil;
    NSArray *imageDict = [[[NSBundle mainBundle] infoDictionary] valueForKey:@"UILaunchImages"];
    for (NSDictionary *dict in imageDict) {
        CGSize imageSize = CGSizeFromString(dict[@"UILaunchImageSize"]);
        if (CGSizeEqualToSize(imageSize, viewSize) && [viewOrientation isEqualToString:dict[@"UILaunchImageOrientation"]]) {
            lauchImage = [UIImage imageNamed:dict[@"UILaunchImageName"]];
        }
    }
    return lauchImage;
}
  • 根據(jù)質(zhì)量或者尺寸壓縮圖片
/**
 壓縮圖片

 @param image 圖片
 @param maxLength 最大質(zhì)量
 @return 圖片
 */
+ (UIImage *)compressImage:(UIImage *)image toByte:(NSUInteger)maxLength {
    // Compress by quality
    CGFloat compression = 1;
    NSData *data = UIImageJPEGRepresentation(image, compression);
    NSLog(@"%lukb",data.length/1024);
    if (data.length < maxLength) return image;
    
    CGFloat max = 1;
    CGFloat min = 0;
    for (int i = 0; i < 6; ++i) {
        compression = (max + min) / 2;
        data = UIImageJPEGRepresentation(image, compression);
        if (data.length < maxLength * 0.9) {
            min = compression;
        } else if (data.length > maxLength) {
            max = compression;
        } else {
            break;
        }
    }
    UIImage *resultImage = [UIImage imageWithData:data];
    if (data.length < maxLength) return resultImage;
    
    // Compress by size
    NSUInteger lastDataLength = 0;
    while (data.length > maxLength && data.length != lastDataLength) {
        lastDataLength = data.length;
        CGFloat ratio = (CGFloat)maxLength / data.length;
        CGSize size = CGSizeMake((NSUInteger)(resultImage.size.width * sqrtf(ratio)),
                                 (NSUInteger)(resultImage.size.height * sqrtf(ratio))); // Use NSUInteger to prevent white blank
        UIGraphicsBeginImageContext(size);
        [resultImage drawInRect:CGRectMake(0, 0, size.width, size.height)];
        resultImage = UIGraphicsGetImageFromCurrentImageContext();
        UIGraphicsEndImageContext();
        data = UIImageJPEGRepresentation(resultImage, compression);
    }
    return resultImage;
}

持續(xù)更新中...

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末咬荷,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子糖赔,更是在濱河造成了極大的恐慌,老刑警劉巖轩端,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件放典,死亡現(xiàn)場離奇詭異,居然都是意外死亡基茵,警方通過查閱死者的電腦和手機(jī)奋构,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拱层,“玉大人弥臼,你說我怎么就攤上這事「疲” “怎么了径缅?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵掺栅,是天一觀的道長。 經(jīng)常有香客問我纳猪,道長氧卧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任氏堤,我火速辦了婚禮沙绝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鼠锈。我一直安慰自己闪檬,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布购笆。 她就那樣靜靜地躺著粗悯,像睡著了一般。 火紅的嫁衣襯著肌膚如雪由桌。 梳的紋絲不亂的頭發(fā)上为黎,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天,我揣著相機(jī)與錄音行您,去河邊找鬼铭乾。 笑死,一個胖子當(dāng)著我的面吹牛娃循,可吹牛的內(nèi)容都是我干的炕檩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼捌斧,長吁一口氣:“原來是場噩夢啊……” “哼笛质!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起捞蚂,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤妇押,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后姓迅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體敲霍,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年丁存,在試婚紗的時候發(fā)現(xiàn)自己被綠了肩杈。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡解寝,死狀恐怖扩然,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情聋伦,我是刑警寧澤夫偶,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布界睁,位于F島的核電站,受9級特大地震影響索守,放射性物質(zhì)發(fā)生泄漏晕窑。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一卵佛、第九天 我趴在偏房一處隱蔽的房頂上張望杨赤。 院中可真熱鬧,春花似錦截汪、人聲如沸疾牲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽阳柔。三九已至,卻和暖如春蚓峦,著一層夾襖步出監(jiān)牢的瞬間舌剂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工暑椰, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留霍转,地道東北人。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓一汽,卻偏偏與公主長得像避消,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子召夹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評論 2 353