您好,登錄后才能下訂單哦!
UIScrollView 類負(fù)責(zé)所有基于 UIKit 的滾動(dòng)操作。
一、創(chuàng)建
CGRect bounds = [ [ UIScreen mainScreen ] applicationFrame ] ; UIScrollView* scrollView = [ [UIScrollView alloc ] initWithFrame:bounds ];
當(dāng)你創(chuàng)建完滾動(dòng)視圖后,你可以將另一個(gè)視圖的內(nèi)容粘合到滾動(dòng)視圖的空白頁上。這回創(chuàng)建一個(gè)滾動(dòng)的內(nèi)容窗口:
[ scrollView addSubview:myView];
你必須給出內(nèi)容的實(shí)際大小,這樣滾動(dòng)視圖才知道滾動(dòng)的范圍:
scrollView.contentSize = myView.frame.size;
要開啟縮放功能需要調(diào)整視圖的兩個(gè)屬性,分別是maxinumZoomScale 和 mininumZoomScale 。這樣就可以允許用戶使用捏合手勢調(diào)整內(nèi)容大小:
scrollView.maxinumZoomScale = 2.0;//允許放大2倍 scrollView.mininumZoomScale = 0.5;//允許放大到0.5倍
要打開縮放功能,你還需要增加一個(gè)UIScrollViewDelegate 代理,通過一個(gè)名為 viewForZoomingScrollView
的方法做出響應(yīng)。這個(gè)方法會(huì)返回進(jìn)行縮放時(shí)所使用的 UIView 對象:
scrollView.delegate = self; - (UIView*)viewForZoomingInScrollView:(UIScrollView*)scrollView{ retutn myView; }
Tips:對于大規(guī)模數(shù)據(jù),你可能會(huì)在最初使用一個(gè)低于實(shí)際大小(1.0)的縮放比例,讓用戶可以平滑地進(jìn)行放大。
二、屬性
除了上面用到的縮放屬性外,滾動(dòng)視圖還有會(huì)讓你多其他屬性,可以對現(xiàn)實(shí)內(nèi)容的行為進(jìn)行微調(diào)。你可以對 UIScrollView 類進(jìn)行多方位定制。下面這些屬性是最常用的。
1.indicatorStyle
指定你希望使用的滾動(dòng)條指示器的類型。默認(rèn)行為是在白邊界上繪制黑色的滾動(dòng)條,這在大多數(shù)背景下都適用。可用風(fēng)格如下:
2.contentOffset
一個(gè)CGPoint結(jié)構(gòu),其中包含有要顯示內(nèi)容相對于窗口左上角的偏移量。默認(rèn)是從0×0開始的,但是你也可以將顯示內(nèi)容放在其他位置。
3.directionalLockEnabled
默認(rèn)行為是允許用戶同時(shí)進(jìn)行橫向和縱向的滾動(dòng)。將這個(gè)屬性設(shè)置為YES會(huì)導(dǎo)致將用戶的滾動(dòng)行為鎖定成只允許橫向或縱向進(jìn)行,具體方向由初始姿態(tài)決定。
4.bounces
當(dāng)用戶抵達(dá)滾動(dòng)區(qū)域邊緣時(shí),這個(gè)功能允許用戶稍微拖動(dòng)到邊界外一點(diǎn)。當(dāng)用戶松開手指后,這個(gè)區(qū)域會(huì)像個(gè)橡皮筋一樣,彈回到原位,給用戶一個(gè)可見的提示,表示他已經(jīng)到達(dá)了文檔開始或結(jié)束位置。如果不想讓用戶的滾動(dòng)范圍能夠超出可見內(nèi)容,可以將這個(gè)屬性設(shè)置為NO。
5.bouncesZoom
類似于bounces 選項(xiàng),這個(gè)方法可以令用戶的縮放操作超出最大或最小縮放級別,然后彈回到范圍以內(nèi)。如果你不想讓用戶能夠超出你指定的范圍進(jìn)行縮放,將這個(gè)屬性設(shè)置為NO。
6.pagingEnabled
當(dāng)開啟了分頁功能時(shí),滾動(dòng)視圖被分割成多個(gè)獨(dú)立區(qū)段,二用戶的滾動(dòng)體驗(yàn)則變成了頁面翻轉(zhuǎn),你可以用這個(gè)屬性來進(jìn)行頁面翻轉(zhuǎn)。
三、委托方法
可以賦予滾動(dòng)視圖一個(gè)委托,下列委托方法會(huì)在特定時(shí)刻收到通知。
-(void)scrollViewDidScroll:(UIScrollView*)scrollView; //會(huì)在視圖滾動(dòng)時(shí)收到通知。包括一個(gè)指向被滾動(dòng)視圖的指針,從中可以讀取contentOffset屬性以確定其滾動(dòng)到的位置。
-(void)scrollViewWillBeginDragging:(UISCrollView*)scrollView; //當(dāng)用戶首次在某個(gè)方向上進(jìn)行拖動(dòng)時(shí)得到通知。這個(gè)方法會(huì)得到被作為參數(shù)傳遞的滾動(dòng)視圖指針,也同樣可以從中讀取 contentOffset 屬性。
-(void)scrollViewDidEndDragging:(UIScrollView*)scrollView willDecelerate:(BOOL)decelerate; //當(dāng)用戶抬起拖動(dòng)到手指時(shí)得到通知。還會(huì)得到一個(gè)布爾值,知名報(bào)告滾動(dòng)視圖最后位置之前,是否需要減速。
-(void)scrollViewWillBeginDecelerate:(UIScrollView*)scrollView; //當(dāng)用戶抬起手指而視圖需要繼續(xù)移動(dòng)時(shí),會(huì)收到通知。這個(gè)方法可以用來讀取 contentOffset屬性,從而判斷出當(dāng)用戶抬起手指錢最后一次滾動(dòng)到的位置,雖然這個(gè)位置并不會(huì)使?jié)L動(dòng)條的最終停止位置。
-(void)scrollViewDidEndDecelerating:(UIScrollView*)scrollView; //當(dāng)上面提到的減速完畢、滾動(dòng)視圖停止時(shí)得到通知。收到這個(gè)通知的時(shí)刻,滾動(dòng)視圖的contentOffset屬性會(huì)反映出滾動(dòng)條最終停止的位置。
-(void)scrollViewDidEndZooming:(UIScrollview*)scrollView withView:(UIView*)view atScale:(float)scale; //當(dāng)用戶對內(nèi)容進(jìn)行縮放時(shí),會(huì)收到通知。縮放比例表示為一個(gè)浮點(diǎn)值,會(huì)作為參數(shù)傳遞進(jìn)來。
-(BOOL)scrollViewShouldScrollToTop:(UIScrollView*)scrollView; -(void)scrollViewDidScrollToTop:(UIScrollView*)scrollView; //當(dāng)用戶點(diǎn)出iPhone狀態(tài)條時(shí),滾動(dòng)視圖委托可以決定視圖是否滾動(dòng)回到開頭。
OK,都總結(jié)完了,后面會(huì)寫一個(gè)頁面翻轉(zhuǎn)的例子敬請關(guān)注。
屬性和作用
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。