多張圖片進行單張上傳

由于服務(wù)器設(shè)置的是只能單張圖片上傳,因此就出現(xiàn)了需要上傳多張圖片時的惡心情況很泊。


??圖中看到的是只有這三行圖片角虫,但其實是有八行的,每行圖片都是沒有限制的委造,因此我對這每行的圖片展示用一個scrollview進行了封裝戳鹅,這里不多介紹。其中圖片的傳入是有的行是必傳的昏兆,有的行是不必傳的枫虏。通過將每行的圖片放到一個數(shù)組中(利用for循環(huán)創(chuàng)建8個數(shù)組),然后將這八個數(shù)組放到一個大數(shù)組中爬虱。

一隶债、使用遞歸算法進行循環(huán)上傳操作

??開始進入上傳圖片的代碼:

/**
 *  多組圖片單張上傳方法
 *
 *  @param up_ImgArr      圖片數(shù)組
 *  @param currentIndex   上傳下一張圖片的索引值,默認(rèn)為0饮潦,外部傳參為0即可
 *  @param urlStringArray 存放圖片上傳成功后返回的url值
 *  @param nextArrIndex   下一組圖片數(shù)組
 */

-(void)uploadImagesWithArray:(NSArray *)up_ImgArr currentIndex:(NSInteger)currentIndex imgUrlStringArray:(NSMutableArray *)urlStringArray nextArrayIndex:(NSInteger)nextArrIndex{

if (up_ImgArr.count>0) {
    
    [API uploadImage:up_ImgArr[currentIndex] withPurpose:@"bang_album" andSuccessBlock:^(NSDictionary *dic) {
        
        [urlStringArray addObject:dic[@"url"]];
        if (currentIndex <up_ImgArr.count-1) {
            NSInteger nextIndex = currentIndex+1;
            //縮略圖thumb 燃异, 大圖 url
            
            [self uploadImagesWithArray:up_ImgArr currentIndex:nextIndex imgUrlStringArray:urlStringArray nextArrayIndex:nextArrIndex];
        }else{
            NSInteger lastIndex = nextArrIndex+1;
            if (lastIndex==self.imgsScrollView.count) {
                [self uploadOtherData];
                return ;
            }else{
                [self uploadImagesWithArray:self.imgsScrollView[lastIndex] currentIndex:0 imgUrlStringArray:self.endImgArr[lastIndex] nextArrayIndex:lastIndex];
            }
        }
        
    } andFailBlock:^(NSError *error) {
        NSLog(@"********%@",error);
    }];
    
}else{
    
    NSInteger lastIndex = nextArrIndex+1;
    if (lastIndex==self.imgsScrollView.count) {
        [self uploadOtherData];
        return ;
    }else{
        [self uploadImagesWithArray:self.imgsScrollView[lastIndex] currentIndex:0 imgUrlStringArray:self.endImgArr[lastIndex] nextArrayIndex:lastIndex];
    }
}
}

??的代碼中傳入的up_ImgArr是包含所有圖片數(shù)組的大數(shù)組中的第一個數(shù)組,然后就會進行循環(huán)上傳继蜡,這種思想利用的是遞歸算法回俐,直到執(zhí)行到自己想要的結(jié)果時需要return,如果遞歸中沒有return的話稀并,那將進入死循環(huán)狀態(tài)仅颇,最終導(dǎo)致 程序崩潰。
上傳多張圖片邏輯規(guī)則:將數(shù)組中的每張圖片取出上傳完成之后再上傳下一張(拋去空數(shù)組)碘举,當(dāng)該數(shù)組上傳完畢之后進行下一個數(shù)組進行上傳忘瓦,直到最后一個數(shù)組上傳完畢。

利用遞歸算法中寫的比較繞引颈,如果仔細(xì)思考的話耕皮,其邏輯還是很清晰的境蜕。PS:這是本人廢了點腦細(xì)胞才寫的,實在是坑爹傲柰!A荒辍!最后找到了使用dispatch_group來實現(xiàn)的就不那么惡心了罚拟,于是就有了??的這塊玉

二台诗、使用dispatch_group和遞歸算法進行多圖上傳

代碼如下:

/**
 *  多張圖片上傳方法
 *
 *  @param images 圖片數(shù)組
 *  @param urlArr 返回圖片數(shù)組對應(yīng)的url
 */
NSInteger current_index = 0;
-(void)senderDataWithImages:(NSArray *) images urls:(NSMutableArray *)urlArr{

if (images.count>0) {
    dispatch_group_t group = dispatch_group_create();
    
    for (UIImage *img in images) {
        dispatch_group_enter(group);
        [API uploadImage:img withPurpose:@"bang_album" andSuccessBlock:^(NSDictionary *dic) {
            
            [urlArr addObject:dic[@"url"]];
            dispatch_group_leave(group);
            
        } andFailBlock:^(NSError *error) {
            NSLog(@"********%@",error);
            dispatch_group_leave(group);
        }];
    }
    
    dispatch_group_notify(group, dispatch_get_global_queue(0, 0), ^{
        
        current_index++;
        
        if (current_index<self.imgsScrollView.count) {
            
            [self senderDataWithImages:self.imgsScrollView[current_index] urls:self.endImgArr[current_index]];
            
        }else{
            
            NSLog(@"上傳結(jié)束");
            return ;
        }
        
    });
}else{
    
    current_index++;
    
    if (current_index<self.imgsScrollView.count) {
        
        [self senderDataWithImages:self.imgsScrollView[current_index] urls:self.endImgArr[current_index]];
        
    }else{
        
        NSLog(@"上傳結(jié)束");
        return ;
    }
}
}

利用這個方法倒是減少了一部分腦細(xì)胞的損耗
demo地址如果喜歡的話給個star
ps:轉(zhuǎn)載請注明iOS小喬 http://www.reibang.com/p/ab2f0b7d764a

如果大家有更好的方法,請給我留言??

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末赐俗,一起剝皮案震驚了整個濱河市拉队,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌阻逮,老刑警劉巖粱快,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異夺鲜,居然都是意外死亡皆尔,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門币励,熙熙樓的掌柜王于貴愁眉苦臉地迎上來慷蠕,“玉大人,你說我怎么就攤上這事食呻×骺唬” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵仅胞,是天一觀的道長每辟。 經(jīng)常有香客問我,道長干旧,這世上最難降的妖魔是什么渠欺? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮椎眯,結(jié)果婚禮上挠将,老公的妹妹穿的比我還像新娘。我一直安慰自己编整,他們只是感情好舔稀,可當(dāng)我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著掌测,像睡著了一般内贮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天夜郁,我揣著相機與錄音什燕,去河邊找鬼。 笑死拂酣,一個胖子當(dāng)著我的面吹牛秋冰,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播婶熬,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼埃撵!你這毒婦竟也來了赵颅?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤暂刘,失蹤者是張志新(化名)和其女友劉穎饺谬,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谣拣,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡募寨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了森缠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拔鹰。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖贵涵,靈堂內(nèi)的尸體忽然破棺而出列肢,到底是詐尸還是另有隱情,我是刑警寧澤宾茂,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布瓷马,位于F島的核電站,受9級特大地震影響跨晴,放射性物質(zhì)發(fā)生泄漏欧聘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一端盆、第九天 我趴在偏房一處隱蔽的房頂上張望怀骤。 院中可真熱鬧,春花似錦爱谁、人聲如沸晒喷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽凉敲。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間爷抓,已是汗流浹背势决。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工判哥, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留母廷,地道東北人病毡。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓侥加,卻偏偏與公主長得像狸捕,于是被迫代替她去往敵國和親愁铺。 傳聞我的和親對象是個殘疾皇子脸侥,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,446評論 2 348

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