• 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, // 日志开关,发布的时候记得改成 false
        height: 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
    });
    
  • 相关阅读:
    DataBinding 高级用法
    【剑指offer系列】71. 求1+2+…+n
    【Java编程进阶之路--三大特性】
    猿人学 第一题
    c++八股day2-虚函数表和虚函数表指针的创建时机
    Java的日期与时间之java.time.format.DateTimeFormatter类型简介说明
    深度解析为什么做深度学习,都用python,而不用java或者c++
    【Python练习】task-07 函数的扩展应用
    Mysql优化---避免索引失效的原则
    开发板移植RTOS操作系统,RTOS操作系统适配开发板整理大全
  • 原文地址:https://blog.csdn.net/weixin_44384273/article/details/139793760