3D Bar Chart
Model: bar3dAMchart.zip
How To Create Your Own
Start by dragging out AM|Charts from the components menu
Resize it to the desired size
Drag out another component nearby (in the example we are using a button)
Select the AM|Chart and the other component and right click, and create group
Delete the other component, so it is just the AM|Chart in the group
Add a tag on the group (this will be used for the program)
Program
Go to programs in the left menu
Click the plus to add a new program, and it will pull up the program editor
In the Program Target Filter type the name of the tag applied to the group
Click the three dots in the top right corner, and select variables
Click the + icon to add a new variable
Click the gear that appears as you hover over the new variable
On the first line type in point, and on the second line put id==$virtualPointRef
Click the gray Save button
Copy and paste the code below into the main section and click the blue save
finstack.eval(point.query, function(data){
queryData=data.result.toObj();
var chart = AmCharts.makeChart(Chart.view, {
"type": "serial",
"theme": "light",
"dataProvider": queryData,
"category": "navName",
"value": "curVal",
"graphs": [ {
"balloonText": "[[navName]]: <b>[[curVal]][[unit]]</b>",
"fillAlphas": 0.8,
"lineAlpha": 0.2,
"type": "column",
"valueField": "curVal"
} ],
"categoryField": "navName",
"depth3D": 20,
"angle": 30,
"rotate": "true",
"categoryAxis": {
"gridPosition": "start",
"fillAlpha": 0.05,
"position": "left",
},
"export": {
"enabled": true
}
} );
});Add string tag query (to group/model) with value set to the query
With Ractive
Start by dragging an AM Chart into the workspace. Next right click and select show/hide so that you will no longer be able to see it
Next drag out Ractive and properties menu with Ractive selected, click Open Editor
In the Ractive Editor copy and paste these lines of code below into the template section and init section and hit save
Template
<div id="am3D" style="width:100%; height:100%;"></div>Init
this.ractive.fire("obtainData");Next were going to add the query
Under Properties and advanced add a tag with the value set to the desired query
Next were going to add the program shown above.
Start by going to Programs in the left menu and clicking the + icon.
Under Program Name, name the program
Under Program Target Filter type in stackRactive
Click the three dots in the top right corner and select variables
Click on the gear that appears as you hover over the word this
Turn on invokes the function and change the dropdown to custom event
In the box below type in obtainData and click the gray save button
Then click the + icon to add a new variable and call it point and in the box under type in id==$virtualPointRef and click the gray save button
Next copy and paste the code below into the main part of the program.
var template = this;
var queryData = query("stackRactive");
finstack.eval(point.query, function(data){
queryData=data.result.toObj();
var test = template.view.querySelector("#am3D");
var chart = AmCharts.makeChart(test, {
"type": "serial",
"theme": "light",
"dataProvider": queryData,
"category": "navName",
"value": "curVal",
"graphs": [ {
"balloonText": "[[navName]]: <b>[[curVal]][[unit]]</b>",
"fillAlphas": 0.8,
"lineAlpha": 0.2,
"type": "column",
"valueField": "curVal"
} ],
"categoryField": "navName",
"depth3D": 20,
"angle": 30,
"rotate": "true",
"categoryAxis": {
"gridPosition": "start",
"fillAlpha": 0.05,
"position": "left",
},
"export": {
"enabled": true
}
} );
});Click the blue save button and your done!