九宮格視圖的布局及展示(相冊(cè)選擇)-創(chuàng)新互聯(lián)

    上周一個(gè)朋友帶的項(xiàng)目出了點(diǎn)問題,招的ios開發(fā)人員在實(shí)現(xiàn)選取相冊(cè)圖片后用九宮格的樣式展示時(shí)遇到了瓶頸,花了將近2周都沒有解決。后來在跟我交流的過程中他把項(xiàng)目的圖片發(fā)給我看了下,看完我就笑了,這就只是個(gè)算法的問題,花點(diǎn)時(shí)間思考下基本就能解決的。廢話不多說,把之前完成的效果展示出來。

成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都做網(wǎng)站、網(wǎng)站制作、安吉網(wǎng)絡(luò)推廣、重慶小程序開發(fā)、安吉網(wǎng)絡(luò)營銷、安吉企業(yè)策劃、安吉品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供安吉建站搭建服務(wù),24小時(shí)服務(wù)熱線:13518219792,官方網(wǎng)址:muchs.cn

九宮格視圖的布局及展示(相冊(cè)選擇)

九宮格視圖的布局及展示(相冊(cè)選擇)

九宮格視圖的布局及展示(相冊(cè)選擇)

九宮格視圖的布局及展示(相冊(cè)選擇)

九宮格視圖的布局及展示(相冊(cè)選擇)

九宮格視圖的布局及展示(相冊(cè)選擇)

        以上是直接用手機(jī)截的圖,傳上來沒想到會(huì)這么大。其中圖片添加的功能是引入了一個(gè)第三方的庫,非常好用,跟qq上的圖片添加功能幾乎沒兩樣,庫的名字是ZLPhotoActionSheet。當(dāng)然這都不是重點(diǎn),重點(diǎn)是怎樣去實(shí)現(xiàn)九宮格的展示,上面的圖片中每行是4個(gè),這個(gè)是我自定義的宏,可以任意修改,每行的展示數(shù)目以及展示的總數(shù)目,是比較靈活的。

        這里要說的是算法的核心,如果想不到這些也就沒法做到自動(dòng)換行展示了。

        首先,你得自定義展示的總數(shù)目MAXPhotosNO(這里默認(rèn)是9),每行展示的個(gè)數(shù)AvgImgsNo(默認(rèn)為4),在自定義用來展示九宮格的視圖類里寫一個(gè)對(duì)象方法-(void)updateTheViewWithImgsArr:(NSArray *)imgsArr;,也就是將獲取到的圖片數(shù)組對(duì)象傳入這個(gè)方法,然后再進(jìn)行處理。

        然后,就到了最關(guān)鍵的一步了,對(duì)圖圖片數(shù)組進(jìn)行處理。先判斷數(shù)組里元素個(gè)數(shù)是否等于MAXPhotosNO,這里用于判斷是否需要隱藏添加按鈕。然后進(jìn)行for循環(huán)處理,創(chuàng)建用于承載圖片的UIImageView,個(gè)數(shù)為圖片數(shù)組元素的個(gè)數(shù)。每次創(chuàng)建之前要知道它是第幾行的第幾個(gè),以此來計(jì)算它應(yīng)該處的位置。

        設(shè)置2個(gè)int類型參數(shù):(i代表循環(huán)的變量)

        int s = i/AvgImgsNo;(確定是第幾行,0代表第一行,以此類推)

        int r = i%AvgImgsNo;(確定是第幾個(gè),0代表第一個(gè),以此類推)

        接下來就可以計(jì)算它的位置了:(帶space的參數(shù)為間距)

        imgV.frame = CGRectMake(ImgSpace*(r+1)+AvgWidth*r,RowSpace*                (s+1)+AvgWidth*s,AvgWidth,AvgWidth);

        當(dāng)然,千萬別忘了添加按鈕的位置也發(fā)生了改變:

        同樣的2個(gè)參數(shù): (因?yàn)樗冀K是最后一個(gè),所以直接在后面加1計(jì)算就可以了)

        int k = (i+1)/AvgImgsNo;

        int j = (i+1)%AvgImgsNo;

        這里要注意:如果數(shù)組元素的個(gè)數(shù)已經(jīng)達(dá)到了設(shè)置的MAXPhotosNO的大值,要這樣做處理

        if((int)imgsArr.count==MaxPhotosNo){

            k = MaxPhotosNo/AvgImgsNo;    //始終讓它處在最后一行的最后一個(gè),因?yàn)槲倚枰姆轿粊聿季?,如果不要的同學(xué),可以不用這樣寫

        }

         最后,其實(shí)已經(jīng)完成了,其中的細(xì)節(jié)可能還有些,但是大體的思路基本就是這個(gè)樣子,非常的簡單。我真的有點(diǎn)不明白為啥這樣的一個(gè)功能2周都寫不出來......,好吧我們都是站在巨人肩膀上說風(fēng)涼話的人哈哈~

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

文章題目:九宮格視圖的布局及展示(相冊(cè)選擇)-創(chuàng)新互聯(lián)
URL標(biāo)題:http://muchs.cn/article44/degihe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、云服務(wù)器網(wǎng)站導(dǎo)航、服務(wù)器托管虛擬主機(jī)、外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司