码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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
    });
    
  • 相关阅读:
    如何写一份好的吸引人的简历
    基于SSM+Vue的体育馆管理系统的设计与实现
    Java中 \n \f \r \t 含义
    OceanBase社区版4.x核心技术解密
    优化Scrum敏捷需求管理流程,敏捷需求如何管理。
    软考高级架构师:AI 通俗讲解软件维护的类型:正确性维护、适应性维护、完善性维护、预防性维护
    vue使用.filter方法检索数组中指定时间段内的数据
    面试复习题--ANR
    Node.js | 基础完结、综合训练 —— 路由应用实战教程
    ☆☆如何学习MATLAB☆☆
  • 原文地址:https://blog.csdn.net/weixin_44384273/article/details/139793760
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号