DIY Data Field

Former Member
Former Member
Application is still pending to be approved, topic is created to be used as a communication hub during and after public beta test.

Do/Design It Yourself Data Field.

Disclaimer:
Application has hundreds of use-cases due to fully user-configurable setup, therefore it is prone to bugs. This project is not sponsored and I'm the only developer working on it in my own free time. Although I'd gladly accept reasonable criticism and improvement suggestions, I do not guarantee that bugs will be fixed and new features added in a timely manner/at all. If this approach is not acceptable for you, then, please, do not leave bad reviews just because I didn't resolve your specific case. Thanks for understanding.

Preface:
There's a lot of things custom activity recorders can do, which native Garmin apps cannot, but sometimes there's no need to invent a bicycle if there's one already itching for a ride. Some capabilities like local watch personal records, structured workouts information and advanced running dynamics will most certainly never be exposed to ConnectIQ API layer, therefore it's sometimes more efficient to use native software, but no one prevents us to use it with a twist. The main idea of this data-field type application is to give user a tool to design his own data field layout in WYSIWYG manner. The web application makes that possible providing cross-platform compatibility at the same time the only requirement being the HTML5 compatible browser. This app is not considered to be an ultimate DF which "replaces them all" as there's always something new and intriguing, which developer may envision, but I hope that this data field will help new and existing users to explore the Garmin ConnectIQ capabilities providing some unique features, which I didn't encounter in existing apps.

First things first: there's a web application, which allows to design data field layout and produces configuration string as a result. This configuration string can only be delivered to data field using standard settings means i.e. you will need either Garmin Express installed on compatible PC or Garmin Connect Mobile on your mobile device. Web app uses HTML5 local storage, changes are saved after each user action, therefore it's safe to leave your work half done and proceed from the same point sometime later. I do not own hardware to test with Apple devices, therefore any problems in that department can be explored and fixed only by sending me detailed explanations and, of course, the configuration string itself. Current version with the default layout setup was tested for several weeks in simulator and for several of my personal runs proving to be rather stable to go live, but of course there's no guarantee that this app will function without hitches on your specific device. Currently, I do not have a reliable hosting for my personal web apps, therefore data field designer will reside on Google Apps Engine servers using free account bandwidth/limitations (as there are almost no server-side computations, I think this will suffice for a while) at least if/until it'll become popular enough for the users to complain about page availability. Current implementation with the default layout setup works on the edge of stability and there was also a price to pay during watch code optimization, which lead to efficient but very unreadable code. This means that for older devices there may be no improvements, only bug fixes. But for modern devices like Forerunner735XT and on we still have additional 10kb of available memory, which can be used for new logic like new data values and/or additional app parameters (e.g. waypoints). Sometimes network latency and/or Google servers accessibility seems to impact resources load time and wrong font may be displayed first time the web app is started, to fix this simply press F5 (refresh page) in browser.

Current settings are 4 lines for definition itself (these should be copy/pasted without changes directly from web app), Target Pace for pacemaker values (should be entered as string in <min>:<sec> format, e.g. "5:40" as in min/km) and Milestones, which are just fixed distances comma separated list, they are expressed in kilometers and may contain fractional values using dot delimiter (e.g. 0.5,1,1.5, etc). It'necessary to enter values in kilometers, but they will be converted before display depending on watch settings.

Default setup is considered to be a "component showcase" and consists of basic building blocks:
- Data values, which are simply text representation of corresponding activity information bits like time or speed, for data values it's possible to change screen coordinates, font, color, number of samples to smooth the value over specified amount of seconds and add optional outline for data to become more readable or dynamically colored on less contrast backgrounds; if text font is selected, then it's also possible to append data value with custom text, e.g. create label with value for another data block;
- Data graphs, these are just rolling data value charts, which represent one selected data value over a set period of time, minimum and maximum graph values are adjusted automatically, number of samples is calculated automatically based on width of graph area and graph bar, all of the other options are similar to data values;
- Graphics elements, these are basic graphical primitives, which allow to customize the layout, add visibility to some values etc; parameters for these elements are mostly self explanatory except for two specific elements of type Arc. These may not only serve as a static view elements, but also can be used to represent a dynamic data value in a manner of a progress bar. For this to happen you need to tick the "Variable" option and select base Data value (currently there's only a limited selection, but this may be a subject to change) accompanied by min and max initial values, these range values are indeed initial as when the underlying data value falls outside of this range, then range is adjusted automatically. For example in bundled layout this feature is used to display the progress to the next kilometer: Elapsed distance is selected as a base value, initial range is specified as 0 to 100 (in this case 100 means 1000m, as the distance values are displayed as 00.00), which means that this arc will grow from start angle to the maximum width angle as the elapsed distance increases during activity acting as a progress bar to the next kilometer. When elapsed distance will become greater than 1000 meters, then ranges will be readjusted using the same range difference as before, in this case minimum value will become 1000m while maximum one will increase to 2000m. Here's a little demo of what you can make using variable value arc (this config is created for semi-round devices, copy/paste this configuration string into import window of web app).
AGUAJA[HIWaVFAJNATXDEAODZQVELEUA[HIWaVFAODU]`DEAOEOQVEVE_A[HIWaVFAABG`[DEAOFDQWE`FHA[HIWaVFAABHGRDEAOF[QWFIFRA[HIWaVFAJNA\ODEAOGQQVFSF\A[HIWaVFAOE]CPCWAODZTMELF\A[HIWaVFAAAAAACWAPDWTMELF\ASADILDAPOE]CPFEABAVDVENQAPQAAAFDJCFACB

Selected element options can be adjusted using the properties panel to the right of the designer canvas. In addition to pixel-by-pixel adjustments, designer canvas allows to drag currently selected element. To drag data value it's not necessary to start drag at any specific point, but for graphs and graphical elements the drag point will be determined based on mouse pointer coordinates: e.g. to resize graph area or rectangle click and drag somewhere around the lower right corner, to adjust the radius of circles and direction arrow start drag outside of the outer radius, to change coordinates - click somewhere near the circle center. For the arcs it's currently possible to change start angle and arc width by activating drag-and-drop near the corresponding arc vertex. Touch support for mobile devices is implemented.

There are still some limitations like direction arrow points only to north or some data values available only on high-end devices like power are not yet implemented etc, but as I already mentioned above, this app is subject to improve especially for the newer devices, where there's a lot of memory available even for the data field type of app. The web app is also meant to be improved especially in a direction to provide the nearest possible WYSIWYG snapshot of what you'll actually see on device, but there are also some limitations like, for example, font, which is used as numeric font in the latest Fenix5/FR935 models is not and won't be publicly available (confirmed by Garmin officials explicitly) and I used nearest lookalike, therefore there still may be some couple of pixel differences here and there between device and web app. For these kinds of problems I can only test and fix using the user-provided layouts in specific device simulator as I'm a simple FR230 owner for real testing and I'm afraid this won't change in the nearest year unless generous users will help me to upgrade.

Web app may eventually become mobile application based on the user feedback (but not for the Apple devices, Android only).
  • Hi,
    I really love the piece of work you did. In case you are interested, my fields I made so far look like this:
    AL\BGAQHJI\FAHOE]CPDVASHEXYHAAAAAAAE]A`ASHEXPCAAAAAAAE]A^ASHCOEAAAAAAAAHJBZASAGYM]ABJOHXVFCABAUHCVVHABAAAAAHFABCYAUHCVVIABJOHXVHFABCZAUHCVXAABJOHXVHFABERAUHCVXBABAAAAAHFABESAUHEXPBABAAAAAGCABGMAUHGNXNABEXUL\CEABCYAUHMDZPABEXUL\FFABCYAUHGAT\ABJOHXVB_ABERAUHMQaYABJOHXVFMABEQAUHJI]CABEXUL\DVABGMASHDYKTAAQACQDBNATAUADN]QCDOE]CPAAABHRASACJI_AVQACQDFCACASHGPTQAAOE]CPCaAUAWAG\XECDAAAAAACABPaceASAG\XTAGAAAAAGCAFASHMFVSAAQABZVBNATAVAJaEPCDOE]CPAEABCadASALPBWAPVK^G^FCAFAWAC^a\CDJOHXVAAABø HRASAB\JFAWQACQDFCABAYAG\ZACDJOHXVACABø PaceASAG\ZKAHABG`[GCAFAXAKT^ACDJOHXVAEABø CadASALaA`AQVK^HCFCAFA[AJNPZCDAAAAAACABDistanceASAJ[T_AMAAAAAGCABAWADa\ACDAAAAAACABTimeASADNaKACAAAAAFCABAQHKJZJAHQAF_PAFAWHKJZJACQAF_PAKADRMCYAWHKJZJACQAF_PAKADEDCYASHIARYAAQADCVASAJASHJBM^AAQADCVADAFAFHJNA\OAE_ABHGRAEYABG`[AESODU]`AAAJNATX

    and
    APFA`AQHJI\FAHOE]CPDVASHEXYHAAAAAAAE]A`ASHEXPIAAAAAAAE]A^ASHCOEAAAAAAAAHJBZASAGYM]ABJOHXVFCABAUHCVVHABAAAAAHFABCYAUHCVVIABJOHXVHFABCZAUHCVXAABJOHXVHFABERAUHCVXBABAAAAAHFABESAUHEXPHABAAAAAGCABGSAUHGAT\ABJOHXVB_ABERAUHMQaYABJOHXVFMABEQAUHJ\VWABEXUL\D`ABGSAVDR\KGASOEH]LF`B\ACBAUAB\IWCDJOHXVACABUpASAB\JFATJNATXFCAFA[AG\ZACDJOHXVACABAltitudeASAG\ZKASOE]CPGCAFAWAL_ENCDJOHXVACABDownASALaA`AUABG`[FCAFAWAJTEECDAAAAAACABDistASAKE^MAMAAAAAGCABAWAEUQ]CDAAAAAACABTimeASAD^AOACAAAAAFCABASAD^BGADEXUL\FCABAQHKNRTAHQAF_PAFAWHKNRTACQAF_PAKADRMCYAWHKNRTACQAF_PAKADEDCYASHIAR_AAQADCVASAJASHJBNCAAQADCVADAFAQHL^H]CEAB[`GAJ



    Hi there, which device are these for?
  • Hi Im currently trying to set up an indoor trainer layout & for some unknown reason the NP field on my Edge1000 is not working and always reads 0.
    I've got 3s Pwr & Avg Pwr.
    I'm guessing that the NP is supposed to be instantaneous over the sampled period & since it's not available in the API has been calculated by the app.
    I was hoping to add NP for the workout and NP Lap is this possible?
    I've also noticed that when following a multistep workout a Lap is not triggered in the app when a workout step changes even though it does on the device. Only on pressing the lap button does the app generate a lap and reset the lap timer, increment the lap number & update any fields with 'lap' selected in the configuration. Can this feature be added for workouts?
    Thanks
  • Former Member
    Former Member over 7 years ago
    I'm guessing that the NP is supposed to be instantaneous over the sampled period & since it's not available in the API has been calculated by the app.
    I was hoping to add NP for the workout and NP Lap is this possible?

    Seems like I didn't update clones B and C for a while now and Normalized power is implemented only in main application branch, I've already released fix for Edge1000 and if all goes well, I'll propagate all of the latest changes to clones.

    I've also noticed that when following a multistep workout a Lap is not triggered in the app when a workout step changes even though it does on the device. Only on pressing the lap button does the app generate a lap and reset the lap timer, increment the lap number & update any fields with 'lap' selected in the configuration

    Unfortunately, this is not something I can fix: application processes standard event of lap change, if it is not triggered by API during structured workouts, then it's a firmware bug and should be fixed by Garmin since there's no other way of knowing the lap number other that handling the lap change event.
  • Hi. Thanks for the feedback. Maybe in time some of these features will be made available in the API
    I've just sent you an email regarding the settings fix for DIY A
    Thanks HD
  • Hi,
    I tested DIY field yesterday with cadence and avg. cadence fields while running. I ran at 156-160 with no stops, but avg. cadence displayed about 78. So there has to be something wrong with that data or calculation.
  • Former Member
    Former Member over 7 years ago
    I tested DIY field yesterday with cadence and avg. cadence fields while running. I ran at 156-160 with no stops, but avg. cadence displayed about 78

    Unless you're using cadence value with samples (to average it's value by the means of application) average cadence is provided directly by API as a native value, which is either determined by internal device accelerometer or provided by external sensor (Footpod, HRM Run etc). I never tested this on my physical FR230 as I'm more interested in either momentary cadence or last 5-10 seconds averaged value. I just tried simple comparison of current, native average and app averaged cadence with 10 samples values, they display expected numbers, so there's either problem with specific device/family firmware or you're using some kind of third-party sensor like Stryd, which sometimes may give strange readings if I remember correctly.

    Other than that I suggest you compare the DIY average cadence results with any other connectIQ data field, which also shows the same metrics, I'm almost sure results will be the same.

  • Hi Easuvorov!
    Are there any changes to be expected in the way transferring the def-strings to the device (building the set-files)?
    If there will be no other way of transmission in the future as sending strings via GE or GCM (which is o.k. for me), will there be any progress in solving the problem to transmit strings by iOS-devices?


  • Former Member
    Former Member over 7 years ago
    Are there any changes to be expected in the way transferring the def-strings to the device (building the set-files)?
    If there will be no other way of transmission in the future as sending strings via GE or GCM (which is o.k. for me), will there be any progress in solving the problem to transmit strings by iOS-devices?

    For iOS I can only suppose that symbol "/" which falls within used symbol range is interpreted incorrectly by GCM iOS, but as I don't have any Apple device I can't test if this is true, so I can only speculate.

    I see at least two workarounds thus far:
    1. Generate application executable server side with bundled settings. Good choice, but this will require to also bundle other settings as it'll be impossible to change something unless app is published on Garmin market. It will also require hosting, which allows file system access for java applications as currently used Google App Engine prohibits this
    2. Use background service, which presumably allow communication even for application types which were initially deprived of this capability (watch faces and data fields). This works for watch faces for sure, but no-one has ever shared the knowledge if this will work for a data fields. But even trying to check this will require of me to implement both web service and authentication in designer app. This is not that hard, but will require substantial updates server side and a considerable amount of time to implement,

    I will try to go the easiest way first: exclude slash symbol from encoding range, this will require one-time re-encoding when user starts designer app, but this is much easier than two scenarios I described above, so stay tuned for updates, although I cannot promise any ETA.
  • Thank you for your explanation!

    EDIT:
    Do you think, some day Garmin Express will support 1024 bytes input?
    Unfortunately the newest version 6.0.0.0 does not... - still 256 :mad:
  • Other than that I suggest you compare the DIY average cadence results with any other connectIQ data field, which also shows the same metrics, I'm almost sure results will be the same.

    Thank you very much for looking into this. I use it on Vivoactive 3. I did a test with 4 fields - current cadence, current cadence 10 samples, avg. cadence and avg. cadence 10 samples. I also used avg. cadence provided by the watch directly on a different screen. The results are quite strange. While cadence and cadence 10 work as expected and they both display nearly identical values, avg. cadence is in both cases about half of that value. The avg. cadence watch field on a different screen displays a correct avg. cadence.
    So I think the problem might be in getting the right avg. cadence data coming from the watch. It might also be something watch specific :-(