Summary: This MR attempts to fix #149 by rewriting the coordinates to the EXIF info of an image with stripped decimals of the coordinates seconds.
A Context and explanations
I did investigate and as far as I could find out, the reason is this:
Camera
objectrationals
. That is a string with numbers and precision parametersdd/1,mm/1,ss/1
with dd=degree, mm=minutes, ss=seconds and "/1" being the precision, with "/1"=no decimals, "/100" two decimals or "/10000" four decimalsEarth Circumference is about 40.000 km Wikipedia. 40.000.000 m divided by 360° by 60' by 60" results in 1" being equal to about 31m. So using seconds without decimals results in photo coordinates being restricted to an accuracy of about 31m. Using 1 decimal second would lower that to about 3m, using two decimals to below 1m.
Although a single GPS position is not below 1m accuracy, it certainly can be in good conditions better than 31m. So specifying 1 decimal would be preferable, two would make sure all the accuracy that is available will be used.
Sadly that seems not to be an option for us. dd/1,mm/1,ss/1
will work, dd/1,mm/1,ss/100
will not work.
This results in a coordinate with seconds value much more than 60", for instance 12° 34' 5678". Obviously seconds should never exceed 60.
B Description of solution
This MR now adds two things:
The logic is as follows: After an image has been saved to disk (onImageSaved event) and has got the broken GPS EXIF info, the coordinates are overwritten in the EXIF infos with the correct values with seconds stripped by all decimals. Thus the coordinate is correct with the limits of the accuracy of about 31m.
Note: I tried writing the coordinate to EXIF with decimals but failed. Although in theory it should be possible (and does make sense for accuracy) as
Since the examples are python and R, maybe (wild guess) only when using c++ this limitation applies?