iOS開發之App主題切換完整解決方案(Swift版)

来源:http://www.cnblogs.com/ludashi/archive/2017/02/20/6289741.html
-Advertisement-
Play Games

本篇博客就來介紹一下iOS App中主題切換的常規做法,當然本篇博客中只是提到了一種主題切換的方法,當然還有其他方法,在此就不做過多贅述了。本篇博客中所涉及的Demo完全使用Swift3.0編寫完成,並使用iOS的NSNotification來觸發主題切換的動作。本篇博客我們先對我們的主題系統進行設 ...


本篇博客就來介紹一下iOS App中主題切換的常規做法,當然本篇博客中只是提到了一種主題切換的方法,當然還有其他方法,在此就不做過多贅述了。本篇博客中所涉及的Demo完全使用Swift3.0編寫完成,並使用iOS的NSNotification來觸發主題切換的動作。本篇博客我們先對我們的主題系統進行設計,然後給出具體實現方式。當然在我們設計本篇博客所涉及的Demo時,我們要遵循“高內聚,低耦合”,“面向介面編程”,“便於維護與擴充”等特點。

本篇博客我們先看一下Demo的運行效果,然後給出設計方案已經對應的類圖,然後再根據設計的類圖給出相應的代碼實現。

 

一、主題切換效果展示

先入為主,接下來我們先看一下本篇博客所涉及Demo的最終運行效果。為了看到整體主題切換的效果,所以我們添加了一個主頁以及主頁Push進去的子頁面。另一個頁面就是選擇相應主題的頁面,也就是下方你所看到的TabieView的列表頁,該列表中提供了6種可選的主題,點擊相應的主題即可切換到該主題上。

當然主題切換,意味著整個App的風格都得改變,所以當修改完主題後,主頁以及其子頁面的主題也得隨之改變。具體效果如下gif圖所示。當然Demo比較簡單,但是麻雀雖小,五臟俱全,用來瞭解App的主題切換足以。當然有更好的實現方式,歡迎留言交流。

  

 

 二、設計主題切換功能的整體結構

看完效果後,接下來我們就進入了設計階段。根據上述Demo的特點,我們先給出相應的類圖,當然我們敲代碼時要根據該類圖進行實現。下方截圖就是我們本篇博客主題切換工程的類圖了。該類圖中省略了一些細節,給出了核心的內容。接下來我們來詳細的看一下下方這個類圖的結構,如果下方的類圖搞明白了,那麼在下部分中看相應代碼時,就會顯得游刃有餘了,因為我們的代碼是按照下方的類圖所實現的。只不過比下方類圖更為詳細。

接下來我們就來看一下類圖的結構,我們就按照不同顏色的框逐一介紹,框中的內容算是一個模塊。

  • 紅色框:下方類圖紅色框中就是我們的主題協議ThemeProtocol以及遵循該協議的所有主題。當然,依據“面向介面”編程的規則,外部所依賴的不是所有的主題類,而是主題協議ThemeProtocol。也就是ThemeManager類依賴於ThemeProtocol。而所有的主題類通過工廠類或者工廠方法間接的與ThemeManager。因為鑒於Swift中的枚舉中可以添加相應的計算屬性以及方法,所以我們可以使用相應的主題枚舉來充當這個工廠類,當然下方類圖中沒有給出,這個要看具體的代碼實現。
  • 藍色框接下來我們就來看藍色框,藍色框中的SuperLabelClass是所有可以改變主題的Label的父類,也就是說在改變主題時,需要改變相應的Label就要繼承該類。
  • 黑色框:該框中中則是SuperViewController及其子類,需要更換主題的VC都要繼承自該基類。
  • 綠色框綠框中則負責修改主題,其中根據Cell的類型來確定用戶選擇的是哪個主題。
  • ThemeManager: 該類以單例的形式存在,負責管理相應的主題,切換主題時,直接調用ThemeManager中的相應的方法即可。

上面只是簡單的介紹一下類圖,具體的還要看代碼的實現。

  

 

 

三、主題以及主題管理者的實現

看完運行效果以及設計類圖,接下來我們就來一下具體的代碼實現本部分我們就來看一下相應的主題類以及主題管理者的代碼實現。下方會先給出主題協議以及各個主題類的實現,然後再給出主題工廠方法以及主題管理者的實現。

 

1、主題協議的實現

下方就是我們定義的主題協議,所有主題都要遵循該協議。因為本篇博客的Demo在切換主題時只涉及到了三個元素,一個是背景色(backgroundColor),一個是標題的顏色(titleTextColor),在一個就是詳情的顏色(detailTextColor)。所以在我們的主題協議中有三個只讀的計算屬性與之對應。具體如下所示:

  

 

2.各個主題的實現

接下來我們就要看看各個主題的實現了,我們就以紅色主題(RedTheme)為例。RedTheme要遵循ThemeProtocol,並且實現協議中規定的方法。在RedTheme中每個計算屬性都會返回當前主題所對應的屬性。具體如下所示。當然其他主題與下方的RedTheme類似,只是每個計算屬性返回的值不同。

  

 

上面在返回UIColor對象時,我們用到了UIColor.colorWithHex(十六進位數)colorWithHex()是我們在UIColor的延展中添加的靜態方法,該方法可以根據十六進位的RGB參數來初始化相應的UIColor對象。下方是該UIColor延展中的具體內容。下方代碼的核心就是位操作的使用。

  

 

3.簡單工廠的創建

主題協議已經主題類構建完畢後,接下來我們就該將這些主題進行打包輸出了。 下方的代碼段本質上就是主題類的簡單工廠,因為Swift的枚舉類型有很多好用的特性,所以我們使用了Swift的枚舉來實現這些主題的簡單工廠。代碼結構比較簡單,在此就不做過多贅述了。

  

 

4.主題管理者(ThemeManager)的創建

上面關於主題的基本工作已經做完,接下來我們就為這些主題來創建一個主題管理者ThemeManager。ThemeManager會根據用戶需求從上面的主題工廠中取出相應的主題對象提供給用戶,這也就是ThemeManager的職能所在。

下方就是我們主題管理者ThemeManager的具體實現代碼,ThemeManager是以單例的姿態對外展現的。因為主題管理者在整個App運行時只需要一個,所以我們賦予了ThemeManager一個單例的身份與用戶進行交流。單例實現完畢後,接著社一些便利方法,這些便利方法都是靜態方法,便於用戶直接使用。接著是一些ThemeManager的私有方法。

ThemeManager的私有方法中,switcherTheme(themeType)是關鍵,該方法在收到修改主題的事件後,會發出修改主題的通知,而通知的內容就是將要進行修改的主題。那些可以修改主題的控制項,在收到該通知的消息後,會根據通知內容修改其自身的主題。具體代碼如下所示:

  

 

四、可更換主題的控制項處理

主題以及主題管理者實現完畢,接下來就該使用了。在主題切換時,需要修改屬性的控制項我們需要進行處理,使其監聽主題切換的通知,並根據通知內容修改控制項的屬性。在本部分我們就以SuperViewController為例。首先我們要將SuperViewController添加為主題切換的觀察者,然後實現收到通知後的方法。在析構函數中,切記要移除觀察者。具體代碼如下所示。

  

 

五、調用ThemeManager更換主題

萬事俱備只欠東風,接下來我們就要在恰當的地方調用ThemeManagerswitcherTheme()的方法進行替換了。當然我們是在我們的Cell來處理的,因為每種cell都對應著主題的類型,下方就是Cell類型的枚舉。CellTitleType中的themeType計算屬性就對應著相應的主題類型,我們可以將該類型提供給ThemeManager,讓後ThemeManager發出更改主題的通知。

  

下方就是調用ThemeManager的switcherTheme()方法來更換主題。

  

 

至此,本篇博客所涉及的主題切換的Demo就介紹完畢了,所涉及的Demo按照慣例,依然會在github上進行分享。下方就是Demo在github上分享地址。

代碼分享地址:https://github.com/lizelu/CEThemeSwitcher

 


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

-Advertisement-
Play Games
更多相關文章
  • 由於新項目的的需求,需要畫環形圖,由於以前都沒接觸過這一類(我是菜鳥),去cocochina山找到了一個案例,個人覺得還可以,分享一下 github 地址https://github.com/zhouxing5311/ZZCircleProgress 這個使用起來非常的簡單 作者開放了很多介面,可以 ...
  • 導語:之前做習慣了Framework層的開發,今天在武漢鬥魚公司面試APP客戶端的開發,其中一道題是講述Asynctask的優缺點,我靠,我只是知道有這麼一個東西,會用而已,看來之前的生活太過於安逸,這麼基礎的東西都不會,特意回家總結下。 轉載請註明原文鏈接:http://www.cnblogs.c ...
  • 寫項目的時候就遇到了這個尷尬的問題,有的是需要進行網路請求的,或者有的手機有點卡頓,用戶就會連續點擊,經常出現的就是接連Push兩個同樣的控制器,當然還有重覆調用網路請求的方法,等等等等。。。。 比較笨的方法就是在每個點擊的地方把用戶交互給關掉,等到功能實現後之後再將這個按鈕的用戶交互恢復。 當然了 ...
  • 很少用DatePicker,項目需要用到DatePicker,再用時發現跟以前有些變化,重新簡單梳理一下DatePicker的用法。 先上效果圖: 首先是xml文件的用法: 以前是用android:spinnersShown和android:calendarViewShown這兩個屬性來控制Date ...
  • 現在做的項目遇到一個問題,設計給過來的圖片只有一種狀態,但是實現的需求是要求有兩個狀態,另一種選狀態為圖片背景加邊框。如圖: 剛開使用使用ImageView ,ImageViewButton 效果不是很明顯; 後來發現 layer-list 能很好的實現這個效果,先分別建 正常模式與選中模式的xml ...
  • 1.概述 在之前的博文中簡單介紹過如何實現fragment之間的信息交互:《Android中Fragment與Activity之間的交互(兩種實現方式)》,今天繼續給大家介紹一種可以實現此效果的另外一種方式EventBus。(相比於handler,介面回調,bundle傳參,這個簡單好用到哭) Ev ...
  • 轉自http://blog.csdn.net/wangyanchang21/article/details/50932191 在很多時候都會遇到錯誤, 還會帶有一些 Error Code , 比如在各種網路請求, 文件操作, cookie 錯誤等各種錯誤的代碼和錯誤代碼對應的含義. 以下目錄為 SO ...
  • 註意:刪除的時候要謹慎!別什麼圖都刪了,看看對項目有沒有作用。這個插件有時也會有一定的誤差。 具體操作步驟: 1.去github上下載LSUnusedResources(下載地址:https://github.com/tinymind/LSUnusedResources/) 2.運行LSUnused ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...