Difference between revisions of "Phonebot developer's reference/Object reference"
|  (→File) |  (→Json) | ||
| Line 466: | Line 466: | ||
| |- | |- | ||
| |<code>size</code>   | |<code>size</code>   | ||
| − | |Read-only. Returns the size of the  | + | |Read-only. Returns the size of the JSON array. | 
| |- | |- | ||
| |} | |} | ||
| Line 476: | Line 476: | ||
| !Syntax | !Syntax | ||
| !Description | !Description | ||
| + | |- | ||
| + | |<code>value = delete_element(name)</code> | ||
| + | |Delete the name/value pair and return the deleted object. | ||
| + | |- | ||
| + | |<code>value = delete_record(index)</code> | ||
| + | |Delete the JSON object at the specified index and return the deleted object. | ||
| |- | |- | ||
| |<code>string = get_element(name)</code> | |<code>string = get_element(name)</code> | ||
| − | |Returns the named value or a  | + | |Returns the named value or a JSON array. | 
| |- | |- | ||
| |<code>string = get_record(index)</code> | |<code>string = get_record(index)</code> | ||
| − | |Returns a value or  | + | |Returns a value or JSON object at the index. | 
| + | |- | ||
| + | |<code>set_element(name, value)</code> | ||
| + | |Add the name/value pair to the JSON object. | ||
| |- | |- | ||
| + | |<code>string = set_record(index, value)</code> | ||
| + | |Add the JSON value to a JSON array at the specified index. | ||
| |} | |} | ||
Revision as of 16:52, 4 August 2012
Contents
Container types
Application
Properties
| Syntax | Description | 
|---|---|
| description | |
| name | Read-only | 
| startup | Read-only | 
| text | 
Events
| Syntax | Description | 
|---|---|
| on_close | |
| on_open | |
| on_service | Fires after any service's on_updatefires. | 
Methods
| Syntax | Description | 
|---|---|
| close_application() | |
| close_module() | |
| value = database_exists(name) | Returns true if the database exists | 
| delete_database(name) | Deletes the database and all records in it. | 
| database = get_database(name) | Retrieve the database and create if it doesn't exist. | 
| array = get_database_names() | |
| log(message) | Log a user event. | 
| notify(title, text, module) | Display a status bar notification. The titlewill be used as the ticker text and title. Themoduleis the name of the module to open when the users selects the notification. | 
| open_application(name) | Open a Phonebot application by passing pbot:APPLICATION_NAME. Open other Android applications using their Intent URI:
 | 
| open_module(name) | 
Module
See Using display properties for details on accessing display properties.
Properties
| Syntax | Description | 
|---|---|
| gravity [ bottom | center_horizontal | center_vertical | left | right | top ], defaultcenter_horizontal | center_vertical | Read-only array | 
| name | Read-only | 
| orientation [ vertical | horizontal ] | Read-only | 
| text | 
Methods
| Syntax | Description | 
|---|---|
| size = clear_events() | Delete all events and return how many were deleted. | 
| event = get_event() | Retrieve the next event in the queue. | 
| event = pop_event() | Retrieve and delete the next event in the queue. | 
| show_file_dialog(path, filter, includeFiles) | Display a file browser dialog. If an item is selected, the module's on_service event will fire. The selected item will be contained in the module's event queue. 
 See Using the Phonebot file object for managing files. See Using Phonebot services for information on application-level services. | 
Events
| Syntax | Description | 
|---|---|
| on_open | |
| on_close | |
| on_service | Fires after any service's on_updatefires. | 
Visual types
See Using display properties for details on accessing display properties.
Properties
| Syntax | Description | 
|---|---|
| enabled | true/false | 
| group | Read-only | 
| layout_height [ fill_container | wrap_content ] | Read-only | 
| layout_width [ fill_container | wrap_content ] | Read-only | 
| name | Read-only | 
| text | |
| type [ button | check | drop_down_list | edit | image | label | list | radio ] | Read-only | 
| visible | true/false | 
Events
| Syntax | Description | 
|---|---|
| on_click | 
Button
Check box
Properties
| Syntax | Description | 
|---|---|
| value | true/false | 
Drop down list
See List.
Edit box
Events
| Syntax | Description | 
|---|---|
| on_update | Fires after any change to the contents | 
Image
The image control uses the display properties configure what image is displayed and how it is displayed.
Label
List
Properties
The text property can contain a semi-colon-delimited list of values to populate the list.
| Syntax | Description | 
|---|---|
| selected_index | Read-only | 
| selected_item | Read-only. The text of column zero of the selected row | 
| size | Read-only | 
Methods
col values can be either zero, for the display value, or a non-numeric value to retrieve the previously set named data value.
| Syntax | Description | 
|---|---|
| index = add_item(item) | Add and item to the list and return the index of the added item. | 
| clear() | |
| delete_item(index) | |
| item = get_item(row, col) | |
| array = get_items(col) | |
| set_item(row, col, value) | |
| sort(type, col) | 0 = alpha-numeric by value, 1 = numeric by value | 
/* Add 10 rows */
for (index = 0; index < 10; index = index + 1)
    list1.add_item("New item " & index)
end
/* Set and get the string displayed in the 5th row */
list1.set_item(4, 0, "New text for the row")     /* Note: the row must already exist. */
row_val = list1.get_item(4, 0)                   /* will retrieve "New item 4" */
/* Set and get the a named data value for the 5th row */
list1.set_item(4, "my data", "hidden value")     /* Note: the row must already exist. */
list1.set_item(4, "more data", "another value")  /* Note: the row must already exist. */
row_val = list1.get_item(4, "my data")           /* will retrieve "hidden value" */
Radio button
Properties
| Syntax | Description | 
|---|---|
| value | true/false | 
Services
See Using Phonebot services: Object reference
Variables
Properties
| Syntax | Description | 
|---|---|
| (value) | Tacit, set/return value by default | 
Array
Manage a collection of values. Values are stored in the order they are added; sorting reorders and eliminates the original order.
Properties
| Syntax | Description | 
|---|---|
| size | 
Methods
| Syntax | Description | 
|---|---|
| index = add_element(element) | Add an element to the end of the collection. | 
| clear() | |
| string = byte_to_string() | Convert an array of bytes to a string. C.f. string.to_byte_array(). | 
| delete_element(index) | |
| boolean = exists(value) | |
| element = get_element(index) | Get the value at index. | 
| string = join(delimiter) | Join the array elements with delimiter and return the string. | 
| reverse() | |
| index = set_element(index, value) | Set the element. Log runtime error if it doesn't exist. | 
| sort(type) | 0 = alpha-numeric by value, 1 = numeric by value | 
| unique() | Delete any duplicate values. The first value will be retained and subsequent duplicates will be deleted. | 
Database
See Managing databases: Database.
Datetime
Properties
| Syntax | Description | 
|---|---|
Methods
| Syntax | Description | 
|---|---|
| add_duration(formatted_value) | Add a duration to the datetime. Values are strings in the format: DURATION[y|M|d|h|m|s] | 
| datetime = difference(datetime) | Calculates the difference between the two datetimes. | 
| string = format(format) | Uses the Java date format pattern syntax | 
| format_difference() | Formats the datetimevalue returned bydifference(). Formatted asHH:mm:ss. The result is only valid within a 24 hour range. | 
| now() | |
| TBD parse(value, format) | Set the datetime to the string valueformatted asformat. | 
File
See Using the Phonebot file object
Json
Properties
| Syntax | Description | 
|---|---|
| is_valid | |
| size | Read-only. Returns the size of the JSON array. | 
Methods
| Syntax | Description | 
|---|---|
| value = delete_element(name) | Delete the name/value pair and return the deleted object. | 
| value = delete_record(index) | Delete the JSON object at the specified index and return the deleted object. | 
| string = get_element(name) | Returns the named value or a JSON array. | 
| string = get_record(index) | Returns a value or JSON object at the index. | 
| set_element(name, value) | Add the name/value pair to the JSON object. | 
| string = set_record(index, value) | Add the JSON value to a JSON array at the specified index. | 
Map
Manage a collection of names mapped to values. Pairs are stored in the order they are added; sorting reorders and eliminates the original order.
Properties
| Syntax | Description | 
|---|---|
| size | 
Methods
| Syntax | Description | 
|---|---|
| index = add_named_element(name, value) | Add an element to the end of the collection. | 
| add_names(array) | |
| clear() | |
| delete_element(name) | |
| boolean = exists(name) | |
| value = get_element(name) | Get the value mapped by name. | 
| name = get_name(index) | Get the name at index. | 
| array = get_names() | |
| value = get_value(index) | Get the value at index. | 
| array = get_values() | |
| string = join_names(delimiter) | Join the names with delimiter and return the string. | 
| string = join_values(delimiter) | Join the values with delimiter and return the string. | 
| reverse() | |
| index = set_element(name, value) | Set the element. Log runtime error if it doesn't exist. | 
| sort(type) | 0 = alpha-numeric by value, 1 = numeric by value, 2 = alpha-numeric by name, 3 = numeric by name | 
Number
Properties
| Syntax | Description | 
|---|---|
Methods
| Syntax | Description | 
|---|---|
| number = average(array) | Sets the value to the average and returns that value. | 
| number = fraction() | x.y returns 0.y | 
| number = integer() | x.y returns x | 
| TBD number = random(min, max) | A random number between min and max | 
| number = round() | < x.5 returns x; >= x.5 returns x + 1 | 
Record
See Managing databases: Record.
String
Properties
| Syntax | Description | 
|---|---|
| size | Read-only | 
Methods
| Syntax | Description | 
|---|---|
| index = index_of(string) | |
| string = replace_all(value, replacement) | |
| array = split(delimiter) | |
| string = substring(start_index, end_index) | |
| array = to_byte_array() | Convert the string to an array of their decimal value representation. C.f. array.byte_to_string(). | 
XML
Parse and query XML and HTML data.
Properties
| Syntax | Description | 
|---|---|
| is_valid | Read-only. | 
| name | Read-only. Element name. | 
| size | Read-only. Number of children. | 
| text | Read-only. Text content. | 
Methods
| Syntax | Description | 
|---|---|
| map = get_attributes() | The element's attribute names mapped to their values. | 
| xml = get_child(index) | |
| xml | array = query(xpath) | Query the document using XPath and return XML or an array of attribute values. Use xml.is_validto determine whether XML or an array has been returned. Uses a subset of the syntax supported by the Java XPath library. The following location path expressions are supported:/foo/bar //bar /foo/bar/* /for/@id (returns array) /foo/bar/text() (returns array) Predicates are not supported: /foo[@bar='bat'] | 
