一個(gè)方法搞定iOS下拉放大及上推縮小
下面這種效果在ios應(yīng)用中很常見(jiàn):

實(shí)現(xiàn)思路:
1、創(chuàng)建頭部的視圖和tableview,需要注意的是tableview要設(shè)置contentInset,contentInsent 的頂部要和頭部視圖的背景圖的高度一樣,否則會(huì)有空隙(或是有遮擋)。
myTableView.contentInset = UIEdgeInsetsMake(headRect.size.height-navHeight-navHeight, 0, 0, 0);
2、對(duì)頭部視圖的背景圖片的尺寸進(jìn)行處理,當(dāng)然,你也可以直接找一個(gè)適合尺寸的圖片,就不用處理圖片了,為了增加程序的擴(kuò)展性,我就隨便選了張圖,并進(jìn)行圖片尺寸處理。
UIImage * image = [UIImage imageNamed:name]; UIImage * newImg = [self image:image byScalingToSize:self.bounds.size]; backgroundView.image = newImg; backgroundView.clipsToBounds = YES;//切掉圖片多余的部分
//處理圖片方法
- (UIImage *)image:(UIImage*)image byScalingToSize:(CGSize)targetSize {
UIImage *sourceImage = image;
UIImage *newImage = nil;
UIGraphicsBeginImageContext(targetSize);
CGRect thumbnailRect = CGRectZero;
thumbnailRect.origin = CGPointZero;
thumbnailRect.size.width = targetSize.width;
thumbnailRect.size.height = targetSize.height;
[sourceImage drawInRect:thumbnailRect];
newImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return newImage ;
}
3.搞定了這些,準(zhǔn)備工作就完成了,接下來(lái),一個(gè)方法實(shí)現(xiàn)我們的下拉放大、上推縮小的功能,當(dāng)然,重點(diǎn)和難點(diǎn)是邏輯,技術(shù)很easy。大家都知道UITableView是繼承UIScrollView的,利用UIScrollView的代理方法- (void)scrollViewDidScroll:(UIScrollView *)scrollView;來(lái)實(shí)現(xiàn)。
下拉放大
在這個(gè)方法中,我們將功能分為兩部分,一個(gè)是下拉放大,這個(gè)是比較容易的,就是對(duì)頭部視圖的背景圖進(jìn)行放大,調(diào)整frame,需要注意的是在此需要調(diào)整圖片的顯示方式,因?yàn)橄吕蜕贤浦袌D片顯示的方式是不同的,否則即使你調(diào)整了frame,也不會(huì)按frame來(lái)顯示的。
_myView.backgroundView.contentMode = UIViewContentModeScaleToFill; _myView.backgroundView.frame = CGRectMake(offset_Y*0.5 , -navHeight, VCWidth - offset_Y, headRect.size.height - offset_Y);
上推移動(dòng)縮小
這個(gè)就比較難理解了,當(dāng)然,我說(shuō)的是中間對(duì)frame的算法,我們將三個(gè)視圖分開(kāi)說(shuō)。
1.背景圖:先切換顯示模式,然后將y隨著tableview偏移移動(dòng)到0,高度也是隨著tableview偏移,最終移動(dòng)到需要的高度(Demo留的是44)
_myView.backgroundView.contentMode = UIViewContentModeTop; _myView.backgroundView.frame = CGRectMake(0 ,navHeight* offset_Y/(headRect.size.height-navHeight-navHeight)-navHeight; , VCWidth , headRect.size.height -(navHeight + navHeight* offset_Y/(headRect.size.height-navHeight-navHeight)-navHeight;) - offset_Y);
2.頭像:頭像需要隨著tableview的偏移而移動(dòng)自身的位置,并且還要進(jìn)行縮小。這里面就是一個(gè)線性方程的關(guān)系,和上面的的背景圖是一樣的。
CGFloat width = offset_Y*(40-(VCWidth / 4))/(headRect.size.height-navHeight-navHeight)+(VCWidth / 4); _myView.headView.frame =CGRectMake(0, 0, width,width); _myView.headView.layer.cornerRadius =width*0.5; _myView.headView.center = _myView.backgroundView.center;
3.簽名:簽名比較簡(jiǎn)單,只要跟著頭像動(dòng)就行,然后再根據(jù)偏移調(diào)整自己的透明度就行了。
_myView.signLabel.frame =CGRectMake(0, CGRectGetMaxY(_myView.headView.frame), VCWidth, 40); _myView.signLabel.alpha = 1 - (offset_Y*3 / (headRect.size.height-navHeight-navHeight) /2);
好了,然后就大功告成了,里的的邏輯挺麻煩的,但有初中的數(shù)學(xué)水平就夠了,因?yàn)槎贾皇呛?jiǎn)單的線性關(guān)系。希望本文給大家學(xué)習(xí)IOS開(kāi)發(fā)有所幫助。
- 舉例講解iOS中延遲加載和上拉刷新/下拉加載的實(shí)現(xiàn)
- iOS開(kāi)發(fā)中視圖的下拉放大和上拉模糊的效果實(shí)現(xiàn)
- iOS實(shí)現(xiàn)頂部標(biāo)簽式導(dǎo)航欄及下拉分類(lèi)菜單
- iOS編寫(xiě)下拉刷新控件
- iOS開(kāi)發(fā)之tableView點(diǎn)擊下拉擴(kuò)展與內(nèi)嵌collectionView上傳圖片效果
- iOS開(kāi)發(fā)之UITableView與UISearchController實(shí)現(xiàn)搜索及上拉加載,下拉刷新實(shí)例代碼
- IOS代碼筆記之下拉菜單效果
- iOS實(shí)現(xiàn)MJRefresh下拉刷新(上拉加載)使用詳解
- iOS下拉選擇菜單簡(jiǎn)單封裝
- iOS DropDown下拉按鈕效果代碼分享
相關(guān)文章
NSURLSession跨域重定向透?jìng)鱄TTP Header問(wèn)題解決
這篇文章主要為大家介紹了NSURLSession跨域重定向透?jìng)鱄TTP Header問(wèn)題解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
IOS 禁止縮放頁(yè)面的實(shí)現(xiàn)方法
這篇文章主要介紹了IOS 禁止縮放頁(yè)面的實(shí)現(xiàn)方法的相關(guān)資料,這里主要介紹了IOS 10如何通過(guò)設(shè)置來(lái)實(shí)現(xiàn)禁止縮放及實(shí)現(xiàn)方法,需要的朋友可以參考下2017-07-07
IOS開(kāi)發(fā)第三方語(yǔ)音-微信語(yǔ)音
微信語(yǔ)音開(kāi)放平臺(tái)致力于為開(kāi)發(fā)者提供免費(fèi)的語(yǔ)音技術(shù),目前已經(jīng)開(kāi)放的語(yǔ)音技術(shù)包括在線語(yǔ)音識(shí)別、在線語(yǔ)音合成等,下面通過(guò)本篇文章給大家介紹IOS開(kāi)發(fā)第三方語(yǔ)言-微信語(yǔ)言,需要的朋友可以一起來(lái)學(xué)習(xí)下2015-08-08
iOS 開(kāi)發(fā)中 NavigationController經(jīng)常出現(xiàn)的問(wèn)題原因分析
這篇文章主要介紹了iOS 開(kāi)發(fā)中 NavigationController經(jīng)常出現(xiàn)的問(wèn)題原因分析的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
iOS仿網(wǎng)易新聞滾動(dòng)導(dǎo)航條效果
這篇文章主要為大家詳細(xì)介紹了iOS仿網(wǎng)易新聞滾動(dòng)導(dǎo)航條效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
IOS中無(wú)限滾動(dòng)Scrollview效果
這篇文章主要為大家詳細(xì)介紹了IOS中無(wú)限滾動(dòng)Scrollview效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02
iOS11&iPhoneX適配&Xcode9打包注意事項(xiàng)
這篇文章主要介紹了iOS11&iPhoneX適配&Xcode9打包注意事項(xiàng),需要的朋友可以參考下2017-10-10
iOS開(kāi)源一個(gè)簡(jiǎn)單的訂餐app UI框架
這篇文章主要介紹了iOS開(kāi)源一個(gè)簡(jiǎn)單的訂餐app UI框架,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
iOS App開(kāi)發(fā)中UITextField組件的常用屬性小結(jié)
這篇文章主要介紹了iOS App開(kāi)發(fā)中UITextField組件的常用屬性小結(jié),文中還介紹了UITextField隱藏鍵盤(pán)及為內(nèi)容增加校驗(yàn)的兩個(gè)使用技巧,需要的朋友可以參考下2016-04-04

