We released InfiniTime 1.11 a few days ago. The timing of the release did not align with the monthly community update, so we decided to write a small blog post to highlight a few new features and provide new about the PineTime community!
InfiniTime 1.11 is the result of three and a half months of work from many contributors. 59 pull request have been merged with changes ranging from new watch faces to small bug fixes passing by improvements in multiples area of the project.
I’ll highlight a few of these new changes in this post, and feel free to read the whole release note for more information!
As you may know, InfiniTime is currently quite constrained by the memory space available in the PineTime. Both RAM and flash memories are quite well packed, and we have to ensure that the changes we include in the project will actually fit in the remaining memory available.
But we are not doomed to save any byte in memory forever, and we have multiple options to give InfiniTime a bit of fresh air!
If you read the Pine64 monthly community updates, you may have noticed that I wrote about the usage of the external flash memory of the PineTime for some time now. Remember the blog post from December 2021 where I teased a few watch faces with custom backgrounds ? Nearly a year, that’s the time it took to put all things together to make this happen : InfiniTime can now use the external flash memory to store fonts and pictures and make them available to applications and watch faces!
This feature will bring a lot of possibilities in the future : the external memory is a 4MB flash memory. It’s really huge compared the the 512KB available in the main memory of the PineTime. In the future, we’ll be able to move more and more data from the internal to the external memory, which will free very precious space to add more and more features to InfiniTime!
What did it take to build this feature? Things started with the integration of LittleFS, a file system designed for embedded systems, in InfiniTime 1.3.0. At first, this file system would only be used to store user settings and BLE bonding information, but we knew it would be the basis for other functionalities in the future.
Then, the BLE FS API was added in InfiniTime 1.8. It provided companion apps with an access to the internal file system of the PineTime. It was not that useful at that time, but once again, we knew we would need it in the future.
Now that we know how to store and access files from the external memory, we can focus on the next step : extending InfiniTime so that applications and watch faces can actually access to the images and fonts stored in the file system! This step took a lot of time with many trials and errors until we finally reached a point where we were satisfied by the performances of the system. Indeed, the external memory is far slower, and we wanted to provide the best user experience no matter what. Most of the work done in this step is documented in this page.
And we are not done yet : we need to provide the users with an easy way to install the resources. And for this, we need the support of companion apps. ITD (since version 0.0.8) and InfiniSim added support for the external resources very soon in the development process. I also implemented the upload procedure in Amazfish (since version 2.1.0) which allowed me to test that the procedure actually worked!
Now, everything is in place to release this new feature to the wild!
Contributors to the InfiniTime project work on many great features, apps and watch faces, and keeping up with this constant stream of pull-requests is probably the most difficult part of our job as project maintainers. I’ve been eyeing the watch faces Infineat and G7710 for quite some time now, but couldn’t merge them because of their memory usage.
It turns out they were great candidates to be the first watch faces to leverage the resources feature in InfiniTime!
Infineat is a very stylish, colorful and customizable watch face that displays the battery level using an animated Pine64 logo. The big font makes it very easy to read.
The G7710 watch face is designed to mimic the interface of LCD watches. It displays the week number, day of the year, days until the end of the year, date, time, step count, battery level and heart rate.
To enable those watch faces, you’ll need to install the resources package provided in the release note of InfiniTime 1.11. Please check the release note and the documentation for more information about this. Note that for now, only ITD and Amazfish support this feature, but I hope other companion app will integrate the upload procedure for external resource very soon!
External resources and the new watch faces are obviously not the only changes we make to the project! On the UI side, we made many improvements in the UI to improve the consistency of the interface and make it more readable. We also created a new ‘counter’ widget to make settings like the date, time and alarm easier.
A new Sleep mode is available via the Quick Settings menu. This mode disables notifications, chimes and all automatic wake up options (touch and motion) and will prevent the watch from waking itself (and the user) up during the night.
I would also like to mention that the Core Developers team worked on a new document that describe the vision of the project.
You’ll find the complete list of additions, improvements and bug fixes in the release note.
InfiniSim, the InfiniTime simulator, evolves alongside InfiniTime. Its main developer NeroBurner takes a great care to make necessary changes in the simulator to adapt to changes in InfiniTime.
InfiniSim was also extended to support all the features related to the external SPI flash memory, the file system and the external resources. A new tool “littlefs-do” allows to easily manage the simulated SPI flash memory : list files, read and write files and even load the external resources package in a single command! Please check the documentation to see what littlefs-do is capable of!
That’s it! Enjoy InfiniTime 1.11 on your PineTime! Feel free to join us in the community chat rooms if you have questions, need help or just want to talk about your favorite smart watch ever!
16 responses to “InfiniTime 1.11”
Correct please link in the first clause – currently it points to 1.10 (not 1.11) release.
I’ve just fixed that typo, thanks!
Same issue with “release note” link.
I’ve just fixed that one too, thanks, and sorry for the confusion!
Great to see how InifiniTime progresses.
It would be nice to see new usecases, e.g. use pinetime to unlock a door using authentification via BLE against a Linux system.
Please wrote about pine dio
We should provide more information about PineDio in next community update 🙂
why don’t you finally make a working prototype? The obtuseness of the community is untrue. Many of your products have no support and yet you publish new hardware versions
I assume this is for PineDio Stack BL604 (and not the PineDio Gateway). I’m curious: How do we plan to use PineDio Stack? What kind of use cases do we have? Like for Meshtastic Communicator? Or a Smartwatch?
I’ve been naive until about 10 years ago about computing and electronics in general,now I have to say well done fellas. Time, money, and effort needed to do the smallest things is amazing. Keep up the good work and I hope within the coming year to join your notable ranks and begin in earnest my programming journey.
My watch is not doing OTA update for some reason, it starts to connect and keeps disconnecting. I’m using nrf connect and was doing fine until recently. Do I need to reset and start over? If so, how? Thanks, love the watch, just want latest updates
Recent versions of NRFConnect are known to cause some issues with the PineTime. I recommend you try with another companion app (Gadgetbridge on Android, for example).
I have gadgetbridge installed and use it with my watch, but I haven’t quite figured out how to perform OTA updates with it. I’ll have to do more research–thanks!
If you open a .zip file on Android, it will offer to either open it using your file manager, or to “Install apps/firmware” using Gadgetbridge. The latter option can be used to perform the OTA update.
I did figure it out, thanks for all the help!
I need simple OTP
ssh + OTPassword example | tutorial