cancel
Showing results for 
Search instead for 
Did you mean: 
cancel
Showing results for 
Search instead for 
Did you mean: 

Community Tip - Need to share some code when posting a question or reply? Make sure to use the "Insert code sample" menu option. Learn more! X

Displaying information based on property value in Vuforia

morganweiss33
10-Marble

Displaying information based on property value in Vuforia

I am pulling external data into Vuforia Studio from Thingworx. However I want to filter the data being displayed. I attached a photo below of my infotable and my question is: Is it possible to only display data where "shelf_number" is equal to [x] within Vuforia? 

 

Thank you!

ACCEPTED SOLUTION

Accepted Solutions

Hi @morganweiss33 ,

the answer is yes, it is possible.

2 options:

1.) option 1. )my favorite - if you anyways use a service from Thingworx you can define a second service where you call the first service/ or direct  value query (e.g. QueryNumberProperty ) and filter it with query where you pass your filter parameters. As example you can check the following topic ( it is more complex example as your case):

How to bind data with chart?

External Data - Date&Time format

Problem with Time Series Chart

you can call you service later with some code like this below

 

 

 

 

$scope.app.runMyTWXService = function() {
  	var TWXmodelID = 'PlatformSubsystem';
  	var serviceName = 'GetAllStateDefinitions';
  	var parameters = {'propertyName': 'Temp', 'maxItems': 10};  
  	//twx.app.fn.triggerDataService(TWXmodelID, serviceName, parameters);
//return  twx.app.fn.triggerDataService(TWXmodelID, serviceName, '{}');
return $scope.app.mdl[TWXmodelID].svc[serviceName].data;  
};
//

var values= $scope.app.runMyTWXService();
 console.log("value in $scope.app.getListStates()"); 
console.warn(values)//print the values in the console STRG-Shift-I

 

 

 

 

2.) You can call the data and filter it in the javaScript  loop / not so sufficient but for a simple case as in your example it could work fine:

 

 

 

 

//function which calls QueryNumberPropertyHistory
//with parameters 
$scope.app.runMyTWXService = function() {
  var TWXmodelID = 'TES_stream';
  var serviceName = 'QueryNumberPropertyHistory';
  var parameters = {'propertyName': 'angle', 'maxItems': 30};  
  twx.app.fn.triggerDataService(TWXmodelID, serviceName, parameters)
};
// myTest is called by UI button for testing see picture
$scope.myTest=function(){
$scope.app.runMyTWXService();
 $timeout(function() 
  {console.log('retData')
   var retData=$scope.app.mdl['TES_stream'].svc['QueryNumberPropertyHistory'].data
   $scope.RESULT={}
  $scope.myFilter_min=50
   //any value to demonstrate a filter function here value should be > as min value
  var count=0;
  retData.forEach(function(value){
    console.log("value["+ (count++) +"]="+JSON.stringify(value))
    if(value['value'] > $scope.myFilter_min) $scope.RESULT=value;
//the first value which exceed the min filter    
}) },600)
  
  $timeout(()=>{console.warn("$scope.RESULT="+JSON.stringify($scope.RESULT))},2000)
};

 

 

 

Then we can check e.g. the resutl in console:

2020-04-23_16-17-47.jpg

 

For such static tables you can also pass the data as parameter in external data  and set the configuration to call it on statup - in this case you can call the service result directly :

var retData=$scope.app.mdl['TES_stream'].svc['QueryNumberPropertyHistory'].data

 

2020-04-23_16-27-54.jpg

 

View solution in original post

4 REPLIES 4
WilsonT
14-Alexandrite
(To:morganweiss33)

Hi @morganweiss33 ,

 

You can bind the infotable result to 2D Data Grid widget in Vuforia Studio. The widget allows you to select which column to display.

 

Please refer the guide for more information.

Thank you. I was able to do that, my question is: Is there a way to filter what is shown based on a property. One of my values is "shelf_number" so I only want to display values on my data grid where "shelf_number === [x]".

WilsonT
14-Alexandrite
(To:morganweiss33)

Hi @morganweiss33 ,

 

Is there any reason why the filtering cannot be done on Thingworx?

 

 

Hi @morganweiss33 ,

the answer is yes, it is possible.

2 options:

1.) option 1. )my favorite - if you anyways use a service from Thingworx you can define a second service where you call the first service/ or direct  value query (e.g. QueryNumberProperty ) and filter it with query where you pass your filter parameters. As example you can check the following topic ( it is more complex example as your case):

How to bind data with chart?

External Data - Date&Time format

Problem with Time Series Chart

you can call you service later with some code like this below

 

 

 

 

$scope.app.runMyTWXService = function() {
  	var TWXmodelID = 'PlatformSubsystem';
  	var serviceName = 'GetAllStateDefinitions';
  	var parameters = {'propertyName': 'Temp', 'maxItems': 10};  
  	//twx.app.fn.triggerDataService(TWXmodelID, serviceName, parameters);
//return  twx.app.fn.triggerDataService(TWXmodelID, serviceName, '{}');
return $scope.app.mdl[TWXmodelID].svc[serviceName].data;  
};
//

var values= $scope.app.runMyTWXService();
 console.log("value in $scope.app.getListStates()"); 
console.warn(values)//print the values in the console STRG-Shift-I

 

 

 

 

2.) You can call the data and filter it in the javaScript  loop / not so sufficient but for a simple case as in your example it could work fine:

 

 

 

 

//function which calls QueryNumberPropertyHistory
//with parameters 
$scope.app.runMyTWXService = function() {
  var TWXmodelID = 'TES_stream';
  var serviceName = 'QueryNumberPropertyHistory';
  var parameters = {'propertyName': 'angle', 'maxItems': 30};  
  twx.app.fn.triggerDataService(TWXmodelID, serviceName, parameters)
};
// myTest is called by UI button for testing see picture
$scope.myTest=function(){
$scope.app.runMyTWXService();
 $timeout(function() 
  {console.log('retData')
   var retData=$scope.app.mdl['TES_stream'].svc['QueryNumberPropertyHistory'].data
   $scope.RESULT={}
  $scope.myFilter_min=50
   //any value to demonstrate a filter function here value should be > as min value
  var count=0;
  retData.forEach(function(value){
    console.log("value["+ (count++) +"]="+JSON.stringify(value))
    if(value['value'] > $scope.myFilter_min) $scope.RESULT=value;
//the first value which exceed the min filter    
}) },600)
  
  $timeout(()=>{console.warn("$scope.RESULT="+JSON.stringify($scope.RESULT))},2000)
};

 

 

 

Then we can check e.g. the resutl in console:

2020-04-23_16-17-47.jpg

 

For such static tables you can also pass the data as parameter in external data  and set the configuration to call it on statup - in this case you can call the service result directly :

var retData=$scope.app.mdl['TES_stream'].svc['QueryNumberPropertyHistory'].data

 

2020-04-23_16-27-54.jpg

 

Announcements

Top Tags