欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS仿微博導航欄動畫(CoreGraphics)的實現(xiàn)方法

 更新時間:2018年07月06日 10:42:42   作者:kirito_song  
這篇文章主要給大家介紹了關(guān)于iOS仿微博導航欄動畫(CoreGraphics)的實現(xiàn)方法,文章最后給出了完整的示例代碼,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

昨天剛做完項目的新版本、除了嘗試一些新的架構(gòu)之外、功能方面并沒什么特別的地方。

但是順手搞了一些還算好玩的東西、其一就是這個導航欄的動畫。

感覺還算簡單易懂、分享一下(其實更多是最近攢了好多封面、不貼出來憋得人難受)。

導航欄動畫.gif

思路

先介紹CA的兩個方法:

基于原始狀態(tài)的位移

CG_EXTERN CGAffineTransform CGAffineTransformMakeTranslation(CGFloat tx,
 CGFloat ty) CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);

基于原始狀態(tài)的形變

CG_EXTERN CGAffineTransform CGAffineTransformScale(CGAffineTransform t,
 CGFloat sx, CGFloat sy) CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);

知道了這兩個方法、剩下就是如何使用形變和位移以達到想要的效果了。

這里、需要分兩部分來看、一部分是位移、一部分是形變
而且、如果將一整個動畫以及翻頁動作看成1。那么位移和形變又需要分成兩部分來看:0到0.5以及0.5到1。

其實一點都不難、畫個圖看一眼。連一元方程都不算、完全是小學算術(shù)題~甚至連奧數(shù)都算不上。

0到0.5區(qū)間內(nèi)

先看形變

在0.5時、我們需要將線條長度從left_width形變成max_width


再看位移

與此同時如果想讓線條在左側(cè)看起來并沒有移動、就需要將線條的x軸一點點向右移動。這個移動的值呢?

由于形變是雙向的、右側(cè)和左側(cè)都會變長。那么對于左側(cè)最終將是中間時最終形變差值的一半。

具體到數(shù)值:

最左側(cè)到中心點時x軸的位移 = 最左側(cè)到中心點時形變的差值/2 = (max_width - left_width)/2

0.5到1區(qū)間內(nèi)

依舊先看形變

和之前的形變相同


形變-0.5到1

然后來看位移

同理、如果我的長度減少了X、那么我如果想保證看起來右側(cè)位置不會改變、考慮到形變是左右同時發(fā)生、就需要向右移動X/2。

具體到數(shù)值:

中心點到最右側(cè)時x軸的位移 = 中心點到最右時形變的差值/2 = (max_width - right_width)/2

具體函數(shù)

以我項目里兩個按鈕(self.titleBtn1/self.titleBtn2)為例

if (0 <= offsetRate && offsetRate <= 0.5) {
  /*
   * 左側(cè)與中間相互移動
   */
  
  //x軸位移 :: 中間時位移 * 偏移比例系數(shù)
  CGFloat translationOfX = _translationofX_center * offsetRate * 2;
  self.line.transform = CGAffineTransformMakeTranslation(translationOfX, 0);
  
  //x軸形變 :: 1 + (最大時相對形變) * 偏移比例系數(shù)
  CGFloat flagScale = 1 + (_flagScale_center - 1) * (offsetRate * 2);
  self.line.transform = CGAffineTransformScale(self.line.transform, flagScale, 1);
  
 }else if (0.5 < offsetRate && offsetRate <= 1) {
  /*
   * 中間與右側(cè)相互移動
   */
  
  //x軸位移 :: 中間時位移 + 最終位移 * 偏移比例系數(shù)
  CGFloat translationOfX = _translationofX_center + _translationofX_right * (offsetRate - 0.5) * 2;
  self.line.transform = CGAffineTransformMakeTranslation(translationOfX, 0);
  
  //x軸形變 :: 最大時形變 - (最大形變 - 最終形變) * 偏移比例系數(shù)
  CGFloat flagScale = _flagScale_center - (_flagScale_center - _btn2Width/_btn1Width) * (offsetRate - 0.5) * 2;

  self.line.transform = CGAffineTransformScale(self.line.transform, flagScale, 1);
 }

其中的某些參數(shù)的意義以及取值:

{
 //整體最大寬度
 CGFloat _maxWidth;
 //位于左側(cè)時寬度
 CGFloat _btn1Width;
 //位于右側(cè)時寬度
 CGFloat _btn2Width;
 //從左側(cè)移到中心時x軸位移
 CGFloat _translationofX_center;
 //從中心移到右側(cè)時x軸位移
 //所以總位移就是_translationofX_center+_translationofX_right
 CGFloat _translationofX_right;
 //位于中心時形變
 CGFloat _flagScale_center;
}

{
 _btn1Width = self.titleBtn1.width;
 _btn2Width = self.titleBtn2.width;
 _maxWidth = self.titleBtn2.right - self.titleBtn1.left;
 _translationofX_center = (_maxWidth - _btn1Width)/2;
 _translationofX_right = (_maxWidth - _btn2Width)/2;
 _flagScale_center = _maxWidth/_btn1Width;
 self.line.frame = CGRectMake(self.titleBtn1.left, self.height, self.titleBtn1.width, 1);
}

將屏幕滑動的偏移量傳遞進來

#pragma mark UIScrollViewDelegate
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
 
 CGFloat offsetX = scrollView.contentOffset.x;
 CGFloat offsetRate = offsetX/BSScreen_Width;
 

 //將偏移率傳遞給navView
 
 [self.navView configLingWithOffsetRate:offsetRate];
}

Demo

上面的例子的代碼其實都已經(jīng)列出來了、沒什么再單獨傳Demo的必要。

但是畢竟開了個帖子、連個Demo都沒有不好看。于是上午干脆封裝了一個小工具出來。

但是只封裝了移動的動畫、并沒封裝按鈕變色等等一系列功能。


用起來也挺簡單的、只要將按鈕的數(shù)組、下方橫線交付、在屏幕滑動的時候把偏移量傳遞進去、就能自動工作了。寬度啊什么都會自己算:

@interface KTNavScrollTool : NSObject


/**
 初始化

 @param titleArr 按鈕數(shù)組
 @param line 需要移動的橫線
 @return 實例對象
 */
- (instancetype)initWithTitleArr:(NSArray<UIView *> *)titleArr line:(UIView *)line;


/**
 移動的函數(shù)

 @param offsetRate scrollview滾動式的偏移量的比例
 */
- (void)configLingWithOffsetRate:(CGFloat)offsetRate;
@end

GitHub有興趣可以自取  (本地下載

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • iOS自帶原生二維碼掃描的實現(xiàn)

    iOS自帶原生二維碼掃描的實現(xiàn)

    最近項目中需要做一個二維碼掃描,雖然有很多二維碼掃描的第三方可以用,但是考慮到項目中的需要,所以我放棄了使用三方庫,而采用了蘋果原生的掃描。下面這篇文章就介紹了iOS自帶原生二維碼掃描的實現(xiàn),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • iOS archive保存圖片到本地的方法

    iOS archive保存圖片到本地的方法

    這篇文章主要為大家詳細介紹了iOS archive保存圖片到本地的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • iOS實現(xiàn)聊天輸入框功能

    iOS實現(xiàn)聊天輸入框功能

    大家都經(jīng)常使用微信聊天功能,在沒事的時候就會想微信聊天輸入框的實現(xiàn)過程,很無聊吧。今天小編抽空給大家分享iOS實現(xiàn)聊天輸入框功能,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-02-02
  • 使用設(shè)計模式中的Singleton單例模式來開發(fā)iOS應(yīng)用程序

    使用設(shè)計模式中的Singleton單例模式來開發(fā)iOS應(yīng)用程序

    這篇文章主要介紹了使用設(shè)計模式中的Singleton單例模式來開發(fā)iOS應(yīng)用程序的例子,示例代碼為傳統(tǒng)的Objective-C語言,需要的朋友可以參考下
    2016-03-03
  • iOS利用余弦函數(shù)實現(xiàn)卡片瀏覽工具

    iOS利用余弦函數(shù)實現(xiàn)卡片瀏覽工具

    這篇文章主要為大家詳細介紹了iOS利用余弦函數(shù)實現(xiàn)卡片瀏覽工具,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • iOS中UIAlertController設(shè)置自定義標題與內(nèi)容的方法

    iOS中UIAlertController設(shè)置自定義標題與內(nèi)容的方法

    UIAlertController是iOS8推出的新概念,取代了之前的 UIAlertView和UIActionSheet(雖然現(xiàn)在仍可以使用,但是會有警告)。下面這篇文章主要給大家介紹了關(guān)于iOS中UIAlertController如何設(shè)置自定義標題與內(nèi)容的相關(guān)資料,需要的朋友可以參考下。
    2017-10-10
  • 簡單說說iOS之WKWebView的用法小結(jié)

    簡單說說iOS之WKWebView的用法小結(jié)

    iOS8.0之后我們使用 WebKit框架中的WKWebView來加載網(wǎng)頁。這篇文章主要介紹了簡單說說iOS之WKWebView的用法小結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • iOS判斷運營商類型的實現(xiàn)方法

    iOS判斷運營商類型的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猧OS判斷運營商類型的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • IOS開發(fā)中延遲執(zhí)行和取消

    IOS開發(fā)中延遲執(zhí)行和取消

    這篇文章主要介紹了IOS開發(fā)中延遲執(zhí)行和取消的相關(guān)資料,需要的朋友可以參考下
    2018-01-01
  • 清除WKWebView cookies的方法

    清除WKWebView cookies的方法

    下面小編就為大家?guī)硪黄宄齏KWebView cookies的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04

最新評論