視錯覺:從一個看似簡單的自訂控制項說起,看似簡單控制項

來源:互聯網
上載者:User

視錯覺:從一個看似簡單的自訂控制項說起,看似簡單控制項

  為什麼要寫今天這篇部落格那就說來話長了,那是在一個大雪紛飛的冬天……然後……。好了,不扯淡了,直接進入今天的主題吧,這篇部落格是關於iOS自訂群組件的東西。一些UI效果看起來似乎是這個樣子,其實本質不是這個樣子。在做一些UI效果時我們可以利用視錯覺的一些東西,讓使用者看到的是一個東西,其實你實現的又是一個東西。原則是想方設法騙過使用者的眼睛。視錯覺如果和UI實現結合起來,有時會產生意想不到的效果。

  一.視錯覺的概述

    引用--“視錯覺就是當人觀察物體時,基於經驗主義或不當的參照形成的錯誤的判斷和感知。視錯:是指 觀察者在客觀因素幹擾下或者自身的心理因素支配下,對圖形產生的與客觀事實不相符的錯誤的感覺。”

    看上面這個解釋似乎有點複雜,其實說白了就是欺騙你自己的眼睛。眼見不一定為實。視錯覺的常用例子:矮中見高、虛中見實、冷調降溫、粗中見細、曲中見直等等常用的手法。說這麼多,接下來我想用一組圖來直觀的感受一下視錯覺。(圖片來源與網路)

    1.這裡不是起點,那裡也不是終點。

  二、一個利用視錯覺的自訂群組件

    當第一次看到這個組件效果時,感覺沒有什麼特別之處,就是一個普通在普通不過的組件。可是再仔細看就感覺不一樣了,一些細節處理的非常好。看到組件效果時,因為沒有源碼,所以當時也不知道如何?的。就想唄,然後就想到了用“視錯覺”這個高大上的東西來實現。當然這個實現方案是我自己想出來的,我不知道原作者是如何?的,下面給出了我自己的實現方案。 說這麼多,先來看一下運行效果吧。

    1. 該組件的運行效果如下,其實就是一個自訂的SegmentControl。看到該組件的時候,我的第一印象是:“這個組件應該挺好做的”。當時感覺就是幾個Button, 然後紅色的是一個UIView, 點擊那個Button時,就把UIView通過動畫的形式移動到當前點擊的Button。頂多就是封裝一下,成為一個自訂群組件,然後給別人使用。

就是在紅色地區中的文字(或文字的一部分)隨著紅色地區的移動,文字的顏色也會隨之部分改變。當紅色地區移動過後,字型顏色又變為原來的了。看到這個效果,對這個組件的崇拜感就油然而生了。瞬間也蒙圈了,一時沒有解決思路。大腦中充滿了無數的問號。這究竟用了什麼黑科技!?實現了這麼NX的效果。晚上做地鐵回家的時候也一直在想其解決方案。果然在地鐵上靈光一現,應該就是用它:“視錯覺”。於是乎就回家晚飯都沒吃,就拿出筆記本開始按著自己的思路去實現。功夫不負有心人呢,所以才有了今天的部落格。當然實現上述效果是我自己的思路,如果還有其他更好的實現方式歡迎交流。

  三、實現原理

    1.原理介紹

    實現上述效果時,如果按著我看到的就是看到的來實現的話,估計會無從下手的。一個原則:“眼見為虛”,就OK了。今天這篇部落格,我不想往上粘貼過多的代碼,還是把我的思路給大家分享一下就好。其實編程這東西,有時候思路比代碼更為重要。下方我想用在Reveal工具上的分析層次來給大家聊一下實現原理。

    通過Reveal上面的UI層次我們很容易看出,這個組件遠比我們想象的要複雜的多。我的實現方式如下:

      (1) 先在View上加上一層的Label, 這些Label用來顯示常規的字型顏色(未選中時的顏色)(黑色的字)

      (2) 在之前的Label上添加一層View , 動畫元素,高亮顯示的字型,點擊的按鈕都在這個View上

      (3) 在這個View上添加一層高亮的Label(白色的字), Label的字型,大小,位置等要和底層的Label一致(除了顏色除外)

      (4) 上層的View的大小要和一個Label的大小一致,並且設定超出View的子視圖不顯示。

      (5) 移動View(紅色部分)時,也要移動View上白色的字。要保持移動的過程中,白色Label和黑色label完全重合。

    這樣View移動到那個label上時,就會把後邊的黑色Label給擋上,顯示的是上面白色的Label.原理大概就是這個原理,原理一旦知道怎麼回事了,至於實現起來就簡單許多了。 

1 // 2 // ZLCustomeSegmentControlView.h 3 // CustomeSegmentControl 4 // 5 // Created by ZeluLi on 15/11/19. 6 // Copyright © 2015年 zeluli. All rights reserved. 7 // 8 9 #import <UIKit/UIKit.h>10 11 typedef void(^ButtonOnClickBlock)(NSInteger tag, NSString * title);12 13 @interface ZLCustomeSegmentControlView : UIView14 15 @property (nonatomic, strong) NSArray *titles; //標題數組16 @property (nonatomic, strong) UIColor *titlesCustomeColor; //標題的常規顏色17 @property (nonatomic, strong) UIColor *titlesHeightLightColor; //標題醒目提示18 @property (nonatomic, strong) UIColor *backgroundHeightLightColor; //高亮時的顏色19 @property (nonatomic, strong) UIFont *titlesFont; //標題的字型大小20 @property (nonatomic, assign) CGFloat duration; //運動時間21 22 /**23 * 點擊按鈕的回調24 *25 * @param block 點擊按鈕的Block26 */27 -(void) setButtonOnClickBlock: (ButtonOnClickBlock) block;28 29 @end

 

   3.該自訂群組件的調用方式

 1     ZLCustomeSegmentControlView *v = [[ZLCustomeSegmentControlView alloc] initWithFrame:CGRectMake(30, 100, SCREEN_WIDTH - 60, 50)]; 2      3     v.titles = @[@"Hello", @"Apple", @"Swift", @"Objc"]; 4     v.duration = 0.7f; 5      6     [v setButtonOnClickBlock:^(NSInteger tag, NSString *title) { 7         NSLog(@"index = %ld, title = %@", (long)tag, title); 8     }]; 9     10     [self.view addSubview:v];

 

    由於某些原因呢,今天部落格中就不一一往上粘貼代碼了。有好的思路歡迎交流~
    上述Demo在GitHub上分享連結如下:https://github.com/lizelu/ZLCustomeSegmentControlView

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.