在 iOS 里 100% 還原 Sketch 實現的陰影效果

来源:https://www.cnblogs.com/Julday/archive/2020/05/06/12836379.html
-Advertisement-
Play Games

還原不了設計師視覺稿的開發者不是一個合格的頁面仔。 Sketch 是 APP 設計的神器,大部分設計師都選擇它作為 APP 界面的設計工具。 在 Sketch 里設置一個陰影,效果圖和參數如下: 開發實現 在 iOS 里實現陰影的方式是使用 UIView 的 layer 屬性。 layer 里與陰影 ...


還原不了設計師視覺稿的開發者不是一個合格的頁面仔。

Sketch 是 APP 設計的神器,大部分設計師都選擇它作為 APP 界面的設計工具。

在 Sketch 里設置一個陰影,效果圖和參數如下:

 

 

 

 

開發實現

在 iOS 里實現陰影的方式是使用 UIView 的 layer 屬性。

layer 里與陰影有關的設置是以下幾個屬性:

  • shadowPath
  • shadowColor
  • shadowOpacity
  • shadowOffset
  • shadowRadius

與 Sketch 里陰影參數的對應關係是:

  • shadowPath ~> 陰影的範圍
  • shadowColor ~> 陰影的顏色
  • shadowOpacity ~> 陰影的透明度
  • shadowOffset ~> X 和 Y
  • shadowRadius ~> 陰影的模糊

 

 

根據上圖的對應關係,在代碼里實現就是(shadowView 的大小是 100x100):

 

 

以上代碼運行的效果如下:

 

 

100% 還原了 Sketch 的設計,完美了。

值得一提的是:layer 陰影和圓角是可以共存的,而且陰影路徑也需要考慮圓角的值。

為了使用方便,為 CALayer 添加一個設置陰影的擴展:

 

 

使用很簡單,傳入的值和 Sketch 里的陰影參數一樣就行:


 

推薦

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

-Advertisement-
Play Games
更多相關文章
  • Kylin on HBase 方案經過長時間的發展已經比較成熟,但也存在著局限性,因此,Kyligence 推出了 Kylin on Parquet 方案。通過標準數據集測試,與仍採用 Kylin on HBase 方案的 Kylin 3.0 相比,Kylin on Parquet 的構建引擎性能有... ...
  • 一開始我就以為 oplog 應該就類似於 mysql bin-log 而事實上,確實差不多。oplog 也是用於複製集間由 Primary 記錄,Secondary 用來同步。從而保持數據一致。 最近遇到了誤刪db(刪庫不能跑路)的事情,所以,實驗了N多次的 oplog 恢複數據。 特地記錄一下,以 ...
  • 4.1 字典數據結構 typedef struct dict{ //類型特定函數 dictType *type; //私有數據 void *privateata; //哈希表 dictht ht[2]; //rehash 索引,rehash未進行時,值為-1 int rehashidx;}dict; ...
  • 表結構 student(StuId,StuName,StuAge,StuSex) 學生表 teacher(TId,Tname) 教師表 course(CId,Cname,C_TId) 課程表 sc(SId,S_CId,Score) 成績表 問題四:查詢姓“李”的老師的個數 SELECT COUNT( ...
  • 一、什麼是事務? 資料庫事務(Transaction)是訪問並可能操作各種數據項的一個資料庫操作序列,這些操作要麼全部執行,要麼全部不執行,是一個不可分割的工作單位。事務由事務開始與事務結束之間執行的全部資料庫操作組成。 例如:從A賬號給B賬號轉帳,對應於如下兩條sql語句 update from ...
  • 本文選自《實時流計算系統設計與實現》 文末有驚喜 狀態管理是流計算系統的核心問題之一。在實現流數據的關聯操作時,流計算系統需要先將視窗內的數據臨時保存起來,然後在視窗結束時,再對視窗內的數據做關聯計算。在實現時間維度聚合特征計算和關聯圖譜特征計算時,更是需要創建大量的寄存用於記錄聚合的結果。而CEP ...
  • @2020.5.5 練習:賬號信息表,用戶組,主機表,主機組 ...
  • 說到iOS,要麼公司規模比較小,<=3人,不需要面試。 其他的,大概率要讓你刀槍棍棒十八般武藝都拿出來耍耍。 而其中,但凡敵軍陣營中有iOSer的,又極大概率會考到 Runtime 的知識點。 以下,是一題 sunnyxx的一道 runtime 考題,給大伙練練手,如果掌握了,Runtime層面的初 ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...