效果图
源代码
var img = new Image();
var canvas = document.createElement('canvas');
var ctx = canvas.getContext('2d');
img.onload = function () {
var width = canvas.width = img.width;
var height = canvas.height = img.height;
ctx.drawImage(img, 0, 0, width, height);
var imgData = ctx.getImageData(0, 0, width, height);
var data = new Float32Array(imgData.data.length / 4 * 3);
var off = 0;
for (var i = 0; i < imgData.data.length / 4; i++) {
var r = imgData.data[i * 4];
var g = imgData.data[i * 4 + 1];
var b = imgData.data[i * 4 + 2];
var lum = (0.2125 * r + 0.7154 * g + 0.0721 * b);
lum = (lum - 125) / 4 + 50;
data[off++] = i % width;
data[off++] = height - Math.floor(i / width);
data[off++] = lum;
}
myChart.setOption(option = {
tooltip: {},
backgroundColor: '#fff',
xAxis3D: {
type: 'value'
},
yAxis3D: {
type: 'value'
},
zAxis3D: {
type: 'value',
min: 0,
max: 100
},
grid3D: {
show: false,
viewControl: {
alpha: 70,
beta: 0
},
postEffect: {
enable: true,
depthOfField: {
enable: true,
blurRadius: 4,
fstop: 10
}
// SSAO: {
// enable: true
// }
},
boxDepth: 100,
boxHeight: 20,
environment: 'data-gl/asset/starfield.jpg',
light: {
main: {
shadow: true,
intensity: 2
},
ambientCubemap: {
texture: 'data-gl/asset/canyon.hdr',
exposure: 2,
diffuseIntensity: 0.2
}
}
},
series: [{
type: 'bar3D',
shading: 'lambert',
barSize: 0.8,
silent: true,
itemStyle: {
color: function (params) {
var i = params.dataIndex;
var r = imgData.data[i * 4] / 255;
var g = imgData.data[i * 4 + 1] / 255;
var b = imgData.data[i * 4 + 2] / 255;
var lum = (0.2125 * r + 0.7154 * g + 0.0721 * b);
r *= lum * 2;
g *= lum * 2;
b *= lum * 2;
return [r, g, b, 1];
}
},
data: data
}]
});
}
img.src = 'data-gl/asset/sample.jpg';