node解析dxf文件

1、dxf数据说明

DXF是一种开放的矢量数据格式,可以分为两类:ASCII格式和二进制格式;ASCII具有可读性好的特点,但占用的空间较大;二进制格式则占用的空间小、读取速度快。由于AutoCAD是最流行的CAD系统,DXF也被广泛使用,成为事实上的标准。绝大多数CAD系统都能读入或输出DXF文件。

2、解析库

npm install dxf-parser

3、接口

1、同步解析:parseSync

2、异步解析:parse

4、实现代码

1、读取文件并解析

javascript 复制代码
const DxfParser = require('dxf-parser');
// 读取DXF文件
const fs = require('fs');
const dxfContent = fs.readFileSync('uploads/road-all2.dxf', 'utf-8');

let parser = new DxfParser();

// 解析DXF文件
const { layers, entities } = parser.parseSync(dxfContent);

2、读取图层实体数据,比如提取道路图层的数据

javascript 复制代码
let gcd = entities.filter(item=>{
    return item.layer==="道路";
})

3、将道路数据转图层并存储到geojson

javascript 复制代码
const calculatePoint=(center, startAngle, endAngle, radius)=> {
    // 将角度转换为弧度
    const startRadians = startAngle;
    const endRadians = endAngle;
    // 计算两角度之间的差角度
    let angle = endRadians - startRadians;
    if(angle<0){
      angle += Math.PI;
    }
    //302 - 32
    // -270
    // 302-9
    let step = angle / 20 ;
    let positions = [];
    for(let i=0;i<21;i++){
      let tempAngle = angle>0?startRadians + step*i:startRadians-step*i;
      const x = center.x + radius * Math.cos(tempAngle);
      const y = center.y + radius * Math.sin(tempAngle);
      positions.push([x,y])
    }
    return positions;

  }
  let features = gcd.map(item=>{
    if(item.type==="LINE"){
      let vertices = item.vertices;
      let positions = vertices.map(vertice=>{
        return [vertice.x, vertice.y]
      })
      return {
        type: "Feature",
        geometry: {
          type: "LineString",
          coordinates: positions,
        },
        properties: {}
      }
    } else if(item.type==="ARC"){
      let {radius,startAngle,endAngle,center} = item;
      let positions = calculatePoint(center,startAngle,endAngle,radius);
      return {
        type: "Feature",
        geometry: {
          type: "LineString",
          coordinates: positions,
        },
        properties: {}
      }
    }

  })
  const gcdJSON = {
    type: "FeatureCollection",
    features: features
  };
  fs.writeFile("./data/road-line.json", JSON.stringify(gcdJSON), (err) => {
    if(err){
      console.log(err.message);
    }
    console.log('写入成功');
  })

5、显示结果

相关推荐
ejinxian11 分钟前
Rust GUI框架Azul与Electron、WebView2
前端·javascript·electron
代码不加糖2 小时前
0基础搭建前后端分离项目:实现菜单与界面左右布局
java·前端·javascript·mysql·elementui·mybatis
zhensherlock2 小时前
Protocol Launcher 系列:Tally 快速计数器的深度集成
前端·javascript·typescript·node.js·自动化·github·js
AC赳赳老秦2 小时前
OpenClaw权限管理实操:团队共享Agent,设置操作权限,保障数据安全
服务器·开发语言·前端·javascript·excel·deepseek·openclaw
光影少年2 小时前
Polyline 组件如何绘制渐变区域?
前端·javascript·掘金·金石计划
普通网友2 小时前
JavaScript:ESLint+Prettier 规范代码格式
开发语言·javascript·ecmascript
jiayong233 小时前
第 38 课:任务列表里高亮当前正在查看详情的任务
开发语言·前端·javascript·vue.js·学习
兔子零10243 小时前
GPT-5.5 与 DeepSeek-V4:大模型竞争的本质,正在从“谁更强”变成“谁让成本更低”
前端·javascript·后端
无心使然云中漫步3 小时前
Openlayers调用ArcGis地图服务之一 —— 地图切片(/tile)
前端·arcgis·vue·数据可视化
火山口车神丶3 小时前
如何借助AI进行模块封装DIY
javascript·人工智能·算法