Difference between revisions of "Apple Watch Interface"

From HSYCO
Jump to navigation Jump to search
Line 4: Line 4:
  
 
== Objects ==
 
== Objects ==
=== Common Parameters ===
 
Each object has these common parameters:
 
* id: the optional object id. If set, it can be used for UISet
 
* visible: true|false, specifies the object visibility. This can be set throught a UISet.
 
  
 
=== Label ===
 
=== Label ===
Line 20: Line 16:
 
==== UISet Attributes ====
 
==== UISet Attributes ====
 
*'''text''': to dynamically modify the text
 
*'''text''': to dynamically modify the text
 +
*'''visible''': true|false, specifies the object visibility
  
 
=== Button ===
 
=== Button ===
Line 50: Line 47:
 
==== UISet Attributes ====
 
==== UISet Attributes ====
 
*'''label''': to dynamically modify the button's label
 
*'''label''': to dynamically modify the button's label
 +
*'''visible''': true|false, specifies the object visibility
  
 
=== Light ===
 
=== Light ===
Line 61: Line 59:
 
*'''label''': to dynamically modify the button's label
 
*'''label''': to dynamically modify the button's label
 
*'''state''': used to change the icon state if the "action" is not "device". Can be "off", "on" or "unknown".
 
*'''state''': used to change the icon state if the "action" is not "device". Can be "off", "on" or "unknown".
 +
*'''visible''': true|false, specifies the object visibility
  
 
=== OnOff ===
 
=== OnOff ===
Line 89: Line 88:
 
*'''label''': to dynamically modify the slider's label
 
*'''label''': to dynamically modify the slider's label
 
*'''value''': 0-100, modifies the displayed value
 
*'''value''': 0-100, modifies the displayed value
 +
*'''visible''': true|false, specifies the object visibility
  
 
=== Image ===
 
=== Image ===
 
[[File:Apple Watch UI Object image.png]]
 
[[File:Apple Watch UI Object image.png]]
 +
Displays an image.
 +
==== Parameters ====
 +
*'''id''': the object's ID, used by UISets, optional
 +
*'''url''': the image's URL
 +
 +
=== UISet ===
 +
*'''url''': to dynamically change the image
 +
*'''visible''': true|false, specifies the object visibility
  
 
=== Camera ===
 
=== Camera ===
 
[[File:Apple Watch UI Object camera.png]]
 
[[File:Apple Watch UI Object camera.png]]
 +
Displays a camera.
 +
==== Parameters ====
 +
*'''id''': the object's ID, used by UISets, optional
 +
*'''address''': the camera's address
 +
*'''visible''': true|false, specifies the object visibility
 +
 +
=== UISet ===
 +
*'''visible''': true|false, specifies the object visibility

Revision as of 17:03, 17 November 2017


An Apple Watch interface can be created visually through the Project Editor or using a Project's UISet (for example, for dynamically build Watch interfaces).

Objects

Label

A label object to display text. Text can be on multiple rows. The object's height will adjust to contain the text.

Apple Watch UI Object label.png

Parameters

  • id: the object's ID, used by UISets, optional
  • text: the label's text

UISet Attributes

  • text: to dynamically modify the text
  • visible: true|false, specifies the object visibility

Button

A button object that executes an action.

Apple Watch UI Object label.png

Parameters

  • id: the object's ID, used by UISets, optional
  • label: the button's label
  • action: the button's action
The action parameter specifies the type of action and can have the following values:
  • user: similar to a User Button object, sends a User call to the server
  • device: similar to a Button object, controls a light or automation device
  • url: requests the specified URL
Each type of action uses different parameters as following.
User Parameters
  • name: name passed to the Java callback method and event in EVENTS
  • parameter: parameter passed to the Java callback method and event in EVENTS
Device Parameters
  • address: device data point name
Device Parameters
  • url: the URL to be requested. Its return value will give a different feedback: "ack" (success feedback) or "error" (failure feedback)

UISet Attributes

  • label: to dynamically modify the button's label
  • visible: true|false, specifies the object visibility

Light

Apple Watch UI Object light.png

The light object displays a "light" icon on the left of the button. It has the same parameters as the "Button" object. If the "action" is "device", Its icon changes to reflect the status of the associated device address.

UISet

  • label: to dynamically modify the button's label
  • state: used to change the icon state if the "action" is not "device". Can be "off", "on" or "unknown".
  • visible: true|false, specifies the object visibility

OnOff

Apple Watch UI Object onoff.png

Same as the Light object, but displays an on/off icon.

Shutter

Apple Watch UI Object shutter.png

Same as the Light and OnOff objects, but with an additional parameter "mode" for the direction of the shutter. The UISet "state" can have the following values: "up", "down", "offup", "offdown", "unknown".

Slider

Apple Watch UI Object slider.png

Same as the Button object, but sends a value as well.

If action is "device", the slider's value is updated with the corresponding device's state.

If the action is "user", the slider's value is sent as parameter.

If the action is "url", the slider's value will be replaced in the URL where "%value" is found.

E.g. If the url is "http://www.myurl.com/slider?%value" and the slider's value is changed to "77", the following URL is requested: "http://www.myurl.com/slider?77"

UISet

  • label: to dynamically modify the slider's label
  • value: 0-100, modifies the displayed value
  • visible: true|false, specifies the object visibility

Image

Apple Watch UI Object image.png Displays an image.

Parameters

  • id: the object's ID, used by UISets, optional
  • url: the image's URL

UISet

  • url: to dynamically change the image
  • visible: true|false, specifies the object visibility

Camera

Apple Watch UI Object camera.png Displays a camera.

Parameters

  • id: the object's ID, used by UISets, optional
  • address: the camera's address
  • visible: true|false, specifies the object visibility

UISet

  • visible: true|false, specifies the object visibility