3d柱状图主要是创建左右两个面,也就是两个柱子,左右两个面颜色稍微要有点不一样,形成一点点对比就行,然后上下用 type: "pictorialBar"
象形柱图来实现底部和顶部的效果,下面代码可以复制到echarts官网运行,会看到一个渐变到透明的3d柱子
const industryColor = {
type: 'linear',
x: 1,
y: 0,
x2: 1,
y2: 1,
colorStops: [
{
offset: 0,
color: '#6CB5EB'
},
{
offset: 1,
color: 'rgba(9,36,83,0.27)'
}
]
};
const industryData = [22, 35, 30, 22, 60, 56];
var option = {
backgroundColor: 'rgba(0, 0, 0, 0.6)',
animation: false,
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
grid: {
left: '0%',
right: '4%',
bottom: '0%',
top: '10px',
containLabel: true
},
xAxis: {
type: 'category',
data: ['种植业', '养殖业', '旅游业', '服务业'],
axisLabel: {
color: '#E6F7FF'
},
axisLine: {
show: true,
lineStyle: {
color: 'rgba(255, 255, 2555, 0.1)'
}
},
axisTick: {
show: false
},
animation: false
},
yAxis: {
type: 'value',
axisLabel: {
color: '#E6F7FF'
},
splitLine: {
show: true,
lineStyle: {
color: 'rgba(255,255,255,0.2)'
}
},
animation: false
},
series: [
{
name: '产业结构',
type: 'bar',
barWidth: 9,
data: industryData,
itemStyle: {
//柱子左面
normal: {
// 重要的是color配置:线性渐变, 从上往下
color: {
type: 'linear',
x: 1,
y: 0,
x2: 1,
y2: 1,
colorStops: [
{
offset: 0,
color: '#6CB5EB'
},
{
offset: 0.8,
color: 'rgba(9, 36, 83, 0.54)'
}
]
}
}
},
tooltip: {
show: false
}
},
{
name: '产业结构',
tooltip: {
show: true,
padding: 100,
position: [-10, '50%'],
borderWidth: 100
},
type: 'bar',
barWidth: 13,
barCategoryGap: '60%',
itemStyle: {
//柱子右面
normal: {
// 重要的是color配置:线性渐变, 从上往下
color: industryColor,
borderWidth: 0.3,
borderColor: 'rgba(9, 36, 83, 0.1)'
}
},
data: industryData,
// 间隔为0
barGap: 0,
z: 5
},
{
z: 10,
name: '产业结构',
// 这里是柱子的顶部,type: "pictorialBar" 可以自定义图形或者使用内置选项
type: 'pictorialBar',
symbolPosition: 'end',
data: industryData,
symbol: 'diamond',
symbolOffset: [0, -10],
symbolRotate: 90,
symbolSize: [3.5, 19.6],
itemStyle: {
normal: {
borderWidth: 0,
color: 'rgba(124, 201, 250, 1)'
}
},
tooltip: {
show: false
}
}
]
};
普通的3d柱子,可以用一个柱子,做从左到右的渐变。或者用两个柱子,和上面透明渐变一样从上到下渐变
var colorArr = ['#0C628C', '#3887D5', '#2570BB'];
var color = {
type: 'linear',
x: 0,
x2: 1,
y: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: colorArr[0]
},
{
offset: 0.5,
color: colorArr[0]
},
{
offset: 0.5,
color: colorArr[1]
},
{
offset: 1,
color: colorArr[1]
}
]
};
const industryData = [22, 35, 30, 25];
var option = {
backgroundColor: 'rgba(0, 0, 0, 0.6)',
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow' // 'shadow' as default; can also be 'line' or 'shadow'
}
},
grid: {
left: '0%',
right: '4%',
bottom: '0%',
top: '10px',
containLabel: true
},
xAxis: {
type: 'category',
data: ['种植业', '养殖业', '旅游业', '服务业'],
axisLabel: {
color: '#E6F7FF'
},
axisLine: {
show: true,
lineStyle: {
color: 'rgba(255, 255, 2555, 0.1)'
}
},
axisTick: {
show: false
}
},
yAxis: {
type: 'value',
axisLabel: {
color: '#E6F7FF'
},
splitLine: {
show: true,
lineStyle: {
color: 'rgba(255,255,255,0.2)'
}
}
},
series: [
{
itemStyle: {
normal: {
// 这里是用一个柱子,从左到右的渐变。也可以用两个柱子做从上往下的渐变,和上面的透明渐变一样用法
color
}
},
data: industryData,
type: 'bar',
barWidth: 18,
z: 2,
name: '产业结构'
},
{
z: 1,
name: '产业结构',
// 柱子底部
type: 'pictorialBar',
data: industryData,
symbol: 'diamond',
symbolOffset: [0, 4],
symbolSize: [20, 8],
itemStyle: {
normal: {
color: color
}
},
tooltip: {
show: false
}
},
{
z: 3,
name: '产业结构',
type: 'pictorialBar',
// 柱子顶部
symbolPosition: 'end',
data: industryData,
symbol: 'diamond',
symbolOffset: [0, -11],
symbolRotate: 90,
symbolSize: [8, 19],
itemStyle: {
normal: {
borderWidth: 2,
color: colorArr[2]
}
},
tooltip: {
show: false
}
}
]
};
带阴影的3d柱子,主要是上要创建两个x轴,阴影的x轴要不显示。然后创建两个3d的柱子,阴影的柱子要用xAxisIndex
关联上阴影的x轴
const situationColor = {
type: 'linear',
x: 1,
y: 0,
x2: 1,
y2: 1,
colorStops: [
{
offset: 0,
color: '#4EF6F6'
},
{
offset: 0.4,
color: '#4EF6F6'
},
{
offset: 1,
color: 'rgba(2, 29, 54, 0.78)'
}
]
};
const industryData = [22, 35, 30, 25];
var option = {
backgroundColor: 'rgba(0, 0, 0, 0.6)',
tooltip: {
trigger: 'axis',
axisPointer: {
// Use axis to trigger tooltip
type: 'shadow' // 'shadow' as default; can also be 'line' or 'shadow'
}
},
grid: {
left: '0%',
right: '4%',
bottom: '0%',
top: '20px',
containLabel: true
},
// 多个x轴
xAxis: [
{
type: 'category',
data: ['7月', '8月', '9月', '10月'],
axisLine: {
show: false,
lineStyle: {
color: '#E6F2FE'
}
},
axisTick: {
show: false
},
},
// 第二个当作阴影柱子的轴,不显示
{
type: 'category',
data: ['7月', '8月', '9月', '10月'],
axisLine: {
show: false,
lineStyle: {
color: '#E6F2FE'
}
},
axisTick: {
show: false
},
show: false
}
],
yAxis: {
type: 'value',
axisLine: {
lineStyle: {
color: '#E6F2FE'
}
},
splitLine: {
show: true,
lineStyle: {
color: 'rgba(255,255,255,0.2)'
}
}
},
series: [
{
name: '村名情意',
type: 'bar',
showSymbol: false,
hoverAnimation: false,
barWidth: 7,
data: industryData,
itemStyle: {
//实体柱子左面
normal: {
borderWidth: 0,
color: {
type: 'linear',
x: 1,
y: 0,
x2: 1,
y2: 1,
colorStops: [
{
offset: 0,
color: '#267A7B'
},
{
offset: 0.5,
color: '#267A7B'
},
{
offset: 1,
color: 'rgba(2, 29, 54, 0.7)'
}
]
}
}
},
tooltip: {
show: false
},
z: 3
},
{
name: '村名情意',
tooltip: {
show: true
},
type: 'bar',
barWidth: 8,
itemStyle: {
//实体柱子右面
normal: {
color: situationColor,
borderWidth: 0
}
},
data: industryData,
barGap: 0,
z: 5
},
{
//实体柱子顶部
z: 10,
name: '村名情意',
type: 'pictorialBar',
symbolPosition: 'end',
data: industryData,
symbol: 'diamond',
symbolOffset: [0, -8],
symbolRotate: 90,
symbolSize: [3, 15.5],
itemStyle: {
normal: {
borderWidth: 0,
color: '#4EF6F6'
}
},
tooltip: {
show: false
}
},
{
//实体柱子底部
z: 1,
name: '村名情意',
type: 'pictorialBar',
symbolPosition: 'start',
data: industryData,
symbol: 'diamond',
symbolOffset: [0, 7.8],
symbolRotate: 90,
symbolSize: [5, 15],
itemStyle: {
normal: {
borderWidth: 0,
color: 'rgba(2, 29, 54, 0.9)'
}
}
},
{
//阴影柱子左面
name: 'a',
// 关联x轴的第二个轴
xAxisIndex: 1,
type: 'bar',
showSymbol: false,
hoverAnimation: false,
barWidth: 7,
// data 要拿到整组数据的最大值
data: Array(industryData.length).fill(Math.max(...industryData)),
itemStyle: {
normal: {
borderWidth: 0,
color: 'rgba(31, 82, 86, 0.85)',
}
},
tooltip: {
show: false
},
z: 1,
},
{
//阴影柱子右面
name: 'a',
// 关联x轴的第二个轴
xAxisIndex: 1,
tooltip: {
show: false
},
type: 'bar',
barWidth: 8,
itemStyle: {
normal: {
color: 'rgba(53, 140, 144, 0.9)',
borderWidth: 0,
}
},
// data 要拿到整组数据的最大值
data: Array(industryData.length).fill(Math.max(...industryData)),
z: 1,
},
{
//阴影柱子顶部
z: 10,
name: 'a',
type: 'pictorialBar',
symbolPosition: 'end',
// data 要拿到整组数据的最大值
data: Array(industryData.length).fill(Math.max(...industryData)),
symbol: 'diamond',
symbolOffset: [0, -8.2],
symbolRotate: 90,
symbolSize: [3, 15.5],
itemStyle: {
normal: {
borderWidth: 0,
color: 'rgba(53, 140, 144, 0.9)'
}
},
tooltip: {
show: false
}
}
]
};
有时柱子会带一些图标,也可以用type: "pictorialBar"
象形柱图来实现,比如下图发光的小图标。这里不需要用3d,需要渐变
var option = {
backgroundColor: 'rgba(0, 0, 0, 0.6)',
tooltip: {
trigger: "axis",
axisPointer: {
type: "shadow",
},
},
grid: {
left: "0%",
right: "43px",
bottom: "0%",
top: 0,
containLabel: true,
},
xAxis: {
type: "value",
show: false,
axisLine: {
lineStyle: {
color: "#E6F2FE",
},
},
},
yAxis: {
type: "category",
data: ["财务公开", "村务公开", "党务公开", "新媒体宣传", "党员在线教育"],
axisLine: {
show: false,
lineStyle: {
color: "#E6F2FE",
},
formatter: "{value} 个",
},
axisTick: {
show: false,
},
},
series: [
{
itemStyle: {
normal: {
label: {
show: true,
position: [340, 0],
valueAnimation: true,
color: "#01DAEA",
formatter: "{c}个",
},
barBorderRadius: [0, 0, 50, 0],
color: {
type: "linear",
x: 0,
y: 0,
x2: 1,
y2: 1,
colorStops: [
{
offset: 0,
color: "#0A74F0", // 0% 处的颜色
},
{
offset: 1,
color: "#49EFFF", // 100% 处的颜色
},
],
},
},
},
data: [91, 78, 157, 435, 672],
type: "bar",
showBackground: true,
barWidth: 12,
backgroundStyle: {
color: "rgba(255, 255, 255, 0.2)",
},
},
{
data: [91, 78, 157, 435, 672],
type: "pictorialBar",
symbolPosition: "end",
symbolRotate: 7,
// 发光的小图标 这里是base64的形式,也可以用网络图片
symbol:
"image://",
symbolOffset: [20, 0],
symbolSize: [36, 26],
z: 10,
},
],
};