微信群頭像的生成方法

工作快一年來(lái),第一次想寫文章冬竟,想想還有點(diǎn)小激動(dòng)欧穴。主要是想把自己開(kāi)發(fā)中的一點(diǎn)經(jīng)歷寫下來(lái)。以供自己查看泵殴。也讓廣大同行參考涮帘,指正。

好了笑诅,作為碼農(nóng)调缨,話不多說(shuō)。先來(lái)看下生成的效果圖:

WechatIMG2.jpeg

WechatIMG3.jpeg

生成的方法很簡(jiǎn)單吆你。直接上代碼:

/**
 根據(jù)網(wǎng)絡(luò)圖片弦叶,得到群組頭像

如果是網(wǎng)絡(luò)圖片,需要先把圖片下載好妇多。
 @param URLArray 頭像地址
 @param bgColor 圖片填充色
 @return 群組頭像
 */
+ (UIImage *)groupImageWithURLS:(NSArray<NSString *> *)URLArray backgroundColor:(UIColor *)bgColor imageWidth:(CGFloat)imageWidth{

    if (!URLArray) return nil;
    
    NSMutableArray<UIImage *> *imageArray = [NSMutableArray arrayWithCapacity:URLArray.count];
    for (NSString *urlStr in URLArray) {
        NSData *imageData = [[NSData alloc] initWithContentsOfURL:[NSURL URLWithString:urlStr]];
        UIImage *image = [[UIImage alloc] initWithData:imageData];
        if (imageData != nil)
            [imageArray addObject:image];
    }
    if (imageArray.count == 1) {
        return imageArray.firstObject;
    }
    
    return [UIImage groupImageWithImages:imageArray backgroundColor:bgColor imageSize:imageWidth];
}

根據(jù)下載好的圖片湾蔓,來(lái)繪制圖片

/**
 根據(jù)圖片合成群組頭像

 @param imageArray 圖片數(shù)組
 @param bgColor 填充色
 @param imageWidth 圖片寬度
 @return 群組頭像
 */
+ (UIImage *)groupImageWithImages:(NSArray<UIImage *> *)imageArray backgroundColor:(UIColor *)bgColor imageSize:(CGFloat)imageWidth {

    if (imageArray == nil) return nil;
    if (imageArray.count < 2) return imageArray.firstObject;
    
    UIColor *drawBackgroundColor = bgColor==nil?[UIColor groupTableViewBackgroundColor]:bgColor;
    // 計(jì)算各個(gè)圖片的位置
    NSArray<NSString *> *rectArray = [UIImage imageRectWithCount:imageArray.count drawSize:imageWidth];
    // 布局畫布
    UIGraphicsBeginImageContextWithOptions(CGSizeMake(imageWidth, imageWidth), NO, [UIScreen mainScreen].scale);
    CGContextRef context = UIGraphicsGetCurrentContext();
    CGContextSetFillColorWithColor(context, drawBackgroundColor.CGColor);
    CGContextSetStrokeColorWithColor(context, drawBackgroundColor.CGColor);
    CGContextSetLineWidth(context, 1.f);
    CGContextMoveToPoint(context, 0, 0);
    CGContextAddLineToPoint(context, 0, imageWidth);
    CGContextAddLineToPoint(context, imageWidth, imageWidth);
    CGContextAddLineToPoint(context, imageWidth, 0);
    CGContextAddLineToPoint(context, 0, 0);
    CGContextClosePath(context);
    CGContextDrawPath(context, kCGPathFillStroke);
    
    for (int i = 0; i<imageArray.count; i++) {
        UIImage *image = imageArray[i];
        CGRect rect = CGRectFromString(rectArray[i]);
        [image drawInRect:rect];
    }
    UIImage *groupIconImage = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    
    return groupIconImage;
}

這里圖片等間距給定8像素,所以圖片等寬度需要大一點(diǎn)砌梆。
下面是最主要的計(jì)算每張圖片的位置。


// 根據(jù)圖片的數(shù)量得到每張圖片對(duì)應(yīng)的位置
+ (NSArray<NSString *> *)imageRectWithCount:(NSInteger)count drawSize:(CGFloat)size {
    
    NSMutableArray *rectArray = [NSMutableArray arrayWithCapacity:count];
    CGFloat drawWidth = size?size:100.f;
    CGFloat padding = 8.f;          //圖片之間的邊距
    CGFloat imageWidth = 0.f;       //圖片寬度
    
    NSInteger row = 0;          //行
    NSInteger column = 0;       //列
    NSInteger remainder = 0;    //余數(shù)
    // 處理圖片寬度
    if (count <= 4) {
        imageWidth = (drawWidth - padding*3)/2;
        row = count/2;
        column = 2;
        remainder = count%2;
    }else{
        imageWidth = (drawWidth - padding*4)/3;
        row = count/3;
        column = 3;
        remainder = count%3;
    }
    CGFloat topMargin = 0.f;
    
    if (remainder > 0) {        //有多余行贬循,先布局多出來(lái)的一行
        CGFloat rowFirstY = (size - ((row + 1)*imageWidth + row*padding))/2;
        CGFloat rowFirstX = (size - (remainder*imageWidth + (remainder - 1)*padding))/2;
        for (int i = 0; i<remainder; i++) {
            CGFloat x = rowFirstX + (imageWidth+padding)*i;
            CGFloat y = rowFirstY;
            CGRect rect = CGRectMake(x, y, imageWidth, imageWidth);
            NSString *imageRectStr = NSStringFromCGRect(rect);
            [rectArray addObject:imageRectStr];
        }
        topMargin = rowFirstY + imageWidth + padding;
    }else{                      // 沒(méi)有多余行咸包,頂部邊距根據(jù)行數(shù)正常計(jì)算
        topMargin = (size - (imageWidth*row + (row-1)*padding))/2;
    }
    
    //布局其他正常的位置
    for (int i = 0; i<row; i++) {
        for (int j = 0; j<column; j++) {
            CGFloat x = padding + (imageWidth + padding)*j;
            CGFloat y = topMargin + (imageWidth + padding)*i;
            CGRect rect = CGRectMake(x, y, imageWidth, imageWidth);
            NSString *imageRectStr = NSStringFromCGRect(rect);
            [rectArray addObject:imageRectStr];
        }
    }
    
    return rectArray;
}

到此。你就能和微信一樣生成群組頭像了杖虾。是不是很簡(jiǎn)單烂瘫。
第一篇文章是個(gè)好的開(kāi)始。以后有時(shí)間奇适,會(huì)多寫文章的坟比。大家一起加油~~~qwq

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市嚷往,隨后出現(xiàn)的幾起案子葛账,更是在濱河造成了極大的恐慌,老刑警劉巖皮仁,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件籍琳,死亡現(xiàn)場(chǎng)離奇詭異菲宴,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)趋急,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門喝峦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人呜达,你說(shuō)我怎么就攤上這事谣蠢。” “怎么了查近?”我有些...
    開(kāi)封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵眉踱,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我嗦嗡,道長(zhǎng)勋锤,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任侥祭,我火速辦了婚禮叁执,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘矮冬。我一直安慰自己谈宛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布胎署。 她就那樣靜靜地躺著吆录,像睡著了一般。 火紅的嫁衣襯著肌膚如雪琼牧。 梳的紋絲不亂的頭發(fā)上恢筝,一...
    開(kāi)封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天,我揣著相機(jī)與錄音巨坊,去河邊找鬼撬槽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛趾撵,可吹牛的內(nèi)容都是我干的侄柔。 我是一名探鬼主播,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼占调,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼暂题!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起究珊,我...
    開(kāi)封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤薪者,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后苦银,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體啸胧,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赶站,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了纺念。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贝椿。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖陷谱,靈堂內(nèi)的尸體忽然破棺而出烙博,到底是詐尸還是另有隱情,我是刑警寧澤烟逊,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布渣窜,位于F島的核電站,受9級(jí)特大地震影響宪躯,放射性物質(zhì)發(fā)生泄漏乔宿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一访雪、第九天 我趴在偏房一處隱蔽的房頂上張望详瑞。 院中可真熱鬧,春花似錦臣缀、人聲如沸坝橡。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)计寇。三九已至,卻和暖如春脂倦,著一層夾襖步出監(jiān)牢的瞬間番宁,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工赖阻, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贝淤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓政供,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親朽基。 傳聞我的和親對(duì)象是個(gè)殘疾皇子布隔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

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