iOS如何開發(fā)一個好看的ActionSheet

小編給大家分享一下iOS如何開發(fā)一個好看的ActionSheet,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)長期為1000多家客戶提供的網(wǎng)站建設服務,團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為土默特右旗企業(yè)提供專業(yè)的做網(wǎng)站、成都做網(wǎng)站,土默特右旗網(wǎng)站改版等技術(shù)服務。擁有十余年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

首先看下效果圖:

樣式一:

iOS如何開發(fā)一個好看的ActionSheet

樣式二:

iOS如何開發(fā)一個好看的ActionSheet

樣式三:

iOS如何開發(fā)一個好看的ActionSheet

系統(tǒng)自帶ActionSheet

iOS如何開發(fā)一個好看的ActionSheet

其實個人感覺還是不錯的,無奈與設計師風格不同,所以咱就換唄...

開始前思考

1.實現(xiàn)actionSheet效果選用什么作為載體?

要實現(xiàn)ActionSheet樣式并不難,剛開始想來好幾種控件實現(xiàn)形式,比如可以用UIView結(jié)合UIButton來實現(xiàn),也可以用TableView這個最常用的表視圖來實現(xiàn).比較這兩者發(fā)現(xiàn),UITableView可以根據(jù)其代理實現(xiàn)不同數(shù)量的Sheet單元格,而且還有cell的selecte方法,對于每個sheet單元格的復雜樣式,我們還可以通過自定義cell來實現(xiàn),相比較Button不僅省去了動態(tài)創(chuàng)建Button數(shù)量的開銷,而且系統(tǒng)封裝性和可擴展性更好.所以選用tableView是一個比較好的選擇.

2.如何封裝提高復用性?

提高復用性這一步對于當前這個ActionSheet用TableView實現(xiàn)來說很簡單,因為UITableView系統(tǒng)本身就給我自帶了很多代理方法,通過代理方法我們可以控制創(chuàng)建Sheet的分區(qū)數(shù)量以及每個分區(qū)內(nèi)sheet的單元格數(shù)量.

但是作為一個自定義控件,特別是github上好的一些第三方,不僅在功能上有很大的實用性,而且每個功能的使用上也是很簡便,對我們來說使用越簡單,說明封裝性越好,在這里我個人覺得復用性的東西就是在一些模塊高度封裝的基礎之上的多次代碼延伸,拿這個ActionSheet來說,我最終希望的是當別人看到我這個控件之后,只需要關(guān)心你自己的業(yè)務需求,比如需要創(chuàng)建什么樣式,需要創(chuàng)建多少個sheet單元格,關(guān)心這些就夠了,所以我暴露給你的就是對應的給你一個創(chuàng)建樣式,給你一個創(chuàng)建多少個的方法就可以了.當然這樣也有缺點,封裝性越好,別人再用的時候再去擴展性就越差,所以,在自定義一個控件的時候要盡可能多考慮到各種需求來提高你封裝的代碼適應性.

3.確定思路

使用UITableView+自定義Cell方式,根據(jù)TableView的不同代理方法控制ActionSheet的單元格數(shù)量以及頭部及尾部分區(qū)的樣式.

實現(xiàn)

創(chuàng)建TableView,在此我是將TableView添加在View上

實現(xiàn)TableView相關(guān)代理方法

自定義TableViewCell樣式,并實現(xiàn)不同ActionSheet風格

測試

這一步到不是有什么技術(shù)含量,我寫在這里也是為了還原實現(xiàn)這一個Demo的思路,但是這一步其實也很重要,因為測試之后才能知道自己的程序?qū)懙脑趺礃?是否可行,這一步直接會影響到后續(xù)的優(yōu)化.我關(guān)注的點是:

  • 功能是否實現(xiàn)了?

  • 使用起來是否簡單方便?

  • 實現(xiàn)同樣的功能,是否有更好的方法?

  • 不好的地方怎么優(yōu)化?

對以上關(guān)注的點來看,我當時寫完之后記錄是這樣的:

  • 功能基本實現(xiàn),但是太單一,擴展性不高

  • 使用起來不方便,初始化代碼復雜,實現(xiàn)功能點代碼過于分散

  • 代碼邏輯有待改進,代碼復用性不強

  • UI處理比較粗糙

優(yōu)化

通過上述測試之后,我把遇到的問題都列出來,然后一一進行優(yōu)化.

1.功能單一,擴展性不高

通過上面的截圖能看出來,我希望這個ActionSheet可以自定義不同的樣式,比如頭部和底部字體大小,顏色,高度;單元格字體大小,顏色,背景顏色以及行高,還有單元格不同的樣式,是只需要文字還是需要圖標加文字.這些應當提供給用戶做更多的選擇.但是這些樣式并不是剛需,所以可以作為額外代碼配置.可以單獨設置某一項,也可以一項都不設置,那就會以默認樣式來展示.通過屬性方式提供給用戶配置更多樣式:

iOS如何開發(fā)一個好看的ActionSheet

2.使用起來不方便,初始化代碼復雜,實現(xiàn)功能點代碼過于分散.

對于一個基本控件的初始化,蘋果API給了我們很好的實例,創(chuàng)建時我們最好把這個控件最基本的需求放在初始化方法里,比如創(chuàng)建一個view 我們可以使用

UIView *view = [[UIView alloc] init];

也可以使用

UIView *view = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];

這兩種方法都是可以的,但是像TableView創(chuàng)建時,我們使用的

UITableView *table = [[UITableView alloc] initWithFrame:CGRectMake(0, 0, 0, 0) style:(UITableViewStyle)]

這個方法會帶有一個style參數(shù),這時我們就可以很方便快速的創(chuàng)建一個tableView的實例,但是像tableView的backgroundColor這樣的參數(shù)我們就不會放在初始化方法里.對于一個ActionSheet的控件,我將標題,單元格標題,取消按鈕標題以及代理作為初始化方法需要的參數(shù),最終的初始化方法如下:

iOS如何開發(fā)一個好看的ActionSheet

3.實現(xiàn)同樣的功能,是否有更好的方法?

這個問題可以通過實現(xiàn)過程中遇到的問題相結(jié)合說明,Demo中有一個設置圓角的屬性,通過設置圓角可以實現(xiàn)和蘋果官方提供的ActionSheet類似的風格,當時這個sheet單元格第一個和最后一個都是半邊圓角,但是中間沒有圓角的樣式,我想過要不要通過判斷樣式用背景圖片來實現(xiàn),但是仔細一想這樣還需要借助美工切圖,在性能差不多的情況下盡量不依賴美工實現(xiàn)我覺得比較可取,所以我又采用了使用貝塞爾曲線定向切圓角的方法來實現(xiàn).

以上是“iOS如何開發(fā)一個好看的ActionSheet”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文題目:iOS如何開發(fā)一個好看的ActionSheet
路徑分享:http://bm7419.com/article22/jjcjcc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供虛擬主機、網(wǎng)站設計公司、微信公眾號、Google、搜索引擎優(yōu)化

廣告

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

網(wǎng)站托管運營