将Echarts图表导出为图片的三种方式

 第一种 使用 html2canvas 对dom元素截图

    1.npm安装

npm install html2canvas

       yarn安装

yarn add html2canvas

    2.组件引入

import html2canvas from "html2canvas"

    3.代码

// 导出多张图表为一张图片
// dmo元素里的内容转换为canvas,并将canvas下载为图片
const download = () => {
  // 转换成canvas
  html2canvas(document.getElementById("echarts")).then(function (canvas) {
    var img = canvas
      .toDataURL("image/png")
      .replace("image/png", "image/octet-stream");
    // 创建a标签,实现下载
    var creatIMg = document.createElement("a");
    creatIMg.download = "图表.png"; // 设置下载的文件名,
    creatIMg.href = img; // 下载url
    document.body.appendChild(creatIMg);
    creatIMg.click();
    creatIMg.remove(); // 下载之后把创建的元素删除
  });
};

第二种 使用Echarts官方文档中的 getDataURL 方法

// 导出单个图表图片
function Export() {
  var img = new Image();
  // pieMyChart1 要导出的图表
  img.src = pieMyChart1.value.getDataURL({
    type: "png",
    pixelRatio: 1, //放大2倍
    backgroundColor: "#fff",
  });
  img.onload = function () {
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0);
    var dataURL = canvas.toDataURL("image/png");

    var a = document.createElement("a");
    var event = new MouseEvent("click");
    a.download = "图片.png" || "下载图片名称";
    // 将生成的URL设置为a.href属性
    a.href = dataURL;
    // 触发a的单击事件
    a.dispatchEvent(event);
    a.remove();
  };
}

第三种 使用Echarts官方文档中的 toolbox

toolbox: {
      show: true,
      orient: "vertical",
      left: "right",
      top: "center",
      feature: {
        saveAsImage: { show: true },  // 保存图表
      },
},

完整代码

<template>
  <el-scrollbar>
    <div style="padding: 10px 10px 0">
      <el-button type="primary" @click="refresh">刷新</el-button>
      <el-button @click="download">下载</el-button>
      <el-button @click="Export">导出pie</el-button>
    </div>
    <el-divider />
    <div id="echarts">
      <div class="about" id="main"></div>
      <div class="about" id="pie"></div>
    </div>
  </el-scrollbar>
</template>

<script setup>
import { ref, getCurrentInstance, onMounted } from "vue";
import html2canvas from "html2canvas";

const { appContext } = getCurrentInstance();
const { $echarts } = appContext.config.globalProperties;

onMounted(() => {
  setEcharts();
});

const pieMyChart1 = ref(null);
const setEcharts = () => {
  // 基于准备好的dom,初始化echarts实例
  var myChart = $echarts.init(document.getElementById("main"));
  // 绘制图表
  myChart.setOption({
    title: {
      text: "ECharts 入门示例",
    },
    tooltip: {},
    xAxis: {
      data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"],
      axisTick: {
        // 坐标轴刻度标签
        show: false,
      },
    },
    yAxis: {
      type: "value", // 类型数值轴
      min: 0,
      max: 40,
      splitNumber: 8, // 坐标轴的分割段数
      axisLine: {
        show: true,
      },
      axisTick: {
        show: false, // 隐藏刻度
      },
    },
    series: [
      {
        name: "销量",
        type: "bar",
        label: {
          show: true,
          fontSize: 16,
        },
        data: [5, 20, 36, 10, 10, 20],
        itemStyle: {
          borderRadius: 5,
          borderWidth: 1,
          borderType: "solid",
          borderColor: "#73c0de",
        },
      },
    ],
  });
  // 绘制图表
  const pieMyChart = $echarts.init(document.getElementById("pie"));
  pieMyChart1.value = pieMyChart;
  pieMyChart.setOption({
    title: {
      text: "ECharts 入门示例",
      titleStyle: {
        lineHeight: 18,
      },
      top: "0px",
    },
    tooltip: {},
    legend: {
      orient: "vertical",
      x: "left",
      data: ["A", "B", "C", "D", "E"],
      top: "80px",
    },
    toolbox: {
      show: true,
      orient: "vertical",
      left: "right",
      top: "center",
      feature: {
        saveAsImage: { show: true }, // 保存图表
      },
    },
    series: [
      {
        type: "pie",
        data: [
          {
            value: 335,
            name: "A",
          },
          {
            value: 234,
            name: "B",
          },
          {
            value: 548,
            name: "C",
          },
          {
            value: 500,
            name: "D",
          },
          {
            value: 500,
            name: "E",
          },
        ],
      },
    ],
  });
};

// 页面刷新
const refresh = () => {
  location.reload();
};

// 导出多张图表为一张图片
// dmo元素里的内容转换为canvas,并将canvas下载为图片
const download = () => {
  // 转换成canvas
  html2canvas(document.getElementById("echarts")).then(function (canvas) {
    var img = canvas
      .toDataURL("image/png")
      .replace("image/png", "image/octet-stream");
    // 创建a标签,实现下载
    var creatIMg = document.createElement("a");
    creatIMg.download = "图表.png"; // 设置下载的文件名,
    creatIMg.href = img; // 下载url
    document.body.appendChild(creatIMg);
    creatIMg.click();
    creatIMg.remove(); // 下载之后把创建的元素删除
  });
};

// 导出单个图表图片
function Export() {
  var img = new Image();
  img.src = pieMyChart1.value.getDataURL({
    type: "png",
    pixelRatio: 1, //放大2倍
    backgroundColor: "#fff",
  });
  img.onload = function () {
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0);
    var dataURL = canvas.toDataURL("image/png");

    var a = document.createElement("a");
    var event = new MouseEvent("click");
    a.download = "图片.png" || "下载图片名称";
    // 将生成的URL设置为a.href属性
    a.href = dataURL;
    // 触发a的单击事件
    a.dispatchEvent(event);
    a.remove();
  };
}
</script>

<style>
.el-scrollbar {
  height: calc(100vh - 59px);
}
.el-divider--horizontal {
  margin: 10px 0;
}
#echarts {
  padding: 20px;
  width: 600px;
}
#main {
  height: 300px;
  width: 600px;
}
#pie {
  height: 300px;
  width: 600px;
}
</style>

### 解决方案 在 VSCode 中遇到 `detectgraph` 未定义标识符的问题通常是因为缺少必要的头文件或者库链接不正确。为了使该函数正常工作,需要引入相应的图形库并配置编译环境。 #### 头文件包含 确保包含了正确的头文件。对于 `detectgraph` 函数来说,应该是在使用旧版的 C 图形库(如 BGI),因此需加入如下语句: ```c #include <graphics.h> ``` 此头文件提供了访问低级绘图命令的功能[^1]。 #### 安装图形库支持包 由于这些图形接口属于较早时期的 Borland Graphics Interface (BGI),现在主流的操作系统不再默认提供此类功能的支持。如果希望继续沿用这套 API,则可以考虑安装第三方模拟工具或移植到其他平台上去实现相似的效果。 一种解决方案是利用 MinGW-w64 下提供的 winbgim 库,在 Windows 上重现经典的 Turbo C/C++ 编程体验。可以通过以下方式获取它: - 访问 [winbgim GitHub 页面](https://github.com/viniciusmiguel/winbgim)下载最新版本; - 按照项目文档中的指示完成设置过程; 另外也可以寻找适用于当前开发环境的新一代替代品,比如 SDL2、SFML 或者 Allegro5 等跨平台多媒体框架。 #### 配置编译选项 当确认已经成功集成了所需的图形库之后,还需要调整项目的构建属性以便能够找到外部依赖项的位置以及指定额外的连接参数。具体操作取决于所使用的构建系统(Makefile、CMakeLists.txt 等)。如果是通过任务运行器直接调用 gcc/g++ 来执行编译的话,那么可以在终端里追加 `-L/path/to/libraries -l<library_name>` 形式的标志来指明静态/动态链接库路径及其名称。 例如,假设已将 winbgim 放置于本地磁盘上的某个目录下,并且想要将其作为共享对象加载进来,就可以这样写: ```bash gcc program.c -o output.exe -I"C:\path\to\include" -L"C:\path\to\lib" -lbgi -lgdi32 -lcomdlg32 -luuid -loleaut32 -lole32 ``` 这里 `-I` 参数用来告知预处理器去哪里查找自定义宏定义和类型声明,而后面的几个 `-l` 则分别对应着不同的 WinAPI 功能模块[^2]。 #### 测试验证 最后一步就是编写简单的测试案例以检验修复措施是否生效。下面给出了一段用于展示窗口创建及基本绘制操作的小例子供参考: ```c #include <stdio.h> #include <conio.h> /* _kbhit(), getch() */ #include <graphics.h> int main() { int gd = DETECT, gm; initgraph(&gd,&gm,""); // 初始化图形模式 circle(320, 240, 100); outtextxy(320 - textwidth("Hello") / 2, 240 + textheight("World") / 2, "Hello World"); while (!_kbhit()) { delay(100); } getch(); closegraph(); // 关闭图形模式 return 0; } ``` 上述代码片段展示了如何打开一个新的画布并在其中呈现圆形与文字字符串。一旦程序结束前按下任意键就会关闭显示的内容并退出应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值