var x = [0, 1, 2, 3];
var y = [0,1,2];

// 数据集1
var data1 = [
  [0, 0, 0], [0, 1, 0], [0, 2, 0],
  [1, 0, 0], [1, 1, 0], [1, 2, 0],
  [2, 0, 0.2], [2, 1, 0], [2, 2, 0],
  [3, 0, 0], [3, 1, 0], [3, 2, 0]
];

// 数据集2
var data2 = [
  [0, 0, 0], [0, 1, 0], [0, 2, 0],
  [1, 0, 0.1], [1, 1, 0.1], [1, 2, 1],
  [2, 0, 0.2], [2, 1, 0], [2, 2, 0],
  [3, 0, 0], [3, 1, 0], [3, 2, 0]
];

// 数据集3
var data3 = [
  [0, 0, 0], [0, 1, 1], [0, 2, 0],
  [1, 0, 0.1], [1, 1, 0.1], [1, 2, 1],
  [2, 0, 0.2], [2, 1, 0], [2, 2, 0],
  [3, 0, 0], [3, 1, 0], [3, 2, 0]
];

// 数据集4
var data4 = [
  [0, 0, 0], [0, 1, 1], [0, 2, 0],
  [1, 0, 0.1], [1, 1, 0.1], [1, 2, 2],
  [2, 0, 0.2], [2, 1, 0], [2, 2, 0],
  [3, 0, 0], [3, 1, 0], [3, 2, 0]
];

var data5 = [
  [0, 0, 0], [0, 1, 1], [0, 2, 0],
  [1, 0, 0.1], [1, 1, 0.1], [1, 2, 3],
  [2, 0, 0.2], [2, 1, 0], [2, 2, 0],
  [3, 0, 0], [3, 1, 0], [3, 2, 0]
];

var data6 = [
  [0, 0, 0], [0, 1, 0], [0, 2, 0],
  [1, 0, 0], [1, 1, 0], [1, 2, 3],
  [2, 0, 0.2], [2, 1, 0], [2, 2, 0],
  [3, 0, 0], [3, 1, 0], [3, 2, 0]
];

option = {
  tooltip: {},
  visualMap: {
     show: false,
    max: 1,
    inRange: {
      color: [
        '#313695', '#4575b4', '#74add1',
        '#abd9e9', '#e0f3f8', '#ffffbf',
        '#fee090', '#fdae61', '#f46d43',
        '#d73027', '#a50026'
      ]
    }
  },
title: [
    {
        text: '1. Initial Status:\n\n a). Only depot can generate or\n      remove blocks.\n b). Depot is in pos-2-0.',
        left: '5%',
        top: '25%',
        textStyle: { fontSize: 14 }
    },
    {
        text: [
            '2. Step one:\n\n',
            'a). At the depot (pos-2-0), create a \n     block (robot now has a block);\n',
            'b). Move from pos2-0 to pos1-0,\n     then to pos1-1;\n',
            'c). Place the block at pos-1-2 from \n     pos-1-1, (heights at pos-1-1 and \n     pos-1-2 are both 0); {redText|[Error: heights  \n      at pos-1-1 is 0, pos-1-2 is 1]}\n',
            'd). Back to the pos2-0.'
        ].join(''),
        left: '38%',
        top: '25%',
        textStyle: {
            fontSize: 14,
            rich: {
                redText: {
                    color: 'red'
                }
            }
        }
    },
    {
        text: [
            '3. Step two:\n\n',
            'a). At the depot (pos-2-0), create a \n     block (robot now has a block);\n',
            'b). Move from pos2-0 to pos1-0,\n     then to pos1-1;\n',
            'c). Place the block at pos-0-1 from \n     pos-1-1 (heights are both 0), \n     increasing height of pos-0-1 to 1.\n',
            'd). Back to the pos2-0.'
        ].join(''),
        left: '71%',
        top: '25%',
        textStyle: {
            fontSize: 14,
            rich: {
                redText: {
                    color: 'red'
                }
            }
        }
    },
    {
        text: [
            '4. Step three:\n\n',
            'a). At the depot (pos-2-0), create a \n     block (robot now has a block);\n',
            'b). Move from pos2-0 to pos1-0,\n     then to pos1-1, then move up to pos-0-1;\n',
            'c). Place the block at pos-1-2 from pos-0-1 \n     (heights at pos-0-1 and pos-1-2 are both 1)\n     {redText|[Error: Can not place from pos-0-1 to pos-1-2 directly. \n      pos-0-1 and pos-1-2 are not neighboring positions. \n      According to the rules: Place a block at a neighboring \n      position from the robots current position.]}\n',
            'd). Back to the pos-2-0.'
        ].join(''),
        left: '5%',
        top: '70%',
        textStyle: {
            fontSize: 14,
            rich: {
                redText: {
                    color: 'red'
                }
            }
        }
    },
    {
        text: [
            '5. Step four:\n\n',
            'a). At the depot (pos-2-0), create a \n     block (robot now has a block);\n',
            'b). Move from pos2-0 to pos1-0,\n     then to pos1-1, then move up to \n     pos-0-1;\n',
            'c). Place the block at pos-1-2 from \n     pos-0-1 (heights at pos-0-1 and \n     pos-1-2 are both 2)\n    {redText|[Error: Can not place from pos-0-1 to pos-1-2 \n      directly. pos-0-1 and pos-1-2 are not \n      neighboring positions. According to the rules: \n      Place a block at a neighboring position from \n      the robots current position.]}\n',
            'd). The height at pos-1-2 is now 3, \n     matching the goal.{redText| [Error: height of pos-0-1 \n      is still 1, does not meet the goal.]}'
        ].join(''),
        left: '38%',
        top: '70%',
        textStyle: {
            fontSize: 14,
            rich: {
                redText: {
                    color: 'red'
                }
            }
        }
    },
    {
        text: '6. Goal Status:\n\n  a). Build blocks so that the height at \n       pos-1-2 is 3.',
        left: '71%',
        top: '70%',
        textStyle: { fontSize: 14 }
    }
],
  grid3D: [
    { boxWidth: 80, boxDepth: 60, boxHeight: 40, left: '-5%', top: '-10%', width: '45%', height: '45%' },
    { boxWidth: 80, boxDepth: 60, boxHeight: 40, left: '28%', top: '-10%', width: '45%', height: '45%' },
    { boxWidth: 80, boxDepth: 60, boxHeight: 40, left: '61%', top: '-10%', width: '45%', height: '45%' },
    { boxWidth: 80, boxDepth: 60, boxHeight: 40, left: '-5%', top: '35%', width: '45%', height: '45%' },
    { boxWidth: 80, boxDepth: 60, boxHeight: 40, left: '28%', top: '35%', width: '45%', height: '45%' },
    { boxWidth: 80, boxDepth: 60, boxHeight: 40, left: '61%', top: '35%', width: '45%', height: '45%' },
    // { boxWidth: 100, boxDepth: 40, boxHeight: 60, left: '55%', top: '55%', width: '45%', height: '45%' }
  ],
  xAxis3D: [
    { type: 'category', grid3DIndex: 0, data: x },
    { type: 'category', grid3DIndex: 1, data: x },
    { type: 'category', grid3DIndex: 2, data: x },
    { type: 'category', grid3DIndex: 3, data: x },
    { type: 'category', grid3DIndex: 4, data: x },
    { type: 'category', grid3DIndex: 5, data: x }
  ],
  yAxis3D: [
    { type: 'category', grid3DIndex: 0, data: y },
    { type: 'category', grid3DIndex: 1, data: y },
    { type: 'category', grid3DIndex: 2, data: y },
    { type: 'category', grid3DIndex: 3, data: y },
    { type: 'category', grid3DIndex: 4, data: y },
    { type: 'category', grid3DIndex: 5, data: y }
  ],
  zAxis3D: [
    { type: 'value', grid3DIndex: 0, max: 5 , axisLabel: {show: false }, axisTick: { show: false }},
    { type: 'value', grid3DIndex: 1, max: 5 , axisLabel: {show: false }, axisTick: { show: false }},
    { type: 'value', grid3DIndex: 2, max: 5 , axisLabel: {show: false }, axisTick: { show: false }},
    { type: 'value', grid3DIndex: 3, max: 5 , axisLabel: {show: false }, axisTick: { show: false }},
    { type: 'value', grid3DIndex: 4, max: 5 , axisLabel: {show: false }, axisTick: { show: false }},
    { type: 'value', grid3DIndex: 5, max: 5 , axisLabel: {show: false }, axisTick: { show: false }},
  ],
  series: [
    {
      type: 'bar3D',
      data: data1.map(function (item) {
        return { value: [item[0], item[1], item[2]] };
      }),
      shading: 'lambert',
      grid3DIndex: 0,
    },
    {
      type: 'bar3D',
      data: data2.map(function (item) {
        return { value: [item[0], item[1], item[2]] };
      }),
      shading: 'lambert',
      grid3DIndex: 1
    },
    {
      type: 'bar3D',
      data: data3.map(function (item) {
        return { value: [item[0], item[1], item[2]] };
      }),
      shading: 'lambert',
      grid3DIndex: 2
    },
    {
      type: 'bar3D',
      data: data4.map(function (item) {
        return { value: [item[0], item[1], item[2]] };
      }),
      shading: 'lambert',
      grid3DIndex: 3
    },
    {
      type: 'bar3D',
      data: data5.map(function (item) {
        return { value: [item[0], item[1], item[2]] };
      }),
      shading: 'lambert',
      grid3DIndex: 4
    },
    {
      type: 'bar3D',
      data: data6.map(function (item) {
        return { value: [item[0], item[1], item[2]] };
      }),
      shading: 'lambert',
      grid3DIndex: 5
    },
  ]
};
