我使用dojo图表中的ThreeD主题显示图表。 当我修改数据时,我可以显示不同的颜色 图中的条形图,我失去了3D外观。
ThreeD的默认颜色为红色
{y:" 15",工具提示:" 15报警",填写:'黄色'}
添加'填充:黄色'在数据项上将条形更改为黄色, 但我失去了3D外观。
关于改变主题颜色并保持3d外观的最佳方法的任何想法?
答案 0 :(得分:0)
只需创建一个基于ThreeD的新主题,并使用您想要使用的颜色更改颜色变量。 我建议你:
答案 1 :(得分:0)
我能够通过从ThreeD.js中获取代码并将其应用到我的应用程序来实现此目的:
var colors = ["#f00", "#0f0", "#00f", "#ff0", "#0ff", "#f0f", "dojox/charting/themes/common"];
var defaultFill = {type: "linear", space: "shape", x1: 0, y1: 0, x2: 100, y2: 0};
// 3D cylinder map is calculated using dojox.gfx3d
var cyl3dMap = [
{o: 0.00, i: 174}, {o: 0.08, i: 231}, {o: 0.18, i: 237}, {o: 0.30, i: 231},
{o: 0.39, i: 221}, {o: 0.49, i: 206}, {o: 0.58, i: 187}, {o: 0.68, i: 165},
{o: 0.80, i: 128}, {o: 0.90, i: 102}, {o: 1.00, i: 174}
];
var hiliteIndex = 2;
var hiliteIntensity = 100;
var lumStroke = 50;
var cyl3dFills = ArrayUtil.map(colors, function(c){
var fill = lang.delegate(defaultFill);
var colors = fill.colors = gradientGenerator.generateGradientByIntensity(c, cyl3dMap),
hilite = colors[hiliteIndex].color;
// add highlight
hilite.r += hiliteIntensity;
hilite.g += hiliteIntensity;
hilite.b += hiliteIntensity;
hilite.sanitize();
return fill;
});
当我为图形数据创建JSON字符串时,我使用cyl3dFill [x]来设置颜色:
{y: "10", tooltip: "10 Alarms", fill: cyl3dFill[3]} //Sets 3D Yellow fill
如果未将填充添加到数据记录,则假定为默认颜色(红色)。 不确定这是不是坏方法,但我喜欢它....
不确定下一个方法对ThreeD主题的作用,但看起来它会改变主题的颜色。无法让方法起作用......