iOS開(kāi)發(fā)之UIScrollView詳解
介紹:UIScrollView用于在一個(gè)小范圍里顯示很大的內(nèi)容的控件。通過(guò)用戶平滑、手捏手勢(shì),在這個(gè)小區(qū)域里查看不同內(nèi)容。是UITableView和UITextView的父類(lèi)。它是視圖,但是比較特殊,可以看成把它看成2層的結(jié)構(gòu)。上面是它的frame層,跟一般試圖一樣,是它的可見(jiàn)區(qū)域,下面層是contentView,可以滑動(dòng)。
父類(lèi)UIView方法
// autoresizingMask - 現(xiàn)在基本棄用,改用autoLayout
typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {
UIViewAutoresizingNone = 0, //不進(jìn)行自動(dòng)調(diào)整
UIViewAutoresizingFlexibleLeftMargin = 1 << 0, //自動(dòng)調(diào)整與superview左側(cè)距離,右側(cè)距離保持不變
UIViewAutoresizingFlexibleWidth = 1 << 1, //自動(dòng)調(diào)整控件自身寬度,保證與superview左右距離不變
UIViewAutoresizingFlexibleRightMargin = 1 << 2, //自動(dòng)調(diào)整與superview右側(cè)距離,左側(cè)距離保持不變
UIViewAutoresizingFlexibleTopMargin = 1 << 3, //自動(dòng)調(diào)整與superview頂部距離,底部距離保持不變
UIViewAutoresizingFlexibleHeight = 1 << 4, //自動(dòng)調(diào)整控件自身高度,保證與superview上下距離不變
UIViewAutoresizingFlexibleBottomMargin = 1 << 5 //自動(dòng)調(diào)整與superview底部距離,頂部距離保持不變
};
// transform - 形變屬性【結(jié)構(gòu)體 - 不能直接賦值】
// 絕對(duì)位置
CGAffineTransformMakeRotation(CGFloat angle);//旋轉(zhuǎn)
CGAffineTransformMakeScale(CGFloat sx, CGFloat sy);//縮放
CGAffineTransformMakeTranslation(CGFloat tx, CGFloat ty);//移動(dòng)
// 增量修改
CGAffineTransformRotation(CGAffineTransform t, CGFloat angle);//旋轉(zhuǎn)
CGAffineTransformScale(CGAffineTransform t, CGFloat sx, CGFloat sy);//縮放
CGAffineTransformTranslation(CGAffineTransform t, CGFloat tx, CGFloat ty);//移動(dòng)
UIScrollView中容易混淆的屬性
contentSize 內(nèi)容尺寸
contentInset 內(nèi)容邊框尺寸
contentOffset 可視框偏移
contentSize、contentInset、contentOffset的區(qū)別
UIScrollViewDelegate代理方法
// 滾動(dòng)時(shí)會(huì)調(diào)用,任何方式觸發(fā)contentOffset變化都會(huì)調(diào)用,調(diào)用頻率高
- (void)scrollViewDidScroll:(UIScrollView *)scrollView;
// 開(kāi)始拖拽時(shí)調(diào)用
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView;
// 停止拖拽時(shí)調(diào)用
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView withDecelerate:(BOOL)decelarate;
// 即將停止?jié)L動(dòng)時(shí)調(diào)用(拖拽松開(kāi)后開(kāi)始減速時(shí)調(diào)用)
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView;
// 滾動(dòng)停止時(shí)調(diào)用,特殊情況:當(dāng)一次減速動(dòng)畫(huà)尚未結(jié)束的時(shí)候再次拖拽,didEndDecelerating不會(huì)被調(diào)用
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView;
// 開(kāi)始縮放時(shí)調(diào)用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view;
// 停止縮放時(shí)調(diào)用
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)scale;
// 正在縮放時(shí)調(diào)用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView;
UIScrollView基本用法
scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, 320, 460)];
scrollView.backgroundColor = [UIColor redColor];
// 是否支持滑動(dòng)最頂端
scrollView.scrollsToTop = NO;
scrollView.delegate = self;
// 設(shè)置內(nèi)容大小、內(nèi)容邊框、可視偏移
scrollView.contentSize = CGSizeMake(320, 460*10);
scrollView.contentInset = UIEdgeInsetsMake(0, 50, 50, 0);
scrollView.contentOffset = CGPointMake( 50 , 50 );
// 是否反彈
scrollView.bounces = NO;
// 是否分頁(yè)
scrollView.pagingEnabled = YES;
// 是否滾動(dòng)
scrollView.scrollEnabled = NO;
// 設(shè)置滾動(dòng)條風(fēng)格
scrollView.indicatorStyle = UIScrollViewIndicatorStyleWhite;
// 設(shè)置滾動(dòng)條邊緣
scrollView.scrollIndicatorInsets = UIEdgeInsetsMake(0, 50, 0, 0);
// 控制是否顯示水平方向的滾動(dòng)條
scrollView.showsHorizontalScrollIndicator = NO;
// 控制是否顯示垂直方向的滾動(dòng)條
scrollView.showsVerticalScrollIndicator = YES;
// 設(shè)置scrollView縮放的范圍
scrollView.maximumZoomScale = 2.0; // 最大2倍
scrollView.minimumZoomScale = 0.5;
// 是否同時(shí)運(yùn)動(dòng),lock
scrollView.directionalLockEnabled = YES;
[self.view addSubview:scrollView];
相關(guān)文章
深入分析iOS應(yīng)用中對(duì)于圖片緩存的管理和使用
這篇文章主要介紹了iOS應(yīng)用中對(duì)于圖片緩存的管理和使用,實(shí)例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-04-04ios scrollview嵌套tableview同向滑動(dòng)的示例
本篇文章主要介紹了ios scrollview嵌套tableview同向滑動(dòng)的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11IOS 開(kāi)發(fā)之UIView動(dòng)畫(huà)的實(shí)例詳解
這篇文章主要介紹了IOS 開(kāi)發(fā)之UIView動(dòng)畫(huà)的實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07iOS開(kāi)發(fā)藍(lán)牙技術(shù)應(yīng)用增加無(wú)線連接功能
這篇文章主要為大家介紹了iOS開(kāi)發(fā)藍(lán)牙技術(shù)應(yīng)用增加無(wú)線連接功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02iOS開(kāi)發(fā)系列--詳細(xì)講解C語(yǔ)言之存儲(chǔ)方式和作用域
本篇文章主要介紹了iOS開(kāi)發(fā)系列--詳細(xì)講解C語(yǔ)言之存儲(chǔ)方式和作用域,具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11iOS定時(shí)器的選擇CADisplayLink NSTimer和GCD使用
這篇文章主要為大家介紹了iOS定時(shí)器的選擇CADisplayLink NSTimer和GCD使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03實(shí)例講解iOS應(yīng)用UI開(kāi)發(fā)之基礎(chǔ)動(dòng)畫(huà)的創(chuàng)建
這篇文章主要介紹了iOS應(yīng)用UI開(kāi)發(fā)之基礎(chǔ)動(dòng)畫(huà)的創(chuàng)建,以關(guān)鍵幀動(dòng)畫(huà)作為重要知識(shí)點(diǎn)進(jìn)行講解,需要的朋友可以參考下2015-11-11