| Yeah, OP's claims about battery life are manifestly silly. The HN headline makes it sound like the article is making claims about the Watch in general, but it isn't, just that one dev's app. I understand and take your point about public APIs lagging behind private ones, but in this case it's not that the public SDK is lagging, it's a totally different beast. The fundamental execution model is the same as watchos 1 -- you don't get to write code that runs in the app process, you write code that runs in a separate extension process and get to twiddle ui elements in the main process using a very limited API. Which is why if you're trying to do anything dynamic, you have to resort to generating and beaming over images. Besides this fundamental limitation, the management of app process vs extension process vs network daemons is still buggy (contributed to, probably, by the fact that apple isn't dogfooding), which means it's hard to impossible to make your app stable. I think this has been a huge contributor the general perception that 3rd party Watch apps are slow and buggy. Obviously, I can only speculate about Apple's motives for going with WatchKit vs exposing native development, as on the iPhone. My guess is they were very worried about an initial public perception of the watch being "battery life sucks," so they didn't want to open up 3rd party code to run on the Watch. Hence WatchKit and OS1. Then there was a huge public negative perception about not having native apps, so they rushed out OS2, which has 'native' apps, but still following the (now nonsensical) 2-process model of WatchKit. I do hope Apple opens up true native dev on the watch at some point. It won't be "the public SDK getting more powerful over time," though, it will be making a qualitative change to the SDK itself. P.S. If you haven't and are curious, I encourage you to take a look at WatchKit. I think you will be surprised at how limited it is. P.P.S. I think Apple may have been better served by doing something akin to the original iPhone model -- just saying, "no 3rd party apps yet, but it's coming," rather than having a half-assed SDK on day 1. |
WatchKit is the html+js of WatchOS development. OK, not that bad, but the situation is analogous.