You can insert a TimePicker area into a form in two ways:
- By inserting a "TimePicker" or "TimeEntry" object from the preconfigured object library of 4D.
- By creating a subform area and assigning the TimePicker or TimeEntry detail form of your choice to it.
Then specify the name of the variable bound to the subform ("Variable Name" property in the Property List). When the form is executed, this variable will automatically contain the time specified by the user. Conversely, if you modify the value of this variable by programming, it will automatically be shown in the subform. You can also choose not to name the variable in order to benefit from the dynamic variable mechanism.
Clock widgets are drawn in SVG, and therefore have a vector path allowing deformations in Application mode (in Design mode, their size is fixed):
data:image/s3,"s3://crabby-images/3b540/3b540751c9f9e6acddb12a1fbbe92ea36e868ad6" alt=""
Note that:
- For a standard clock, the second hand can be displayed or hidden using the TimePicker DISPLAY SECOND HAND method.
- A standard clock automatically changes to "day mode" or "night mode" depending on the time:
data:image/s3,"s3://crabby-images/17321/173212557c962664556fe9d8e167ceeae93db787" alt=""
The time ranges are 8:00:00 -> 19:59:59 = Day, 20:00 -> 07:59:59 = Night. - The "digital clock" widget is transparent and has no background, so it can be placed on top of colored objects in order to vary its appearance:
data:image/s3,"s3://crabby-images/4eaed/4eaede6d0565470ab9ee4efb2ef635b6bda21855" alt=""
There are several display options for this widget that are available through component methods, which are prefixed by "TimePicker LCD".
Note: Developers can displace this clock drawing and substitute their own creations by replacing the "clock.svg" file found at the first level of the "Resources" folder.
Clocks can either display the current time dynamically, or show a static time.
- To display the current time, associate an Integer variable to the subform object of the widget (default operation). In this case, the widget automatically displays the current time and operates like a clock.
You can apply an offset to the displayed time: the value of the number variable indicates the offset in seconds. For example, 3600 = advancing the clock one hour, -1800 = turning the clock back 30 minutes, etc.
- To display a static time, associate a Time variable to the subform object of the widget (by means of the C_TIME command or the Property List). The clock then displays the value of the this variable.
For example, we want the clock to show 10:10:30:
C_TIME(myvar)
myvar:=?10:10:30?
data:image/s3,"s3://crabby-images/89b5f/89b5f9c2f0b6ec0ee58eb91e36640e0c536777d7" alt=""