視錯覺升級版:多個視錯覺效果實現

来源:http://www.cnblogs.com/ludashi/archive/2016/08/10/5671133.html
-Advertisement-
Play Games

之前發表過一篇關於視錯覺的文章:《視錯覺:從一個看似簡單的自定義控制項說起》,雖然不是用iOS開發中的Mask來實現的,但是原理和Mask原理是一樣的,相當於手動給上面一層加了個Mask。當然用mask完全可以實現上篇博客中的效果,無論是使用Mask還是不使用Mask,都是利用了視錯覺,都是兩層不一樣 ...


之前發表過一篇關於視錯覺的文章:《視錯覺:從一個看似簡單的自定義控制項說起》,雖然不是用iOS開發中的Mask來實現的,但是原理和Mask原理是一樣的,相當於手動給上面一層加了個Mask。當然用mask完全可以實現上篇博客中的效果,無論是使用Mask還是不使用Mask,都是利用了視錯覺,都是兩層不一樣的視圖進行疊加而成的。今天這篇博客是視錯覺Demo的升級版,上篇博客發表後,好多小伙伴說使用Mask實現會更容易,其實使用Mask和之前的原理是一樣的。今天我們這篇博客就使用Mask來實現視錯覺的效果,並給出不使用Mask的解決方案。當然今天博客中的內容較多。

一、一些視錯覺經典圖片

在博客的第一部分呢,先放鬆一下,看一些視錯覺的經典圖片,當然下方圖片來源於網路。還是那句話,你的眼睛有時候會欺騙你的,你看到的不一定是你看到的。

1.右下方的人和後方的人大小是一樣的,第一眼我還不信,拿著尺子量了一下,結果是毋庸置疑的。

  

 

2.下方兩個豎直黑線真的是平行的

  

 

3.中間那個框,真的是正方形的

  

就先放這三張視錯覺圖片當開胃菜吧,比較我們今天的主題還是iOS開發,還是代碼。說實話,看這種視錯覺圖片老感覺不舒服呢,越想越彆扭。OK, 第一部分的開胃菜到此為止,更多視錯覺圖片請自行Google

 

二、利用視錯覺實現圖片蒙版

本部分我要實現常見的圖片蒙版,就是你看上去同一張圖片不同的區域會有不同的顏色。這種效果我們經常看到,就是一個圖片有部分區域是彩色的而其他部分則是黑白的。本部分我們先使用Mask來實現這個效果,然後使用自定義蒙版在實現一次。好進入今天的第一個主題。

1.在ImageView上使用Mask

開門見山,下方這個效果就是我們接下來要實現的效果。圓框區域中顯示的圖片是彩色的,圓框外是黑白的。我們可以通過手指移動來變化彩色的區域。下方就是我們要實現的最終效果。

  

還是那句話,你看到的不一定是你看到的。上面的效果,給你的第一感覺是只用一張圖片,然後渲染圓框區域內的部分即可。當然說到這,你就能猜到,上面是使用的兩張圖片來實現的,也就是兩層。這種原理與上篇視錯覺的博客中的原理一致。下方截圖就是上述效果的層級截圖。本質上使用的是兩張圖片,下麵是一個黑白圖片,上面是一個彩色圖片。只不過我們給彩色圖片添加了一個圓形的mask。在這兒簡單的提一下mask吧,其實mask就是給上面的ImageView添加了一個層,然後設置一塊區域,mask區域內是可見的, 而mask區域外是不透明的。所以就會形成上方的效果。

  

實現上述效果是比較簡單的,下方就是上述效果的核心代碼。關鍵還是給上面的ImageView添加Mask。下方代碼就是給上方彩色的ImageView添加mask, 然後在touchesMoved事件中隨著手指的移動來改變mask的位置即可。至此上述這個效果就使用mask實現完畢了。

  

 

2.自定義蒙版

我們不使用系統自帶的Mask也能實現上述效果,而且實現起來並麻煩。該部分的核心主要是利用AutoLayout來實現上述效果。下方是我們使用AutoLayout來實現的上述效果,在下方的效果中,並沒有用到上述的Mask,不過也是手動加了一層蒙版。下方就是我們沒有使用mask的最終效果。效果還是和上方差不多少的。

  

接下來我們來看上面這個效果的視圖層級,這種實現方式的視圖層級與第一部分的視圖層級稍微不同。下方就是該部分效果所對應的視圖層級。雖然也是兩層ImageView,一張載入黑白圖片,一張載入彩色圖片,但是這種視圖結構和上面的是不一樣的。彩色圖片看不見的部分並不是透明的,而是被中間一塊小的View所遮擋了,用戶看到的就是為遮擋的部分,也就是小的View所在的區域。

從下方的視圖層級中我們不難看出,先貼一張黑白照,然後貼一個小的MaskView,在這個小的MaskView上在貼一張彩照,小MaskView的外的區域的彩照是看不見的。關鍵還在於,彩照的絕對坐標要與黑白照的絕對坐標完全重合,為了達到這個效果我們就採用了AutoLayout來實現的。下方會給出核心的實現代碼。

  

看完效果和視圖層級後,接下來來看一下核心代碼的實現,還是那句話核心代碼就是AutoLayout的應用。下方代碼就是上述效果的核心部分。colorImageView也就是我們的彩色圖片是加在小的MaskView上的,也就是上面我們選中的View,不過其約束是添加在整個視圖控制器的self.view上的。黑白照的約束也是self.view, 這樣,彩照和黑白照就會重合。雖然彩照是在小的MaskView上,但是其約束是添加在self.view上的。所以你移動MaskView時,彩照的位置是不會隨MaskView的位置改變而改變的。所以你就儘管在TouchesMoved事件中盡情的修改MaskView的坐標即可。

  

 

三、給Label添加Mask

接下我們將之前的視錯覺的Demo進行重寫,當然我們此處使用的是Swift語言,並使用mask來進行實現。

  

上圖就是我們為我們的Label添加的Mask,添加後,文字就會出現漸變的效果。當然原理是一樣的。下方就是上述效果的視圖層級。也是兩層不同的文字,通過mask來顯示指定區域。當然上面的Hello World是講Mask添加在了Lable上了,而下方的效果是講Mask添加在了上層視圖上,上層視圖的背景色是紅色,上層視圖上貼了一些列的白色Label,當然顯示的只是mask區域內的東西了。

  

接下來來看上述效果的核心代碼。下方代碼就是為我們上層紅色的Hello World添加蒙版,並給蒙版添加一個弧度,所以你看起來的蒙版效果是橢圓形的。而第二種效果是講蒙版添加在了上層的View上,與下方代碼類似,在此就不做過多贅述了,相關代碼會在Github上進行分享。本篇博客後附有github分享鏈接。

  

 

四、上述效果實戰

在項目開發中上述的這種漸變的效果是經常使用到的,接下來就使用上述效果來進行實戰一下。下方這個效果就是利用上述效果寫的一個標簽欄的切換,在切換時,效果是漸變的。並且與下方的ScrollView是聯動的。下方這種形式是比較常見的。

  

接下來我們來看一下上述效果的視圖層級。從下方視圖層級中我們不難看出上面用的就是我們第三部分所封裝的組件,而下方是一個ScrollView上貼了三個View無論上面有多少個Tab標簽,下方的View會進行復用的。下方類似於我們之前所發佈的幻燈片輪播圖的效果。原理請參加《iOS開發之三個Button實現圖片無限輪播(參考手機淘寶,Swift版)》這篇博客,原理在此就不做過多的贅述了。

  

 

通過本篇博客想必你還是有所收穫的,今天博客就先到這。上述所有代碼在Github上的分享地址為https://github.com/lizelu/MaskLayerDemo

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 【scrollTo/scrollBy】 //控制項內的文字會移動,但是控制項本身不會移動,而且移動到控制項之外之後,文字也就看不見了 if(v.equals(button2)){ button2.scrollTo(5, 5); //View內的文字會向左移動5,向上移動5,絕對坐標,只會移動一次 Toas ...
  • 解決辦法:就是把無用的CFBundle刪除掉。 根據提示,找到對應第三方的SDK, 找到第三方的info.plist文件,刪除裡面的Executable file對應的一整行,包括值。 ...
  • Android系統很多,但是最常用的就兩類,一類是有系統進場管理的,系統視窗。還有一類就是由應用程式產生的,應用視窗。 1.系統視窗的添加流程 1.1 addStatusBarWindow PhoneStatus.java中 getStatusBarHeight() 獲取狀態欄的高度 可以看到,高度 ...
  • 前言:由於最近在做SDK的功能,需要設計線程池。看了很多資料不知道從何開始著手,突然發現了AsyncTask有對線程池的封裝,so,就拿它開刀,本文將從AsyncTask的基本用法,到簡單的封裝,再到任務隊列分析,最後自定義線程池。 1、概念 Android 中的非同步任務常用的一種方式是:Handl ...
  • 因項目介面變動,導致之前的CoreData欄位需要調整。於是記錄下出錯的流程和解決方案。步驟如下: 1. 先在 *****.xcdatamodeld 文件中添加需要調整的欄位。並更新本地model實體。 2. 我的流程是接到消息後本地存儲在CoreData裡面,然後UI展示(具體消息推送和接收問題, ...
  • 參考文檔: http://cache.baiducontent.com/c?m=9f65cb4a8c8507ed4fece763105392230e54f73e7e808c027fa2ce0ac4384c413037bee43a7c4b54ce81273044b2141ebdac3574310023 ...
  • 一,代碼。 - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. self.title=@"字元串的分割"; //一般的字元串的解析 NSString *string ...
  • 一、何謂版本控制 它是一種軟體工程籍以在開發的過程中,確保由不同人所編輯的同一檔案都得到更新,它透過文檔控制記錄程式各個模塊的改動,併為每次改動編上序號,並且編輯錯誤之後還可以回溯到以前的版本 二、可供我們選擇的版本控制系統 1、VCS (本地版本控制) 2、VSS、CVS(集中版本控制) 3、Cl ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...