iOS開發之UIScrollView詳解_IOS

來源:互聯網
上載者:User

介紹:UIScrollView用於在一個小範圍裡顯示很大的內容的控制項。通過使用者平滑、手捏手勢,在這個小地區裡查看不同內容。是UITableView和UITextView的父類。它是視圖,但是比較特殊,可以看成把它看成2層的結構。上面是它的frame層,跟一般試圖一樣,是它的可見地區,下面層是contentView,可以滑動。

父類UIView方法

複製代碼 代碼如下:

// autoresizingMask - 現在基本棄用,改用autoLayout
typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {
    UIViewAutoresizingNone                 = 0,      //不進行自動調整
    UIViewAutoresizingFlexibleLeftMargin   = 1 << 0, //自動調整與superview左側距離,右側距離保持不變
    UIViewAutoresizingFlexibleWidth        = 1 << 1, //自動調整控制項自身寬度,保證與superview左右距離不變
    UIViewAutoresizingFlexibleRightMargin  = 1 << 2, //自動調整與superview右側距離,左側距離保持不變
    UIViewAutoresizingFlexibleTopMargin    = 1 << 3, //自動調整與superview頂部距離,底部距離保持不變
    UIViewAutoresizingFlexibleHeight       = 1 << 4, //自動調整控制項自身高度,保證與superview上下距離不變
    UIViewAutoresizingFlexibleBottomMargin = 1 << 5  //自動調整與superview底部距離,頂部距離保持不變
};
// transform - 形變屬性【結構體 - 不能直接賦值】
// 絕對位置
CGAffineTransformMakeRotation(CGFloat angle);//旋轉
CGAffineTransformMakeScale(CGFloat sx, CGFloat sy);//縮放
CGAffineTransformMakeTranslation(CGFloat tx, CGFloat ty);//移動
// 增量修改
CGAffineTransformRotation(CGAffineTransform t, CGFloat angle);//旋轉
CGAffineTransformScale(CGAffineTransform t, CGFloat sx, CGFloat sy);//縮放
CGAffineTransformTranslation(CGAffineTransform t, CGFloat tx, CGFloat ty);//移動

UIScrollView中容易混淆的屬性

contentSize 內容尺寸
contentInset 內容邊框尺寸
contentOffset 可視框位移
contentSize、contentInset、contentOffset的區別

UIScrollViewDelegate代理方法

複製代碼 代碼如下:

// 滾動時會調用,任何方式觸發contentOffset變化都會調用,調用頻率高
- (void)scrollViewDidScroll:(UIScrollView *)scrollView;
// 開始拖拽時調用
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView;
// 停止拖拽時調用
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView withDecelerate:(BOOL)decelarate;
// 即將停止滾動時調用(拖拽鬆開後開始減速時調用)
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView;
// 滾動停止時調用,特殊情況:當一次減速動畫尚未結束的時候再次拖拽,didEndDecelerating不會被調用
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView;
// 開始縮放時調用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view;
// 停止縮放時調用
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)scale;
// 正在縮放時調用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView;
UIScrollView基本用法
scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, 320, 460)];
scrollView.backgroundColor = [UIColor redColor];
// 是否支援滑動最頂端
scrollView.scrollsToTop = NO;
scrollView.delegate = self;
// 設定內容大小、內容邊框、可視位移
scrollView.contentSize = CGSizeMake(320, 460*10);
scrollView.contentInset = UIEdgeInsetsMake(0, 50, 50, 0);
scrollView.contentOffset = CGPointMake( 50 , 50 );
// 是否反彈
scrollView.bounces = NO;
// 是否分頁
scrollView.pagingEnabled = YES;
// 是否滾動
scrollView.scrollEnabled = NO;
// 設定捲軸風格
scrollView.indicatorStyle = UIScrollViewIndicatorStyleWhite;
// 設定捲軸邊緣
scrollView.scrollIndicatorInsets = UIEdgeInsetsMake(0, 50, 0, 0);
// 控制是否顯示水平方向的捲軸 
scrollView.showsHorizontalScrollIndicator = NO; 
// 控制是否顯示垂直方向的捲軸 
scrollView.showsVerticalScrollIndicator = YES;
// 設定scrollView縮放的範圍 
scrollView.maximumZoomScale = 2.0; // 最大2倍 
scrollView.minimumZoomScale = 0.5;
// 是否同時運動,lock
scrollView.directionalLockEnabled = YES;
[self.view addSubview:scrollView];

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.