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/b6418/b64185f766fad0536a73d86636cab343cf5714ce" 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/eae4d/eae4d3950f22e06f47817c9e869319439ea73b72" 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/ed0da/ed0daf462eee308e0130fb1cde21e9591ad7182c" 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 and operates like a clock:
- When using a variable as datasource, associate an Integer variable to the subform object of the widget (default)
- When using an object property as datasource (e.g. Form.myTime), associate an Integer or Time value to the subform object of the widget.
Note: 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:
- When using a variable as datasource, associate a Time or Text variable to the subform object of the widget (using the language or the Property List).
- When using an object property as datasource (e.g. Form.myTime), associate a Text value to the subform object of the widget.
For example, we want the clock to show 10:10:30:
- with a variable as datasource
C_TIME(myTime)
myTime:=?10:10:30?
C_TEXT(myOtherTime)
myOtherTime:="10:10:30"
- with an object property as datasource:
data:image/s3,"s3://crabby-images/bc216/bc2165caed8190b7878c115aadb57ae9a92ba038" alt=""