MIF格式详解,javascript加载导出 MIF文件示例

在这里插入图片描述

MIF 格式详解

MIF(MapInfo Interchange Format)是由Pitney Bowes Software开发的一种文本格式,用于存储地理空间数据。它通常与地图可视化和地理信息系统(GIS)相关联。MIF文件通常成对出现,一个.mif文件用于存储几何数据,另一个.mid文件用于存储属性数据。以下是MIF格式的一些关键点:

MIF 文件结构
  • 头部信息

    • VERSION:指定MIF文件的版本。
    • Charset:指定字符编码,默认为"WindowsLatin1"
    • Delimiter:指定分隔符,默认为空格。
    • CoordSys:定义坐标系统,可以是地理坐标系(如WGS84)或投影坐标系。
  • 列定义

    • Columns:列出每个字段的名称和类型,例如"ID Integer""NAME Char(25)"等。
  • 数据部分

    • Data:表示数据部分的开始。
    • 几何对象(Point, Line, Region, etc.):每个几何对象以关键字开头,后面跟着具体的坐标数据。
      • Point:单个点,格式为x y
      • Line:线段,由一系列点组成,格式为N x1 y1 x2 y2 ... xn yn,其中N是点的数量。
      • Region:多边形,格式与Line类似,但首尾相连形成封闭区域。
      • Text:文本注释,包括位置、字体、大小、旋转角度和文本内容。
  • 属性数据

    • .mid 文件包含与.mif文件中几何对象对应的属性数据,每行对应一个几何对象,字段之间用分隔符(默认为空格)分隔。
特点
  • 简单易读:MIF文件是纯文本格式,易于阅读和编辑。
  • 灵活性:支持多种几何类型,并且可以通过自定义字段来存储丰富的属性信息。
  • 兼容性:广泛应用于GIS软件中,如MapInfo Professional、QGIS等。

在JavaScript中加载和导出MIF文件

由于MIF文件主要用于GIS应用,three.js本身并不直接支持MIF格式的加载和导出。但是,你可以使用其他库或者编写自己的解析器来处理MIF文件。下面是一个简单的示例,展示如何在JavaScript中解析和生成MIF文件的内容。请注意,这只是一个基础示例,实际应用中可能需要根据具体需求进行扩展和优化。

加载MIF文件

为了加载MIF文件,你需要解析文件内容并将其转换为可以在three.js中使用的几何体。以下是一个简化的示例,展示如何从MIF文件创建three.js中的几何体:

// 假设你有一个MIF文件的内容作为字符串
const mifContent = `
VERSION 300
Charset "WindowsLatin1"
Delimiter ","
CoordSys Earth Projection 1, 104
Columns 2
  ID Integer
  NAME Char(25)
Data
Point
  10.0 20.0
`;

// 解析MIF内容
function parseMIF(content) {
    const lines = content.split('\n').map(line => line.trim()).filter(line => line.length > 0);
    let i = 0;
    let vertices = [];
    let attributes = [];

    while (i < lines.length) {
        if (lines[i].startsWith('Point')) {
            i++;
            const coords = lines[i].split(' ').map(Number);
            vertices.push(new THREE.Vector3(coords[0], coords[1], 0));
        }
        // 处理其他几何类型(Line, Region, Text)...
        i++;
    }

    return { vertices, attributes };
}

// 创建three.js几何体
function createGeometryFromMIF(mifData) {
    const geometry = new THREE.BufferGeometry();
    const positions = [];

    mifData.vertices.forEach(vertex => {
        positions.push(vertex.x, vertex.y, vertex.z);
    });

    geometry.setAttribute('position', new THREE.Float32BufferAttribute(positions, 3));

    return geometry;
}

// 使用示例
const mifData = parseMIF(mifContent);
const geometry = createGeometryFromMIF(mifData);

const material = new THREE.PointsMaterial({ color: 0xff0000 });
const points = new THREE.Points(geometry, material);

scene.add(points);
导出MIF文件

为了导出MIF文件,你需要将three.js中的几何体和属性信息转换为MIF格式的字符串。以下是一个简化的示例,展示如何将three.js中的点集合导出为MIF文件的内容:

// 假设你有一个three.js的几何体和属性数据
const geometry = new THREE.BufferGeometry().setFromPoints([
    new THREE.Vector3(10, 20, 0),
    new THREE.Vector3(30, 40, 0),
    // 添加更多点...
]);

const attributes = [
    { ID: 1, NAME: 'Point1' },
    { ID: 2, NAME: 'Point2' },
    // 添加更多属性...
];

// 生成MIF内容
function generateMIFContent(vertices, attributes) {
    let mifContent = `VERSION 300\n`;
    mifContent += `Charset "WindowsLatin1"\n`;
    mifContent += `Delimiter ","\n`;
    mifContent += `CoordSys Earth Projection 1, 104\n`;
    mifContent += `Columns 2\n`;
    mifContent += `  ID Integer\n`;
    mifContent += `  NAME Char(25)\n`;
    mifContent += `Data\n`;

    vertices.forEach((vertex, index) => {
        mifContent += `Point\n`;
        mifContent += `${vertex.x} ${vertex.y}\n`;
    });

    // 生成MID内容
    let midContent = '';
    attributes.forEach(attr => {
        midContent += `${attr.ID},${attr.NAME}\n`;
    });

    return { mifContent, midContent };
}

// 使用示例
const { mifContent, midContent } = generateMIFContent(
    Array.from(geometry.attributes.position.array).reduce((points, value, index, array) => {
        if (index % 3 === 0) points.push(new THREE.Vector3(array[index], array[index + 1], array[index + 2]));
        return points;
    }, []),
    attributes
);

// 创建下载链接
function downloadFile(filename, content) {
    const blob = new Blob([content], { type: 'text/plain' });
    const link = document.createElement('a');
    link.href = URL.createObjectURL(blob);
    link.download = filename;
    link.click();
}

// 导出MIF和MID文件
downloadFile('exported_model.mif', mifContent);
downloadFile('exported_model.mid', midContent);

总结

  • MIF 是一种用于存储地理空间数据的文本格式,广泛应用于GIS领域。
  • 加载MIF文件 需要解析文件内容并将其转换为three.js中的几何体。你可以使用现有的GIS库(如Turf.js、GeoJSON等)来帮助处理复杂的几何类型。
  • 导出MIF文件 可以通过将three.js中的几何体和属性信息转换为MIF格式的字符串来实现。
  • 注意事项:MIF格式主要用于GIS应用,因此在three.js中处理MIF文件时,可能需要额外的工具或库来简化几何类型的解析和生成。如果你需要更高级的功能,考虑使用专门的GIS库或工具,如Leaflet、OpenLayers、或QGIS的API。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/937121.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vlan和vlanif

文章目录 1、为什么会有vlan的存在2、vlan(虚拟局域网)1、vlan原理1. 为什么这样划分了2、如何实现不同交换机相同的vlan实现互访呢3、最优化的解决方法&#xff0c;vlan不同交换机4、vlan标签和vlan数据帧 5、vlan实现2、基于vlan的划分方式1、基于接口的vlan划分方式2、基于m…

PyTorch基本使用-自动微分模块

学习目的&#xff1a;掌握自动微分模块的使用 训练神经网络时&#xff0c;最常用的算法就是反向传播。在该算法中&#xff0c;参数&#xff08;模型权重&#xff09;会根据损失函数关于对应参数的梯度进行调整。为了计算这些梯度&#xff0c;PyTorch 内置了名为 torch.autogra…

Oracle最佳实践-优化硬解析

前段时间参加oracle CAB&#xff0c;oracle高级服务部门做了一个数据库最佳实践的报告&#xff0c;其中就有一项就是解决未使用绑定变量但执行次数很多的SQL&#xff1b; 对于一个数据库来说如果不知道该如何优化&#xff0c;那么最简单最有效的优化就是减少硬解析&#xff0c;…

源码编译jdk11 超详细教程 openjdk11

关于源代码 当前的openJDK的源代码已经被发布到了github上了&#xff0c;所以我们可以直接从github上下载到。 OpenJDK11u源码托管地址&#xff1a;https://github.com/openjdk/jdk11u 带后缀U的地址&#xff0c;或者发行的jdk包&#xff0c;表示当前版本下的持续跟新版。而…

STL-vector类

目录 vector介绍及其使用 介绍 使用 vector定义 vector iterator vector内存管理 vector内容管理 vector的模拟实现 vector的迭代器失效 会引起迭代器失效的操作 vector介绍及其使用 介绍 向量是序列容器&#xff0c;表示大小可以变化的数组 见 chttps://cpluspl…

http1.1 vs http2.0 速度对比实测

首先对比一下http1.1 vs http2.0 区别&#xff1a; 1. 连接管理&#xff1a; HTTP/1.1: 每个请求/响应都需要一个独立的 TCP 连接&#xff0c;虽然可以使用持久连接&#xff08;keep-alive&#xff09;来复用连接&#xff0c;但仍然存在请求队头阻塞&#xff08;Head-of-Line…

JAVA学习日记(二十六)网络编程

一、网络编程的概念 常见的软件架构&#xff1a; 二、网络编程三要素 IP&#xff1a;设备在网络中的地址&#xff0c;是唯一的标识 端口号&#xff1a;应用程序在设备中的唯一标识 协议&#xff1a;数据在网络中传输的规则&#xff0c;常见的协议有UDP、TCP、http、https、f…

域名信息(小迪网络安全笔记~

附&#xff1a;完整笔记目录~ ps&#xff1a;本人小白&#xff0c;笔记均在个人理解基础上整理&#xff0c;若有错误欢迎指正&#xff01; 2.1 域名信息 引子&#xff1a;上一章介绍了服务器的信息收集。本篇则介绍在面对存在Web资产企业时&#xff0c;其域名信息该如何收集。…

ubuntu18.04配置实时内核

ubuntu系统&#xff1a;18.04 当前内核&#xff1a;5.4.0-84-generic 待安装实时内核&#xff1a; 5.6.19-rt11 1、查看当前版本 uname -r 2、下载内核与补丁 一种方式从官网自己下载 官方内核下载地址官方补丁下载地址阿里镜像内核下载地址&#xff08;速度快&#xff0…

Lumos学习王佩丰Excel第二十一讲:经典Excel动态图表实现原理

一、动态图表实现原理 1、理解图表中的数据系列 在Excel图表中&#xff0c;系列指的是图表中的数据集合&#xff0c;它通常代表着一个数据源。每个系列都可以包含多个数据点&#xff0c;这些数据点在图表中以特定的形式展现&#xff0c;如柱状图中的柱子&#xff0c;折线图中…

医学分割数据集B超图像肾脏分割数据集labelme格式715张1类别

数据集格式&#xff1a;labelme格式(不包含mask文件&#xff0c;仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数)&#xff1a;715 标注数量(json文件个数)&#xff1a;715 标注类别数&#xff1a;1 标注类别名称:["kidney"] 每个类别标注的框数&#x…

福湘板材:树立行业一线品牌典范

在当今的建筑装修市场中&#xff0c;板材作为一种重要的建筑材料&#xff0c;其品质和性能直接关系到工程质量和使用寿命。福湘板材&#xff0c;作为一个在行业内具有广泛影响力的品牌&#xff0c;一直以来都以高品质、环保性能和卓越的服务赢得了广大消费者的认可&#xff0c;…

redis数据类型(一)

博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:数据库 JavaEE专栏:JavaEE 软件测试专栏:软件测试 关注博主带你了解更多知识 目录 1. String 字符串类型 常见命令: 1. set 2. get 3. MGET和MSET 4.SETNX 5. setex和psetex 计数命令: 1. INCR 2. IN…

在 macOS 下安装和使用 Clang Static Analyzer

在 macOS 下安装和使用 Clang Static Analyzer 相对简单&#xff0c;因为 macOS 自带 Clang 编译器&#xff0c;并且工具链已经包含了静态分析器的功能。以下是详细步骤&#xff1a; 1. 检查系统自带的 Clang macOS 自带 Clang 编译器&#xff0c;安装在 Xcode 或 Xcode Comm…

docker简单私有仓库的创建

1&#xff1a;下载Registry镜像 导入镜像到本地中 [rootlocalhost ~]# docker load -i registry.tag.gz 进行检查 2&#xff1a;开启Registry registry开启的端口号为5000 [rootlocalhost ~]# docker run -d -p 5000:5000 --restartalways registry [rootlocalhost ~]# dock…

搭建mqtt服务端并在Spring Boot项目中集成mqtt

文章目录 一、MQTT1.MQTT 的特点2.MQTT 的工作原理3.MQTT 的应用场景 二、EMQX(服务端)1.EMQX 的特点2.安装 三、客户端1.MQTTX2.EMQX后台建客户端3.H5页面客户端4.Spring Boot集成mqtt做客户端 一、MQTT MQTT&#xff08;Message Queuing Telemetry Transport&#xff0c;消息…

Easysearch Java SDK 2.0.x 使用指南(一)

各位 Easysearch 的小伙伴们&#xff0c;我们前一阵刚把 easysearch-client 更新到了 2.0.2 版本&#xff01;借此详细介绍下新版客户端的使用。 新版客户端和 1.0 版本相比&#xff0c;完全重构&#xff0c;抛弃了旧版客户端的一些历史包袱&#xff0c;从里到外都焕然一新&am…

《计算机视觉证书:开启职业发展新航道》

一、引言 在当今科技飞速发展的时代&#xff0c;计算机视觉技术正以惊人的速度改变着我们的生活和工作方式。从智能手机的人脸识别解锁到自动驾驶汽车的环境感知&#xff0c;计算机视觉技术的应用无处不在。而计算机视觉证书作为这一领域的专业认证&#xff0c;其作用愈发凸显…

ubuntu 用 ss-tproxy的最终网络结构

1、包含了AD广告域名筛选 2、Ss-tproxy 国内国外地址分类 3、chinadns-ng解析 4、透明网关 更多细节看之前博客 ubuntu 用ss-TPROXY实现透明代理&#xff0c;基于TPROXY的透明TCP/UDP代理,在 Linux 2.6.28 后进入官方内核。ubuntu 用 ss-tproxy的内置 DNS 前挂上 AdGuardHome…

OpenCV相关函数

一、二值化函数&#xff08;threshold&#xff09; 功能&#xff1a;将灰度图像转换为二值图像&#xff0c;通常用于图像分割。通过设置阈值&#xff0c;把图像中低于阈值的像素设为0&#xff0c;高于阈值的像素设为1。 参数&#xff1a; src&#xff1a;输入图像。 thresh&a…