iOS應(yīng)用開發(fā)中UIScrollView滾動(dòng)視圖的基本用法總結(jié)
在項(xiàng)目開發(fā)時(shí)遇到一個(gè)問題,我在UIViewController上面直接創(chuàng)建了一個(gè)UIScrollerView,把UIScrollerView作為一個(gè)子視圖添加到了UIViewController,
又再UIScrollerView中添加了一個(gè)UISlider的組件,在手勢(shì)滑動(dòng)的過程中,很難滑動(dòng)到UISlider這個(gè)控件,經(jīng)常是滑動(dòng)的時(shí)候UIScrollerView進(jìn)行了滾動(dòng),
而UISlider這個(gè)控件沒有滑動(dòng),讓人很抓狂。
上網(wǎng)具體去了解了一下UIScrollerView的詳解,終于徹底明白了問題出在哪里
下面引用一下前輩的總結(jié),因?yàn)樽约河X得沒有他總結(jié)的詳細(xì)
UIScrollView重載了hitTest方法,當(dāng)手指touch的時(shí)候,UIScrollView會(huì)攔截所有event,然后等待150ms,在這段時(shí)間內(nèi),如果沒有手指沒有移動(dòng),當(dāng)時(shí)間結(jié)束時(shí),UIScrollView會(huì)發(fā)送tracking event到子視圖上,并且自身不滑動(dòng)。在時(shí)間結(jié)束前,手指發(fā)生了移動(dòng),那么UIScrollView就會(huì)進(jìn)行滑動(dòng),從而取消發(fā)送tracking。
看來是UIScrollView的問題。直接拖動(dòng)UISlider,此時(shí)touch時(shí)間在150ms以內(nèi),UIScrollView會(huì)認(rèn)為是拖動(dòng)自己,從而攔截了event,導(dǎo)致UISlider接受不到滑動(dòng)的event。但是只要按住UISlider一會(huì)再拖動(dòng),此時(shí)此時(shí)touch時(shí)間超過150ms,因此滑動(dòng)的event會(huì)發(fā)送到UISlider上。
期間試過幾種方法,只有一種可行,就是重寫UIScrollView的hitTest方法:當(dāng)滑動(dòng)UISlider時(shí),使UIScrollView不可滑動(dòng)。
但是又出現(xiàn)了一個(gè)問題,我的UIScrollerView是直接繼承了UIScrollerView,在UIViewController中是無法重寫的UIScrollerView的hitTest方法的,所以需要重新創(chuàng)建一個(gè)view,繼承UIScrollerView,然后再重寫上述方法,然后再導(dǎo)入U(xiǎn)IViewController中就可以輕松實(shí)現(xiàn)了。
下面來看一些UIScrollerView中一些比較常見的用法,說明都包含在注釋中了:
- (void)viewDidLoad
{
[super viewDidLoad];
scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, 320, 460)];
scrollView.backgroundColor = [UIColor redColor];
// 是否支持滑動(dòng)最頂端
// scrollView.scrollsToTop = NO;
scrollView.delegate = self;
// 設(shè)置內(nèi)容大小
scrollView.contentSize = CGSizeMake(320, 460*10);
// 是否反彈
// scrollView.bounces = NO;
// 是否分頁(yè)
// scrollView.pagingEnabled = YES;
// 是否滾動(dòng)
// scrollView.scrollEnabled = NO;
// scrollView.showsHorizontalScrollIndicator = NO;
// 設(shè)置indicator風(fēng)格
// scrollView.indicatorStyle = UIScrollViewIndicatorStyleWhite;
// 設(shè)置內(nèi)容的邊緣和Indicators邊緣
// scrollView.contentInset = UIEdgeInsetsMake(0, 50, 50, 0);
// scrollView.scrollIndicatorInsets = UIEdgeInsetsMake(0, 50, 0, 0);
// 提示用戶,Indicators flash
[scrollView flashScrollIndicators];
// 是否同時(shí)運(yùn)動(dòng),lock
scrollView.directionalLockEnabled = YES;
[self.view addSubview:scrollView];
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 200, 320, 40)];
label.backgroundColor = [UIColor yellowColor];
label.text = @"學(xué)習(xí)scrolleview";
[scrollView addSubview:label];
[label release];
}
#pragma mark -
/*
// 返回一個(gè)放大或者縮小的視圖
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
{
}
// 開始放大或者縮小
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:
(UIView *)view
{
}
// 縮放結(jié)束時(shí)
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale
{
}
// 視圖已經(jīng)放大或縮小
- (void)scrollViewDidZoom:(UIScrollView *)scrollView
{
NSLog(@"scrollViewDidScrollToTop");
}
*/
// 是否支持滑動(dòng)至頂部
- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView
{
return YES;
}
// 滑動(dòng)到頂部時(shí)調(diào)用該方法
- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView
{
NSLog(@"scrollViewDidScrollToTop");
}
// scrollView 已經(jīng)滑動(dòng)
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
NSLog(@"scrollViewDidScroll");
}
// scrollView 開始拖動(dòng)
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
NSLog(@"scrollViewWillBeginDragging");
}
// scrollView 結(jié)束拖動(dòng)
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
NSLog(@"scrollViewDidEndDragging");
}
// scrollView 開始減速(以下兩個(gè)方法注意與以上兩個(gè)方法加以區(qū)別)
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView
{
NSLog(@"scrollViewWillBeginDecelerating");
}
// scrollview 減速停止
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
NSLog(@"scrollViewDidEndDecelerating");
}
- IOS上iframe的滾動(dòng)條失效的解決辦法
- iOS實(shí)現(xiàn)滾動(dòng)字幕的動(dòng)畫特效
- IOS中UITableView滾動(dòng)到指定位置
- iOS ScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路與最佳實(shí)踐
- IOS 的彈性滾動(dòng)解決方案
- iOS使用UICollectionView實(shí)現(xiàn)橫向滾動(dòng)照片效果
- ios之UIScrollerView滾動(dòng)視圖總結(jié)
- iOS Swift UICollectionView橫向分頁(yè)滾動(dòng),cell左右排版問題詳解
- 在IOS系統(tǒng)上滾動(dòng)條滾動(dòng)到指定的位置出現(xiàn)空白頁(yè)面的解決方案
- iOS實(shí)現(xiàn)循環(huán)滾動(dòng)公告欄
相關(guān)文章
iOS中解決Xcode9的Log日志無法輸出中文的問題小結(jié)
這篇文章主要介紹了iOS中解決Xcode9的Log日志無法輸出中文的問題小結(jié),需要的朋友可以參考下2017-11-11
總結(jié)iOS開發(fā)中的斷點(diǎn)續(xù)傳與實(shí)踐
本文先從斷點(diǎn)續(xù)傳問題開始,介紹斷點(diǎn)續(xù)傳概述和原理。接著結(jié)合筆者調(diào)研中嘗試的 AFHTTPRequestOpeartion,簡(jiǎn)單分析源碼。最后分別基于 NSURLConnection,NSURLSessionDataTask 和 NSURLSessionDownloadTask 去實(shí)現(xiàn)應(yīng)用重啟情況下的斷點(diǎn)續(xù)傳。下面一起來看看。2016-07-07
iOS界面布局簡(jiǎn)化UIStackView使用詳解
這篇文章主要為大家介紹了iOS界面布局簡(jiǎn)化UIStackView使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
iOS中UILabel實(shí)現(xiàn)長(zhǎng)按復(fù)制功能實(shí)例代碼
在iOS開發(fā)過程中,有時(shí)候會(huì)用到UILabel展示的內(nèi)容,那么就設(shè)計(jì)到點(diǎn)擊UILabel復(fù)制它上面展示的內(nèi)容的功能,也就是Label長(zhǎng)按復(fù)制功能,下面這篇文章主要給大家介紹了關(guān)于在iOS中UILabel實(shí)現(xiàn)長(zhǎng)按復(fù)制功能的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-10-10

