Sagit.Framework For IOS 開發框架入門開發教程2:一行代碼實現引導頁

来源:http://www.cnblogs.com/cyq1162/archive/2017/12/18/8057611.html
-Advertisement-
Play Games

第二篇教程之前寫了一半,感覺不太好寫,而且內容單純介紹API,要說的很多,又枯燥乏味。所以那半篇文章就放下了。後來又開始思考這教程該怎麼寫,經過幾天的沉澱,終於有了一個決定:這個教程,就用IT戀里的實例來和大伙分享了,看看在實戰是怎麼被應用的。 ...


前言:

開篇比較簡單:Sagit.Framework For IOS 開發框架入門開發教程1:框架下載與環境配置

第二篇教程之前寫了一半,感覺不太好寫,而且內容單純介紹API,要說的很多,又枯燥乏味。

所以那半篇文章就放下了。

後來又開始思考這教程該怎麼寫,經過幾天的沉澱,終於有了一個決定:

這個教程,就用IT戀里的實例來和大伙分享了,看看在實戰是怎麼被應用的。

這篇文章分兩部分,前面講實戰的應用,後面補充框架設計原理,及未來設想的擴展等。

Sagit 實現引導頁功能:

1:首先,我們要有N張引導頁的圖片

IT戀里就放有3張了,如下(這裡圖片把翻頁的效果直接帶上了,我們就省點事了):

2:然後,邏輯與代碼:

邏輯流程:

AppDelegate啟動時=》檢測如果是第一次啟動App=》WelcomeController(歡迎引導頁)

if([ITGlobal share].IsFirstRun)
    {
        //歡迎界面
        self.window.rootViewController = [WelcomeController new];
    }
    else if (launchOptions) {}

滑動顯示三張圖片之後,最後一張觸發點擊事件,根據條件進入以下界面:

A:(更新App時)存在Token,跳轉到:MainController(主界面)

B:(第一次時)無Token時,跳轉到:StartController(登陸註冊引導界面)

然後就是核心的一行代碼實現功能了,一切都來的這麼簡單輕鬆:

[[self.view addScrollView:nil direction:X imgName:@"welcome_1", @"welcome_2", @"welcome_3", nil].lastSubView click:name];

Sagit 框架原理解說:

1:Controller載入View的原理:

在往上看的第一張圖中,註意細節:

A:可以看到引導歡迎界面,只有一個WelcomeController,木有WelcomeView。

B:而引導註冊界面,有和StartController對應的StartView。

這個功能是我這兩天增加的,主要是考慮到當View里的代碼極少時,節省文件的同時,也更簡潔。

所以,目前Controller檢測載入View的流程是:

@implementation STController

- (void)viewDidLoad {
    [super viewDidLoad];//獲取當前的類名
    NSString* className= NSStringFromClass([self class]);
    NSString* viewClassName=[className replace:@"Controller" with:@"View"];
    Class viewClass=NSClassFromString(viewClassName);
    if(viewClass!=nil)//view
    {
        self.view=self.stView=[[viewClass alloc] initWithController:self];
        [self.stView initView];
    }
    else
    {
        self.view=[[STView alloc] initWithController:self];//將view換成STView
        [self initUI];
    }
}
//空方法(保留給子類覆蓋)
-(void)initUI{}

代碼讀下來是這樣的:

1: 如果XXXController檢測到存在XXXView,則進行載入,並調用其initView方法(裡面會再調用initUI方法)

--所以框架的預設載入的約定的是XXX名字首碼一樣,就會被載入。 2: 如果檢測不存在,則調用自身的initUI方法(這就是這裡單獨一個WelcomeController存在的原因)。

 

2:UIView的AddUI相關的方法。

框架擴展了UIView,增了常用了組件方法,並對這些組件,進行了些特殊的處理:

-(void)addView:(UIView *)view name:(NSString*)name;
-(UIView*)addUIView:(NSString*)name;
-(UIButton*)addSwitch:(NSString*)name;
-(UIButton *)addStepper:(NSString *)name;
-(UIButton *)addSlider:(NSString *)name;
-(UIButton *)addProgress:(NSString *)name;

-(UILabel*)addLabel:(NSString*)name;
-(UILabel*)addLabel:(NSString*)name text:(NSString*)text;
-(UILabel*)addLabel:(NSString*)name text:(NSString*)text font:(NSInteger)px;
-(UIImageView*)addImageView:(NSString*)name;
-(UIImageView*)addImageView:(NSString*)name imgName:(NSString*)imgName;
-(UIImageView*)addImageView:(NSString*)name imgName:(NSString*)imgName xyFlag:(XYFlag)xyFlag;

-(UITextField*)addTextField:(NSString*)name;
-(UITextField*)addTextField:(NSString*)name placeholder:(NSString*)placeholder;
-(UITextView*)addTextView:(NSString*)name;

-(UIButton*)addButton:(NSString*)name;
-(UIButton*)addButton:(NSString*)name imgName:(NSString*)imgName;
-(UIButton*)addButton:(NSString*)name imgName:(NSString*)imgName buttonType:(UIButtonType)buttonType;
-(UIButton*)addButton:(NSString*)name title:(NSString*)title;
-(UIButton*)addButton:(NSString*)name title:(NSString*)title font:(NSInteger)px;
-(UIButton*)addButton:(NSString*)name title:(NSString*)title font:(NSInteger)px buttonType:(UIButtonType)buttonType;
-(UIButton*)addButton:(NSString*)name title:(NSString*)title font:(NSInteger)px imgName:(NSString*)imgName buttonType:(UIButtonType)buttonType;
-(UIView*)addLine:name color:(id)colorOrHex;
-(UIScrollView*)addScrollView:(NSString*)name;
-(UIScrollView *)addScrollView:(NSString*)name direction:(XYFlag)direction imgName:(NSString*)imgName,...NS_REQUIRES_NIL_TERMINATION;

有些組件目前還沒涉及,後續根據項目情況可能會追加或進一步優化。

這裡先講一下addScrollView的基礎用法:

-(UIScrollView *)addScrollView:(NSString*)name direction:(XYFlag)direction imgName:(NSString*)imgName,...NS_REQUIRES_NIL_TERMINATION;

核心講解:

1:每個UI都有個name屬性,這個name很核心,可以關聯事件,用於尋找UI,也用於對UI取值賦值,如果實在沒用到,可以賦nil。

2:XYFlag 指求滑動是左右的X,還是上下的Y。

3:可以指定一個可追加的圖片名稱,用於載入圖片(內部載入時,會自動根據數據調整ScrollView和圖片的寬高等屬性)。

4:對於一個add的UIView,沒指定xy寬高時,會自動繼承上一個相對視圖的frame屬性,這裡是繼承父視圖,全屏了。

 

3:事件的觸發

AddScrollView只是追加了圖片,並可以滑動,但我們需要對最後一張圖片增加點擊事件:

所以需要先拿到最後一張圖片,框架對UIView擴展了四個屬性:

-(UIView*)lastSubView;
-(UIView*)firstSubView;
-(UIView*)preView;
-(UIView*)nextView;

用於方便拿到子視圖的第一個和最後一個,以及自己同級的上一個和下一個。

接著,是對這個UIView,追加點擊事件。

框架對於UIView擴展了兩種點擊事件的綁定方式:

#pragma mark 擴展系統事件
-(UIView*)click:(NSString*)event;
- (UIView*)addClick:(onClick)block;

click用於指定一個事件的名稱,addClick用於追加一個事件執行的代碼塊。

這裡先講click傳的event名字的尋找事件的流程:

1:先找傳進來的event在所在的Controller中是否有對應的事件,若有,執行,若沒有繼續以下:

2:對event追加尾碼變成eventClick和eventClick:再看有沒有對應的事件,若有,執行,若沒有繼續以下:

3:對event追加尾碼變成EventController,看有沒有對應的控制器,若有,執行預設的open:事件跳轉,若沒有,則無綁定事件。

OK,原理講解到這裡,大伙再重溫一下這行代碼:

[[self.view addScrollView:nil direction:X imgName:@"welcome_1", @"welcome_2", @"welcome_3", nil].lastSubView click:name];

總結:

這些天一直在改進框架,相信隨著框架的不斷完善,可以讓大伙編寫IOS代碼時,變的輕鬆很多!!!

下一篇,我們以跳轉到登陸註冊引導頁為示例,繼續下一篇教程。 

最後,謝謝大伙對Sagit框架和本人IT連創業項目的關註!


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

-Advertisement-
Play Games
更多相關文章
  • SQL Server on Linux也發佈一段時間了,官方上支持Red Hat, SUSE, Ubuntu。手上沒有以上Linux版本,選用了與Red Hat最接近的CentOS7.4來進行安裝和測試。 1. 環境 Linux: CentOS Linux release 7.4.1708 (Cor ...
  • 本文是學習時的自我總結,用於日後溫習。如有錯誤還望諒解,不吝賜教 此處附上部分內容所出博客:http://blog.csdn.net/ymh198816/article/details/51998085 Flume+Kafka+Storm+Redis實時分析系統基本架構 1) 整個實時分析系統的架構 ...
  • 本文是學習時的自我總結,用於日後溫習。如有錯誤還望諒解,不吝賜教 一、安裝方式(內嵌模式,本地模式遠程模式) 安裝環境以及前提說明: Hive是依賴於hadoop系統的,因此在運行Hive之前需要保證已經搭建好hadoop集群環境。 本例中使用的hadoop版本為2.6.1,Hive版本為2.1.1 ...
  • 方法一:添加代理 - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string { NSString *tem ...
  • 推送通知可以在應用沒有啟動或者在後臺運行的時候給用戶一些提示。因此,很多應用開發者和公司用它來推銷自己的產品。通過這個渠道推送自己的產品是不錯的選擇,但是一定要遵守起碼的道德規範(不要在用戶睡覺的時候推送你的通知),否則用戶就會毫不留情地屏蔽你這個應用的通知,甚至卸載你的應用。 一,蘋果究竟有多少個 ...
  • 1、Android系統目前支持的CPU架構:ARMv5、ARMv7、x86、MIPS、ARMv8、MIPS64、x86_64,每一種都關聯著一個ABI(Application Binary Interface) 2、ABI:定義了二進位文件(尤其是.so文件)如何運行在相應系統平臺上,包括使用的指令 ...
  • 問題引入: 有一個下載功能,在Android 5.x設備上運行正常,Android 6.x上運行異常,現象是下載進度卡在0%。 問題排查發現,是sdk的target設置為23導致,修改為21則恢復正常。 這就引出了今天討論的問題:Android中build target,minSdkVersion, ...
  • 一、簡介 什麼是cocoapods?——是OS X和iOS下一個第三方類庫管理工具。通過cocoapods,可以為項目添加“Pods“依賴庫,並且管理其版本。 cocoapods好處: (1)可以方便引入第三方依賴庫,自動完成各種配置:配置編譯階段、連接器選項等。 (2)可以方便查找新的、標準的第三 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...