首页 > 其他分享 >如何使用KrpanoToolJS在浏览器切图

如何使用KrpanoToolJS在浏览器切图

时间:2022-10-09 20:15:01浏览次数:92  
标签:浏览器 string 切图 分辨率 生成 KrpanoToolJS file krpano

如何使用KrpanoToolJS在浏览器切图

  1. 框架DEMO
  2. 框架源码地址
  3. 【独辟蹊径】逆推Krpano切图算法,实现在浏览器切多层级瓦片图

一、功能介绍

在浏览器中将全景图转为立方体图、多层级瓦片图

备注:

  • 切图的逻辑、缩略图、预览图均以krpano为标准,如果是使用krpano来开发全景的,可以直接使用,暂时未开发自定义切图的参数,后续可能会开放。
  • 目前仅支持jpeg/jpg20000x10000分辨率以内的图片,当然这已经是覆盖了80%的使用场景了
  • 切图速度快于krpano命令行工具
  • 如果需要更高的要求还是可以使用krpano工具,也可以混着使用

如下功能:


  1. 生成立方体图片(6个面)
  2. 生成多分辨率瓦片图(层级根据图片分辨率自动调节)
  3. 生成场景预览图preview.jpg
  4. 生成场景缩略图thumb.jpg
  5. 生成krpano代码:场景代码、立方体image节点代码、多分辨率image节点代码(包含简写和完整两种写法)
  6. 生成的图片和场景,均无水印

二、如何使用

安装依赖

npm i @krpano/js-tools

切图,示例:在vue中的使用:

<template>
    <input type="file" name="test" @change="onFileChange" accept="image/jpeg">
</template>

<script>

// (可选)用于下载文件
import FileSaver from 'file-saver'
// 导入
import KrpanoToolJS from '@krpano/js-tools'

export default {
    methods: {
        onFileChange(e) {
            const file = e.target.files[0]
            if (!file) return
            
            const krpanoTool = new KrpanoToolJS()
            krpanoTool.makeTiles(file).then(result => {
                // result 的具体值看下面介绍
                // 可选,可以使用FileSaver,把内容下载下来
                FileSaver.saveAs(result.content)
            })
        },
    }
}
</script>

切图的返回值

// result对象
interface IConvertPanoResult {
    dirName: string;  // 生成根目录文件夹名称
    content: Blob; // 场景图片、缩略图、预览图 的Blob文件,可以用于上传到后台或者下载到本地
    duration: string | number; // 单次切图时长
    code: {  // 代码
        scene: string;  // 整个场景的代码
        cubeImage: string; // 立方体切图image节点的代码
        tileImage: string; // 多分辨率切图image节点的代码
        shortTileImage: string; // (简写)多分辨率切图image节点的代码
    };
}

切图方法

// 生成立方体图(6张)、缩略图、预览图
makeCube(file: File): Promise<IConvertPanoResult>;

// 生成多分辨率瓦片图、缩略图、预览图
makeTiles(file: File): Promise<IConvertPanoResult>;

// 同时生成立方体图、多分辨率瓦片图
makeCubeAndTiles(file: File): Promise<IConvertPanoResult>;

标签:浏览器,string,切图,分辨率,生成,KrpanoToolJS,file,krpano
From: https://www.cnblogs.com/liuqinrui/p/16773476.html

相关文章

  • 一个浏览器上面呈现的内容 是怎么生成的呢?
     浏览器的渲染过程:浏览器从服务器下载完文件后,就要对其进行解析和渲染.HTMLParser将HTML解析转换成DOM树.CSSParser将样式表解析转换成CSS规则树.转换完成后的DOM树......
  • 浏览器
    历史记录chormefirefoxieiehttps://www.xiazaiba.com/hotsoft/ie/https://baike.baidu.com/item/MicrosoftEdge/17511966?fr=aladdinIE浏览器20年1995年:微软Inter......
  • 浏览器中javascript简易实现json数据保存到客户端
    思路很简单,就是利用Blob、URL.createObjectURL()方法和<a>便签的HTML5新属性download来模拟远端文件下载保存。下面直接上代码savePath:function(){varme......
  • Mac的chrome浏览器右键翻译失败解决方案
    右键翻译失败解决办法我们打开chrome浏览器右键翻译老是失败或者重试mac用户打开终端输入nslookupgoogle.cn得到的Adress220.181.174.162保存起来用终端以管理员权......
  • 远程浏览器隔离技术
    1、什么是浏览器隔离?浏览器隔离是一项技术,它通过将加载网页的过程与显示网页的用户设备分开以此来保持浏览活动的安全。这样,潜在的恶意网页代码就不会在用户的设备上运行,......
  • proxy_cfw全局代理_浏览器代理配置(chromium based(edge)/firefox/IDM)
    文章目录​​无须sstap等软件实现虚拟网卡代理​​​​reference​​​​配置步骤​​​​serviceMode​​​​tunMode​​​​检查启用情况​​​​edge浏览器内部代理......
  • 浏览器的渲染过程、回流、重绘
    一、浏览器的渲染过程1.根据HTML生成DOM树浏览器在接收到服务器发来的HTML文件是字节形式的,首先要将字节形式的HTML组建成字符串,然后将字符串转换成token,再将token组装......
  • Chrome浏览器内置翻译功能突然失效(自动翻译失败)解决方案
    解决方案1.找到hosts文件hosts文件的路径C:\Windows\System32\drivers\etc2.修改hosts文件打开hosts文件后,在最下面添加以下两行内容,保存203.208.40.66translate.......
  • Java如何调用HttpURLConnection类模拟浏览器访问呢?
    下文笔者讲述使用Java代码模拟浏览器请求的方法分享,如下所示:实现思路:使用HttpURLConnection类即可模拟浏览器访问例:packagecom.java265.other;importjava.......
  • 前端浏览器打印
    window.print()constbodyHtml=document.body.innerHTMLdocument.body.innerHTML=$0.innerHTMLwindow.print();document.body.innerHTML=bodyHtm......