Subversion Repositories Applications.papyrus

Compare Revisions

Ignore whitespace Rev 2149 → Rev 2150

/trunk/api/js/dojo1.0/dojox/charting/plot3d/Bars.js
New file
0,0 → 1,66
if(!dojo._hasResource["dojox.charting.plot3d.Bars"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
dojo._hasResource["dojox.charting.plot3d.Bars"] = true;
dojo.provide("dojox.charting.plot3d.Bars");
 
dojo.require("dojox.charting.plot3d.Base");
 
(function(){
 
// reduce function borrowed from dojox.fun
var reduce = function(/*Array*/ a, /*Function|String|Array*/ f, /*Object?*/ o){
// summary: repeatedly applies a binary function to an array from left
// to right; returns the final value.
a = typeof a == "string" ? a.split("") : a; o = o || dojo.global;
var z = a[0];
for(var i = 1; i < a.length; z = f.call(o, z, a[i++]));
return z; // Object
};
 
dojo.declare("dojox.charting.plot3d.Bars", dojox.charting.plot3d.Base, {
constructor: function(width, height, kwArgs){
this.depth = "auto";
this.gap = 0;
this.data = [];
this.material = {type: "plastic", finish: "dull", color: "lime"};
if(kwArgs){
if("depth" in kwArgs){ this.depth = kwArgs.depth; }
if("gap" in kwArgs){ this.gap = kwArgs.gap; }
if("material" in kwArgs){
var m = kwArgs.material;
if(typeof m == "string" || m instanceof dojo.Color){
this.material.color = m;
}else{
this.material = m;
}
}
}
},
getDepth: function(){
if(this.depth == "auto"){
var w = this.width;
if(this.data && this.data.length){
w = w / this.data.length;
}
return w - 2 * this.gap;
}
return this.depth;
},
generate: function(chart, creator){
if(!this.data){ return this; }
var step = this.width / this.data.length, org = 0,
depth = this.depth == "auto" ? step - 2 * this.gap : this.depth,
scale = this.height / reduce(this.data, Math.max);
if(!creator){ creator = chart.view; }
for(var i = 0; i < this.data.length; ++i, org += step){
creator
.createCube({
bottom: {x: org + this.gap, y: 0, z: 0},
top: {x: org + step - this.gap, y: this.data[i] * scale, z: depth}
})
.setFill(this.material);
}
}
});
})();
 
}
/trunk/api/js/dojo1.0/dojox/charting/plot3d/Base.js
New file
0,0 → 1,23
if(!dojo._hasResource["dojox.charting.plot3d.Base"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
dojo._hasResource["dojox.charting.plot3d.Base"] = true;
dojo.provide("dojox.charting.plot3d.Base");
 
dojo.require("dojox.charting.Chart3D");
 
dojo.declare("dojox.charting.plot3d.Base", null, {
constructor: function(width, height, kwArgs){
this.width = width;
this.height = height;
},
setData: function(data){
this.data = data ? data : [];
return this;
},
getDepth: function(){
return this.depth;
},
generate: function(chart, creator){
}
});
 
}
/trunk/api/js/dojo1.0/dojox/charting/plot3d/Cylinders.js
New file
0,0 → 1,69
if(!dojo._hasResource["dojox.charting.plot3d.Cylinders"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
dojo._hasResource["dojox.charting.plot3d.Cylinders"] = true;
dojo.provide("dojox.charting.plot3d.Cylinders");
 
dojo.require("dojox.charting.plot3d.Base");
 
(function(){
 
// reduce function borrowed from dojox.fun
var reduce = function(/*Array*/ a, /*Function|String|Array*/ f, /*Object?*/ o){
// summary: repeatedly applies a binary function to an array from left
// to right; returns the final value.
a = typeof a == "string" ? a.split("") : a; o = o || dojo.global;
var z = a[0];
for(var i = 1; i < a.length; z = f.call(o, z, a[i++]));
return z; // Object
};
 
dojo.declare("dojox.charting.plot3d.Cylinders", dojox.charting.plot3d.Base, {
constructor: function(width, height, kwArgs){
this.depth = "auto";
this.gap = 0;
this.data = [];
this.material = {type: "plastic", finish: "shiny", color: "lime"};
this.outline = null;
if(kwArgs){
if("depth" in kwArgs){ this.depth = kwArgs.depth; }
if("gap" in kwArgs){ this.gap = kwArgs.gap; }
if("material" in kwArgs){
var m = kwArgs.material;
if(typeof m == "string" || m instanceof dojo.Color){
this.material.color = m;
}else{
this.material = m;
}
}
if("outline" in kwArgs){ this.outline = kwArgs.outline; }
}
},
getDepth: function(){
if(this.depth == "auto"){
var w = this.width;
if(this.data && this.data.length){
w = w / this.data.length;
}
return w - 2 * this.gap;
}
return this.depth;
},
generate: function(chart, creator){
if(!this.data){ return this; }
var step = this.width / this.data.length, org = 0,
scale = this.height / reduce(this.data, Math.max);
if(!creator){ creator = chart.view; }
for(var i = 0; i < this.data.length; ++i, org += step){
creator
.createCylinder({
center: {x: org + step / 2, y: 0, z: 0},
radius: step / 2 - this.gap,
height: this.data[i] * scale
})
.setTransform(dojox.gfx3d.matrix.rotateXg(-90))
.setFill(this.material).setStroke(this.outline);
}
}
});
})();
 
}