From wiki.ginstr.com
Jump to: navigation, search
(Example)
(Action signatures)
(47 intermediate revisions by one other user not shown)
Line 4: Line 4:
  
 
;Description: Action is used to calculate driving distance between two GPS coordinates and store the result into target
 
;Description: Action is used to calculate driving distance between two GPS coordinates and store the result into target
 +
:In order for this action to work, an internet connection must be active because the calculations are done by OSRM server.
 +
 
;Action returns: void
 
;Action returns: void
 
==Action signatures==
 
==Action signatures==
  
===Calculate driving distance===
+
===Full signature===
 
+
:;<code>[gn:act_calculateDrivingDistance]|[targetRows,targetColumnNameOrWidgetIdNumber,targetColumnNameOrWidgetIdText,targetTextSuffix,callbackWidgetWhenDistanceReceived,callbackWidgetActionSet;gpsPointsDataBlock{n}]</code>
:;<code>[gn:act_calculateDrivingDistance]|[target,source1,source2]</code>
 
  
 
:{| class="wikitable sortable" style="font-size: 85%; text-align: left;"
 
:{| class="wikitable sortable" style="font-size: 85%; text-align: left;"
Line 16: Line 17:
 
! scope="col" | Description
 
! scope="col" | Description
 
|-
 
|-
| <code>[[target]]</code>
+
| <code>[[target|targetRows]]</code>
| [[target]] into which calculated driving distance will be stored
+
| [[target]] target rows which can be used as source for calculating distance and target for storing calculated distance
 
* Valid [[target|targets]]:
 
* Valid [[target|targets]]:
:*<code>[[Datatypes#number|number]]</code>
+
:*<code>[[Datatypes#rows|row]]</code>
 
|-
 
|-
| <code>[[source|source1]]</code>
+
| <code>[[target|targetColumnNameOrWidgetIdNumber]]</code>
| [[target]] into which calculated driving distance will be stored
+
| [[target]] column in row or widget into which calculated distance will be stored
 +
* Valid [[target|targets]]:
 +
:*<code>rowColumnId</code> id of column in case we want to store into row, column must be of type [[Datatypes#number|number]]
 +
:*<code>widgetId</code> id of widget, widget must support and be of type [[Datatypes#number|number]]
 +
|-
 +
| <code>[[target|targetColumnNameOrWidgetIdText]]</code>
 +
| [[target]] column in row or widget into which calculated distance will be stored as text. <code>targetTextSuffix</code> will be appended as suffix to the value
 +
* Valid [[target|targets]]:
 +
:*<code>rowColumnId</code> id of column in case we want to store into row, column must be of type [[Datatypes#text|text]]
 +
:*<code>widgetId</code> id of widget, widget must support and be of type [[Datatypes#text|text]]
 +
|-
 +
| <code>[[source|targetTextSuffix]]</code>
 +
| [[source]] suffix which will be added to <code>targetColumnNameOrWidgetIdText</code>
 
* Valid [[source|sources]]:
 
* Valid [[source|sources]]:
:*<code>[[Datatypes#gps|gps]]</code>
+
:*<code>[[Datatypes#text|text]]</code>
 
|-
 
|-
| <code>[[source|source2]]</code>
+
| <code>callbackWidgetWhenDistanceReceived</code>
| [[target]] into which calculated driving distance will be stored
+
| [[target]] on which is defined <code>callbackWidgetActionSet</code>
 
* Valid [[source|sources]]:
 
* Valid [[source|sources]]:
:*<code>[[Datatypes#gps|gps]]</code>
+
:*<code>widgetId</code>
 
|-
 
|-
 +
| <code>callbackWidgetActionSet</code>
 +
| [[:Category:Events|event]] action set name which will be fired after distance is calculated and stored
 +
* Valid [[source|sources]]:
 +
:*<code>hardcoded</code>
 +
|-
 +
| <code>gpsPointsDataBlock{n}</code>
 +
| [[source|sources]] which will be included into calculation
 +
* Valid [[source|sources]]:
 +
:*<code>[[Datatypes#gps|gps]]</code> widgets and/or column id's in case <code>targetRows</code> is defined
 
|}
 
|}
 +
 +
===Calculate driving distance===
 +
 +
:;<code>[gn:act_calculateDrivingDistance]|[,targetColumnNameOrWidgetIdNumber;gpsPoint1,gpsPoint2]</code>
 +
 +
====Example====
 +
:<code>@+id/calculateDrivingDistance_calculateDrivingDistance_result</code> - targetColumnNameOrWidgetIdNumber<br>
 +
:<code>@+id/calculateDrivingDistance_calculateDrivingDistance_pointOne</code> - gpsPoint1<br>
 +
:<code>@+id/calculateDrivingDistance_calculateDrivingDistance_pointTwo</code> - gpsPoint2<br>
 +
:<code>@+id/calculateDrivingDistance_calculateDrivingDistance_pointThree</code> - gpsPoint3<br>
 +
:<code>@+id/calculateDrivingDistance_calculateDrivingDistance_pointFour</code> - gpsPoint4<br>
 +
:; ⤷ [gn:act_calculateDrivingDistance]|[,@+id/calculateDrivingDistance_calculateDrivingDistance_result;@variable/calculateDrivingDistance_calculateDrivingDistance_pointOne,@variable/calculateDrivingDistance_calculateDrivingDistance_pointTwo,@variable/calculateDrivingDistance_calculateDrivingDistance_pointThree,@variable/calculateDrivingDistance_calculateDrivingDistance_pointFour]</code>
 +
<hr>
 +
 +
===Calculate driving distance with callback action===
 +
 +
:;<code>[gn:act_calculateDrivingDistance]|[,targetColumnNameOrWidgetIdNumber,,,callbackWidgetWhenDistanceReceived,callbackWidgetActionSet;gpsPoint1,gpsPoint2]</code>
  
 
====Example====
 
====Example====
:<code>@+id/deviceKm</code> - target<br>
+
:<code>@+id/calculateDrivingDistance_withCallbackAction_result</code> - targetColumnNameOrWidgetIdNumber<br>
:<code>@+id/gpsInput</code> - source1<br>
+
:<code>@+id/calculateDrivingDistance_withCallbackAction_pointOne</code> - gpsPoint1<br>
:<code>@+id/deviceGps</code> - source2<br>
+
:<code>@+id/calculateDrivingDistance_withCallbackAction_pointTwo</code> - gpsPoint2<br>
:; ⤷ <code>[gn:act_calculateDrivingDistance]|[@+id/deviceKm,@+id/gpsInput,@+id/deviceGps]</code>
+
:<code>@+id/myCallbackBlock</code> - callbackWidgetWhenDistanceReceived<br>
 +
:<code>gn:act_set</code> - callbackWidgetActionSet<br>
 +
:; ⤷ <code>[gn:act_calculateDrivingDistance]|[,@+id/calculateDrivingDistance_withCallbackAction_result,,,@+id/myCallbackBlock,gn:act_set;@variable/calculateDrivingDistance_withCallbackAction_pointOne,@variable/calculateDrivingDistance_withCallbackAction_pointTwo]</code>
 +
<hr>
 +
 
 +
===Calculate driving distance and store result into [[Datatypes#rows|rows]]===
 +
 
 +
:;<code>[gn:act_calculateDrivingDistance]|[targetRows,targetColumnNameOrWidgetIdNumber,targetColumnNameOrWidgetIdText,targetTextSuffix;gpsPoint1,gpsPoint2]</code>
 +
 
 +
====Example====
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult</code> - targetRows<br>
 +
:<code>devices_km</code> - targetColumnNameOrWidgetIdNumber<br>
 +
:<code>devices_kmText</code> - targetColumnNameOrWidgetIdText<br>
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult_km</code> - targetTextSuffix<br>
 +
:<code>devicesFullInfo_gps</code> - gpsPoint1<br>
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRows_pointOne</code> - gpsPoint2<br>
 +
:; ⤷ <code>[gn:act_calculateDrivingDistance]|[@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult,devices_km,devices_kmText,@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult_km;devicesFullInfo_gps,@variable/calculateDrivingDistance_storeResultIntoRows_pointOne]</code>
 +
<hr>
 +
 
 +
===Calculate driving distance and store result into [[Datatypes#rows|rows]] with callback action===
 +
 
 +
:;<code>[gn:act_calculateDrivingDistance]|[targetRows,targetColumnNameOrWidgetIdNumber,targetColumnNameOrWidgetIdText,targetTextSuffix,callbackWidgetWhenDistanceReceived,callbackWidgetActionSet;gpsPoint1,gpsPoint2]</code>
 +
 
 +
====Example====
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult</code> - targetRows<br>
 +
:<code>devices_km</code> - targetColumnNameOrWidgetIdNumber<br>
 +
:<code>devices_kmText</code> - targetColumnNameOrWidgetIdText<br>
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult_km</code> - targetTextSuffix<br>
 +
:<code>@+id/myCallbackBlock</code> - callbackWidgetWhenDistanceReceived<br>
 +
:<code>gn:act_set</code> - callbackWidgetActionSet<br>
 +
:<code>devicesFullInfo_gps</code> - gpsPoint1<br>
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointTwo</code> - gpsPoint2<br>
 +
:<code>@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointThree</code> - gpsPoint3<br>
 +
:; ⤷ <code>[gn:act_calculateDrivingDistance]|[@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult,devices_km,devices_kmText,@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult_km,@+id/myCallbackBlock,gn:act_set;devicesFullInfo_gps,@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointTwo,@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointThree]</code>
 +
 
 +
=====Explanation=====
 +
For each row in <code>@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult</code>
 +
:- get the datatype GPS value of the column named <code>devicesFullInfo_gps</code>, <code>calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointTwo</code>,<code>calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointThree</code>
 +
:- asynchronously connect to our osrm server, send gpsPoints and get the distance
 +
:- store the distance into rows <code>calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult</code> same row from where gpsPoints were taken in column <code>devices_km</code> with number DT
 +
:- store the distance (with suffix read from <code>@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult_km</code>) into rows <code>calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult</code> same row from where gpsPoints were taken in column <code>devices_kmText</code> with text DT
 +
:- execute callback on widget <code>@+id/myCallbackBlock</code> for action <code>gn:act_set</code>  
 
<hr>
 
<hr>

Revision as of 06:31, 16 June 2020

gn:act_calculateDrivingDistance

Description
Action is used to calculate driving distance between two GPS coordinates and store the result into target
In order for this action to work, an internet connection must be active because the calculations are done by OSRM server.
Action returns
void

Action signatures

Full signature

[gn:act_calculateDrivingDistance]|[targetRows,targetColumnNameOrWidgetIdNumber,targetColumnNameOrWidgetIdText,targetTextSuffix,callbackWidgetWhenDistanceReceived,callbackWidgetActionSet;gpsPointsDataBlock{n}]
Parameter Description
targetRows target target rows which can be used as source for calculating distance and target for storing calculated distance
targetColumnNameOrWidgetIdNumber target column in row or widget into which calculated distance will be stored
  • rowColumnId id of column in case we want to store into row, column must be of type number
  • widgetId id of widget, widget must support and be of type number
targetColumnNameOrWidgetIdText target column in row or widget into which calculated distance will be stored as text. targetTextSuffix will be appended as suffix to the value
  • rowColumnId id of column in case we want to store into row, column must be of type text
  • widgetId id of widget, widget must support and be of type text
targetTextSuffix source suffix which will be added to targetColumnNameOrWidgetIdText
callbackWidgetWhenDistanceReceived target on which is defined callbackWidgetActionSet
  • widgetId
callbackWidgetActionSet event action set name which will be fired after distance is calculated and stored
  • hardcoded
gpsPointsDataBlock{n} sources which will be included into calculation
  • gps widgets and/or column id's in case targetRows is defined

Calculate driving distance

[gn:act_calculateDrivingDistance]|[,targetColumnNameOrWidgetIdNumber;gpsPoint1,gpsPoint2]

Example

@+id/calculateDrivingDistance_calculateDrivingDistance_result - targetColumnNameOrWidgetIdNumber
@+id/calculateDrivingDistance_calculateDrivingDistance_pointOne - gpsPoint1
@+id/calculateDrivingDistance_calculateDrivingDistance_pointTwo - gpsPoint2
@+id/calculateDrivingDistance_calculateDrivingDistance_pointThree - gpsPoint3
@+id/calculateDrivingDistance_calculateDrivingDistance_pointFour - gpsPoint4
⤷ [gn
act_calculateDrivingDistance]|[,@+id/calculateDrivingDistance_calculateDrivingDistance_result;@variable/calculateDrivingDistance_calculateDrivingDistance_pointOne,@variable/calculateDrivingDistance_calculateDrivingDistance_pointTwo,@variable/calculateDrivingDistance_calculateDrivingDistance_pointThree,@variable/calculateDrivingDistance_calculateDrivingDistance_pointFour]</code>

Calculate driving distance with callback action

[gn:act_calculateDrivingDistance]|[,targetColumnNameOrWidgetIdNumber,,,callbackWidgetWhenDistanceReceived,callbackWidgetActionSet;gpsPoint1,gpsPoint2]

Example

@+id/calculateDrivingDistance_withCallbackAction_result - targetColumnNameOrWidgetIdNumber
@+id/calculateDrivingDistance_withCallbackAction_pointOne - gpsPoint1
@+id/calculateDrivingDistance_withCallbackAction_pointTwo - gpsPoint2
@+id/myCallbackBlock - callbackWidgetWhenDistanceReceived
gn:act_set - callbackWidgetActionSet
[gn:act_calculateDrivingDistance]|[,@+id/calculateDrivingDistance_withCallbackAction_result,,,@+id/myCallbackBlock,gn:act_set;@variable/calculateDrivingDistance_withCallbackAction_pointOne,@variable/calculateDrivingDistance_withCallbackAction_pointTwo]

Calculate driving distance and store result into rows

[gn:act_calculateDrivingDistance]|[targetRows,targetColumnNameOrWidgetIdNumber,targetColumnNameOrWidgetIdText,targetTextSuffix;gpsPoint1,gpsPoint2]

Example

@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult - targetRows
devices_km - targetColumnNameOrWidgetIdNumber
devices_kmText - targetColumnNameOrWidgetIdText
@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult_km - targetTextSuffix
devicesFullInfo_gps - gpsPoint1
@variable/calculateDrivingDistance_storeResultIntoRows_pointOne - gpsPoint2
[gn:act_calculateDrivingDistance]|[@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult,devices_km,devices_kmText,@variable/calculateDrivingDistance_storeResultIntoRows_rowsResult_km;devicesFullInfo_gps,@variable/calculateDrivingDistance_storeResultIntoRows_pointOne]

Calculate driving distance and store result into rows with callback action

[gn:act_calculateDrivingDistance]|[targetRows,targetColumnNameOrWidgetIdNumber,targetColumnNameOrWidgetIdText,targetTextSuffix,callbackWidgetWhenDistanceReceived,callbackWidgetActionSet;gpsPoint1,gpsPoint2]

Example

@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult - targetRows
devices_km - targetColumnNameOrWidgetIdNumber
devices_kmText - targetColumnNameOrWidgetIdText
@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult_km - targetTextSuffix
@+id/myCallbackBlock - callbackWidgetWhenDistanceReceived
gn:act_set - callbackWidgetActionSet
devicesFullInfo_gps - gpsPoint1
@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointTwo - gpsPoint2
@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointThree - gpsPoint3
[gn:act_calculateDrivingDistance]|[@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult,devices_km,devices_kmText,@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult_km,@+id/myCallbackBlock,gn:act_set;devicesFullInfo_gps,@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointTwo,@variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointThree]
Explanation

For each row in @variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult

- get the datatype GPS value of the column named devicesFullInfo_gps, calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointTwo,calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_pointThree
- asynchronously connect to our osrm server, send gpsPoints and get the distance
- store the distance into rows calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult same row from where gpsPoints were taken in column devices_km with number DT
- store the distance (with suffix read from @variable/calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult_km) into rows calculateDrivingDistance_storeResultIntoRowsWithCallbackAction_rowsResult same row from where gpsPoints were taken in column devices_kmText with text DT
- execute callback on widget @+id/myCallbackBlock for action gn:act_set