SwiftUI:看我展現52張撲克牌,「很快啊!」

思路

使用 SwiftUI 建立 UI 結構;git

使用 swift 的枚舉和結構體實現數據生成,經過 viewModel 整合數據用於展現(交互暫時未作,所以不涉及 MVVM 設計模式中的數據綁定)。github

效果圖

畫布實時預覽 iphone 效果圖:編程

截屏2020-11-20 下午6.00.37

運行 iphone11 黑暗模式效果圖:swift

Simulator Screen Shot - iPhone 11 - 2020-11-25 at 11.25.13

運行 ipad air 模擬器效果圖:設計模式

Simulator Screen Shot - iPad Air (4th generation) - 2020-11-23 at 11.42.50

相關代碼解析

枚舉建立撲克牌號碼

//CaseIterable:當須要對枚舉進行遍歷時,須要遵照 CaseIterable 協議,而後對枚舉的 allCases 類屬性進行遍歷便可
enum Rank:Int, CaseIterable {
    case ace = 1
    
    //未指定肯定值的類別,默認值是「依次」加1,所以,two 的 rawValue 爲2,three 的 rawValue 爲 3,以此類推
    case two,three,four,five,six,seven,eight,nine,ten
    case J,Q,K
    
    //swift的枚舉,能夠自定義方法。寫代碼時,「很快啊!」
    func customDescription()->String{
        switch self {
        case .ace:
            return "A"
        case .J:
            return "J"
        case .Q:
            return "Q"
        case .K:
            return "K"
        default:
            return "\(self.rawValue)"
        }
    }
}

枚舉建立撲克牌類型

enum CardType: CaseIterable{
    case heart,spades,club,diamond
    
    func customDescription() -> String {
        switch self {
        case .heart:
            
            //command+ctrl+space,快速調出 emoji 窗口,能夠搜索,"很6啊!"
            return "♥️"
        case .spades:
            return "♠️"
        case .club:
            return "♦️"
        default:
            return "♣️"
        }
    }
}

viewModel邏輯

struct GameVM {
    
    /// 聲明爲 private,符合封裝的思想,經過方法初始化時,必須是類方法(static func)!若是用實例方法,建立實例時,屬性還未初始化,不符合語法!
    private var model:GameM = generateGame()
    
    //數組的泛型不能直接聲明爲 Card 類型,會提示找不到。須要經過結構體名點出來!
    var cards: Array<GameM.Card> {
        return model.cards
    }
     
    static func generateGame()->GameM{
        var lArr: Array<GameM.Card> = Array<GameM.Card>()
        
        //兩個循環就建立好了數據源,"很快啊!"
        for type in CardType.allCases {
            for rank in Rank.allCases{
                lArr.append(GameM.Card(rank: rank, type:type))
            }
        }
        return GameM(cards: lArr)
    }
}

UI實現

/// 聲明式UI編程,"很快啊!"
struct ContentView: View {
    var viewModel: GameVM
    
    var body: some View {
        let columnNum = 4
        let rowNum = viewModel.cards.count/columnNum
        
        return
            HStack{
                ForEach(0..<columnNum){column in
                    VStack{
                        ForEach(0..<rowNum){row in
                            let index = (rowNum) * column + row
                            let card = viewModel.cards[index]
                            Card(cardM:card)
                        }
                    }
                }
            }.padding()
    }
}

源碼

FullDeckOfCards_SwiftUI數組

感覺

swift 語法在構建數據類型時比 OC 方便太多了,枚舉和結構體(值類型,copy-on-write)都很強大。微信

非共享數據優先使用結構體,類通常只用於 viewModel,用於數據共享給多個 view。app

SwiftUI 使用聲明式方法構建 UI,代碼方面簡潔了不少,一套代碼,三端適用(iOS,iPadOS,macOS(M1))。並且支持實時預覽,大大提升了 UI 開發效率!iphone

距離 APP 支持最低版本 iOS13 應該也不遠了(微信目前最低支持 iOS11.0),iOSer 們,是時候學習一波 SwiftUI 了!隨便再溫習下 swift 相關語法。oop

展望將來,iOSer 們實現需求起來,終於能夠大喊:"很快啊!"

自娛自樂:

剛纔有個朋友問我,"OC老師"發生什麼事了,我說怎麼回事,給我發了幾張截圖,我一看,嗷,原來是昨天,有兩個年輕人,實現需求,一個用時九十多分鐘,一個用時八十多分鐘......

可是不要緊啊,我兩百分多鐘之後,需求也作好了。我說 Kotlin 你不講武德,你不懂,他說 "OC 老師"對不起,我不懂,我亂打的,後來他說他練過三四年 Java,看來是有 bear 而來,這個年輕人不講發德,來,騙,來,偷襲,我二十九歲+的老同志,這好嗎?這很差,我勸,這位年輕人好自爲之,好好反思,之後不要再犯這樣的錯誤,小聰明啊,開發要以和爲貴,要講發德,不要搞窩裏鬥,謝謝朋友們。

歡迎掃描下面二維碼,關注我,謝謝!

qrcode_for_gh_b4657e673349_258

相關文章
相關標籤/搜索