Close Menu
geekfence.comgeekfence.com
    What's Hot

    Launch of the 52nd Business & Finance Awards in association with KPMG

    May 18, 2026

    How Melbourne’s AI and Data Center Flywheel Is Accelerating Research Innovation

    May 18, 2026

    Submarine Networks EMEA 2026: Bridging the future of AI, security, and next-gen talent in London 

    May 18, 2026
    Facebook X (Twitter) Instagram
    • About Us
    • Contact Us
    Facebook Instagram
    geekfence.comgeekfence.com
    • Home
    • UK Tech News
    • AI
    • Big Data
    • Cyber Security
      • Cloud Computing
      • iOS Development
    • IoT
    • Mobile
    • Software
      • Software Development
      • Software Engineering
    • Technology
      • Green Technology
      • Nanotechnology
    • Telecom
    geekfence.comgeekfence.com
    Home»iOS Development»ClockKit complications cheatsheet – The.Swift.Dev.
    iOS Development

    ClockKit complications cheatsheet – The.Swift.Dev.

    AdminBy AdminMay 18, 2026No Comments3 Mins Read2 Views
    Facebook Twitter Pinterest LinkedIn Telegram Tumblr Email
    ClockKit complications cheatsheet – The.Swift.Dev.
    Share
    Facebook Twitter LinkedIn Pinterest Email


    4/28/16 2:20 PM
    · 1 min read


    ClockKit families and templates, there are so many of them. It’s a little bit time consuming if you are looking for the right one.

    The official ClockKit documentation on Apple’s site is well written, but it lacks a generic overview of all the existing complications. I’ve created a little cheatsheet for you to simplify the searching process for the right complication style.

    This cheatsheet supports watchOS 5. In order to get the template name you just have to add up the names in the proper order. Usually left to right, top to bottom. Don’t worry you’ll get it. 😅

    Swift sample code is below the cheatsheet, please scroll! 👇

    ClockKit complications cheatsheet – The.Swift.Dev.

    Feel free to right click and download the cheatsheet image.

    ClockKit code sample in Swift
    This little snippet contains all the ClockKit complication families and templates. 😎

    import ClockKit
    
    class ComplicationDataSource: NSObject, CLKComplicationDataSource {
    
        func getSupportedTimeTravelDirections(
            for complication: CLKComplication,
            withHandler handler: @escaping (CLKComplicationTimeTravelDirections
        ) -> Void) {
            handler([.forward, .backward])
        }
    
        func getCurrentTimelineEntry(
            for complication: CLKComplication,
            withHandler handler: @escaping (CLKComplicationTimelineEntry?) -> Void
        ) {
            let date = Date()
            var template: CLKComplicationTemplate!
    
            switch complication.family {
            case .circularSmall:
                template = CLKComplicationTemplateCircularSmallStackText()
                template = CLKComplicationTemplateCircularSmallStackImage()
    
                template = CLKComplicationTemplateCircularSmallSimpleText()
                template = CLKComplicationTemplateCircularSmallSimpleImage()
    
                template = CLKComplicationTemplateCircularSmallRingText()
                template = CLKComplicationTemplateCircularSmallRingImage()
    
                break;
            case .extraLarge:
                template = CLKComplicationTemplateExtraLargeStackText()
                template = CLKComplicationTemplateExtraLargeStackImage()
    
                template = CLKComplicationTemplateExtraLargeSimpleText()
                template = CLKComplicationTemplateExtraLargeSimpleImage()
    
                template = CLKComplicationTemplateExtraLargeRingText()
                template = CLKComplicationTemplateExtraLargeRingImage()
    
                template = CLKComplicationTemplateExtraLargeColumnsText()
                break;
            case .modularSmall:
                template = CLKComplicationTemplateModularSmallStackText()
                template = CLKComplicationTemplateModularSmallStackImage()
    
                template = CLKComplicationTemplateModularSmallSimpleText()
                template = CLKComplicationTemplateModularSmallSimpleImage()
    
                template = CLKComplicationTemplateModularSmallRingText()
                template = CLKComplicationTemplateModularSmallRingImage()
    
                template = CLKComplicationTemplateModularSmallColumnsText()
                break;
            case .modularLarge:
                template = CLKComplicationTemplateModularLargeTable()
                template = CLKComplicationTemplateModularLargeColumns()
                template = CLKComplicationTemplateModularLargeTallBody()
                template = CLKComplicationTemplateModularLargeStandardBody()
                break;
            case .utilitarianSmall:
                template = CLKComplicationTemplateUtilitarianSmallFlat()
                template = CLKComplicationTemplateUtilitarianSmallSquare()
                template = CLKComplicationTemplateUtilitarianSmallRingText()
                template = CLKComplicationTemplateUtilitarianSmallRingImage()
                break;
            case .utilitarianSmallFlat:
                template = CLKComplicationTemplateUtilitarianSmallFlat()
            case .utilitarianLarge:
                template = CLKComplicationTemplateUtilitarianLargeFlat()
                break;
            case .graphicCorner:
                template = CLKComplicationTemplateGraphicCornerCircularImage()
                template = CLKComplicationTemplateGraphicCornerGaugeText()
                template = CLKComplicationTemplateGraphicCornerGaugeImage()
                template = CLKComplicationTemplateGraphicCornerStackText()
                template = CLKComplicationTemplateGraphicCornerTextImage()
                break;
            case .graphicCircular:
                template = CLKComplicationTemplateGraphicCircularImage()
                template = CLKComplicationTemplateGraphicCircularOpenGaugeImage()
                template = CLKComplicationTemplateGraphicCircularOpenGaugeRangeText()
                template = CLKComplicationTemplateGraphicCircularOpenGaugeSimpleText()
                template = CLKComplicationTemplateGraphicCircularClosedGaugeText()
                template = CLKComplicationTemplateGraphicCircularClosedGaugeImage()
                break;
            case .graphicBezel:
                template = CLKComplicationTemplateGraphicBezelCircularText()
                break;
            case .graphicRectangular:
                template = CLKComplicationTemplateGraphicRectangularLargeImage()
                template = CLKComplicationTemplateGraphicRectangularStandardBody()
                template = CLKComplicationTemplateGraphicRectangularTextGauge()
                break;
            }
            let entry = CLKComplicationTimelineEntry(
                date: date,
                complicationTemplate: template
            )
            handler(entry)
        }
    }
    

    That’s it for now. Time is over. ⏰


    Awesome native Xcode extensions – The.Swift.Dev.

    Share this article

    Thank you. 🙏

    Related posts

    Awesome native Xcode extensions – The.Swift.Dev.

    4/28/16 2:20 PM
    · 1 min read


    ClockKit families and templates, there are so many of them. It’s a little bit time consuming if you are looking for the right one.

    Awesome native Xcode extensions – The.Swift.Dev.

    2/27/18 3:20 PM
    · 3 min read


    Learn how to use Bonjour, with UDP/TCP sockets, streams and how to communicate through CoreBluetooth or the watch APIs.



    Source link

    Share. Facebook Twitter Pinterest LinkedIn Tumblr Email

    Related Posts

    ios – How to achieve a 2 column grid of cards that expand into a full screen view when tapped upon?

    May 17, 2026

    My Outer Loop | Cocoanetics

    May 13, 2026

    Conventions for Xcode – The.Swift.Dev.

    May 12, 2026

    ios – How to add shadow to border?

    May 11, 2026

    Introducing SwiftPorts | Cocoanetics

    May 7, 2026

    Awesome native Xcode extensions – The.Swift.Dev.

    May 6, 2026
    Top Posts

    Understanding U-Net Architecture in Deep Learning

    November 25, 202540 Views

    Redefining AI efficiency with extreme compression

    March 25, 202627 Views

    Hard-braking events as indicators of road segment crash risk

    January 14, 202627 Views
    Don't Miss

    Launch of the 52nd Business & Finance Awards in association with KPMG

    May 18, 2026

    Business & Finance launched 52nd annual Business & Finance Awards, in association with KPMG. The…

    How Melbourne’s AI and Data Center Flywheel Is Accelerating Research Innovation

    May 18, 2026

    Submarine Networks EMEA 2026: Bridging the future of AI, security, and next-gen talent in London 

    May 18, 2026

    Agent Skills Work but the Research Shows Most Teams Are Building Them Wrong – O’Reilly

    May 18, 2026
    Stay In Touch
    • Facebook
    • Instagram
    About Us

    At GeekFence, we are a team of tech-enthusiasts, industry watchers and content creators who believe that technology isn’t just about gadgets—it’s about how innovation transforms our lives, work and society. We’ve come together to build a place where readers, thinkers and industry insiders can converge to explore what’s next in tech.

    Our Picks

    Launch of the 52nd Business & Finance Awards in association with KPMG

    May 18, 2026

    How Melbourne’s AI and Data Center Flywheel Is Accelerating Research Innovation

    May 18, 2026

    Subscribe to Updates

    Please enable JavaScript in your browser to complete this form.
    Loading
    • About Us
    • Contact Us
    • Disclaimer
    • Privacy Policy
    • Terms and Conditions
    © 2026 Geekfence.All Rigt Reserved.

    Type above and press Enter to search. Press Esc to cancel.