I am trying to build an app that supports multiple complication families on watch OS2 like modular large, utilitarian large, circular small etc, each showing various meaningful information from the app. I know complications is little similar to the glances we have since OS1 in terms of user interaction i.e, it opens the app on user clicking on it and no special interaction over there.
In glance I was able to do a deep link to the app based on current glance content but I am looking for a way to do the same with complications.
So my question is when the user clicks on my app's complication will I get any sort of context information saying this complication was clicked etc. I am thinking like if I may get a CLKComplication Object in the context.
Any help is appreciated.
You can add special features—called complications—to some watch faces, so you can instantly check things like stock prices, the weather report, or information from other apps you installed. With the watch face showing, touch and hold the display, then tap Edit.
Swipe all the way to the left to edit complications, which you can use to check things like the weather, your activity, or information from other apps that you installed. Tap a complication to select it, then turn the Digital Crown to change it. When you're finished, press the Digital Crown to save your changes.
With this watch face, you can choose up to three complications as well as a digital or analog dial.
In ClockKit/CLKDefines.h
you can find the CLKLaunchedTimelineEntryDateKey
constant.
But you can't define your own user info to help you determine what to do when your app is launched.
From the CLKComplicationDataSource Protocol Reference:
CLKLaunchedTimelineEntryDateKey
A key indicating the date with which the complication was launched. The value of this key is an
NSDate
object. When the user taps your complication, ClockKit includes this key in the dictionary passed to thehandleUserActivity:
method of the extension delegate.Available in watchOS 2.0 and later.
Since you can get the tapped timeline entry's date via CLKLaunchedTimelineEntryDateKey
, you can get the complication type (family) by making "fixed second" for specific type's timeline entry.
Fixed second should be calculated by NSDateComponents
and then convert to NSDate
that you can pass to CLKComplicationTimelineEntry
.
For example, you can specify modularSmall
entry's date end with 10 seconds but modularLarge
entry's date end with 20 seconds. So, tapped entry with date 9:41:10 AM should be a modularSmall
type, and entry with date 9:41:20 AM should be a modularLarge
type.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With