当前位置: 首页 > news >正文

ThreeJS-截屏下载pdf或者图片时白屏

JS-页面截图下载为pdf
关于如何下载为 pdf 在上面的这篇文章中有写,大家可以看下,下载图片代码在最下面
这时我们发现 three 部分是空白的如下:
在这里插入图片描述
这就多少有点尴尬了,这时我们习惯性的看下后台报错
在这里插入图片描述
是不是发现了惊喜,html2canvas其实已经给我报错了,而且还很贴心的给出了解决方案,我们先上代码:

renderer = new THREE.WebGLRenderer({ antialias: true,  // 启用抗锯齿功能preserveDrawingBuffer: true
});

其实就是给 WebGLRenderer 多传了一个参数,那这个是什么意思呢?请添加图片描述
官方解释:是否保留缓冲区直到手动清除或重写。默认值为false。
preserveDrawingBuffer 是一个WebGL渲染器选项,用于确定是否在多个渲染循环中保留drawing buffer。如果设置为true,则drawing buffer在多个渲染循环中会被保持,这可以提高性能,但可能会占用更多的内存。

请注意,这个选项在WebGL渲染器的默认行为中并不常用,因为通常WebGL会在每次渲染后自动清除drawing buffer。设置preserveDrawingBuffer为true可能会导致性能问题或内存问题,特别是如果你在渲染循环中不断请求帧缓存的像素数据。

下载为图片:

const downloadPDF = () => {const element: any = document.querySelector('.app');// const { scrollHeight, scrollWidth, offsetHeight, height } = element;const opts = {scale: 3, // 缩放比例,提高生成图片清晰度useCORS: true, // 允许加载跨域的图片allowTaint: false, // 允许图片跨域,和 useCORS 二者不可共同使用tainttest: true, // 检测每张图片都已经加载完成logging: true, // 日志开关,发布的时候记得改成 falseheight: element.offsetHeight};html2canvas(element, opts).then((canvas) => {const link = document.createElement('a');// 通过超链接herf属性,设置要保存到文件中的数据link.href = canvas.toDataURL("image/png");link.download = 'aaa.png'; // 下载文件名link.click(); // js代码触发超链接元素a的鼠标点击事件,开始下载文件到本地});
};

请大家注意如果 three 中有用到 CSS2DRenderer 或者 CSS3DRenderer,这个也要加

labelRenderer = new CSS2DRenderer({preserveDrawingBuffer: true
});
http://www.lryc.cn/news/383187.html

相关文章:

  • redis以后台的方式启动
  • 力扣随机一题 哈希表 排序 数组
  • 昇思25天学习打卡营第01天|基本介绍
  • 问题:1、金属基复合材料界面的物理结合是指 #学习方法#媒体
  • 突发!OpenAI停止不支持国家API,7月9日开始执行
  • 大数据集群数据传输
  • css-vxe列表中ant进度条与百分比
  • 网络协议TCP/IP, HTTP/HTTPS介绍
  • STM32高级控制定时器(STM32F103):PWM输出模式
  • TikTok达人背后的品牌影响力与用户增长
  • 零撸广告创业项目:撸包小游戏对接广告联盟app开发
  • 【Web3初识系列】如何连接 Binance Smart Chain通过交易对绘制 k 线?
  • STM32——定时器
  • [20] Opencv_CUDA应用之 关键点检测器和描述符
  • 支持离线翻译任意语言的桌面应用程序;单张图像高效生成高质量的 3D 模型;2500种色彩映射的集合,适用于matplotlib和seaborn
  • BC-Linux 8.6最小化安装的服务器启用GNOME图形化界面
  • 数据库 复习题
  • web前端——CSS
  • STM32学习-HAL库 串口通信
  • 【Linux】进程信号_1
  • Vue71-嵌套(多级)路由
  • Elk安装及使用
  • 【代码随想录】【算法训练营】【第50天】 [1143]最长公共子序列 [1035]不相交的线 [53]买卖股票的最佳时机III [392]判断子序列
  • 【摄像头标定】双目摄像头标定及矫正-opencv(python)
  • PostgreSQL 高可用性与容错性(十三)
  • RabbitMQ的WorkQueues模型
  • 【LeetCode】每日一题:最大子数组和
  • 什么是进程?
  • 后端返回base64文件流下载
  • 云原生面试