当前位置: 首页 > article >正文

如何在JavaScript中快速生成专业的PowerPoint演示文稿

如何在JavaScript中快速生成专业的PowerPoint演示文稿【免费下载链接】PptxGenJSBuild PowerPoint presentations with JavaScript. Works with Node, React, web browsers, and more.项目地址: https://gitcode.com/gh_mirrors/pp/PptxGenJSPptxGenJS是一个功能强大的JavaScript库让开发者能够在浏览器、Node.js、React等多种环境中通过代码自动生成高质量的PowerPoint演示文稿。这个开源工具无需安装Microsoft Office或任何第三方软件就能创建符合Open Office XML标准的PPTX文件兼容Microsoft PowerPoint、Apple Keynote、LibreOffice Impress和Google Slides等主流演示软件。 从零开始5分钟创建你的第一个演示文稿环境准备与快速安装无论你是前端开发者还是后端工程师PptxGenJS都能无缝集成到你的项目中。安装过程极其简单# 使用npm安装 npm install pptxgenjs # 或者使用yarn yarn add pptxgenjs对于浏览器环境你可以直接通过CDN引入script srchttps://cdn.jsdelivr.net/gh/gitbrent/pptxgenjs/dist/pptxgen.bundle.js/script创建基础演示文稿让我们从一个最简单的示例开始仅需4行代码就能生成一个完整的PPT文件// 1. 创建演示文稿实例 const pptx new PptxGenJS(); // 2. 添加幻灯片 const slide pptx.addSlide(); // 3. 添加文本内容 slide.addText(Hello PptxGenJS!, { x: 1, y: 1, w: 8, h: 2, fontSize: 32, color: #2D3748, bold: true, align: center }); // 4. 保存文件 pptx.writeFile({ fileName: my-first-presentation.pptx });这个简单的例子展示了PptxGenJS的核心工作流程创建实例、添加幻灯片、添加内容、保存文件。整个过程完全通过JavaScript控制无需任何图形界面操作。PptxGenJS能够将HTML表格自动转换为格式化的PowerPoint幻灯片实现网页数据到演示文稿的无缝转换 实战应用构建数据驱动的业务报告动态数据可视化在实际业务场景中我们经常需要将数据库中的数据转换为演示文稿。PptxGenJS让这个过程变得异常简单// 模拟业务数据 const salesData { title: 2024年Q1销售报告, quarters: [一月, 二月, 三月], revenue: [125000, 138000, 152000], profit: [45000, 52000, 61000], growthRate: [12.5, 15.8, 18.2] }; // 创建演示文稿 const pptx new PptxGenJS(); pptx.setLayout(LAYOUT_WIDE); // 添加封面页 const coverSlide pptx.addSlide(); coverSlide.addText(salesData.title, { x: 0.5, y: 2, w: 9, h: 1.5, fontSize: 36, color: #2C5282, bold: true, align: center }); // 添加数据图表页 const chartSlide pptx.addSlide(); chartSlide.addText(季度收入趋势, { x: 0.5, y: 0.5, w: 9, h: 0.8, fontSize: 24, color: #2D3748 }); // 创建柱状图 chartSlide.addChart(pptx.ChartType.COLUMN, [ { name: 收入, labels: salesData.quarters, values: salesData.revenue }, { name: 利润, labels: salesData.quarters, values: salesData.profit } ], { x: 1, y: 1.5, w: 8, h: 5, chartColors: [#3182CE, #38A169], showLegend: true, showValue: true }); // 添加数据表格页 const tableSlide pptx.addSlide(); tableSlide.addText(详细销售数据, { x: 0.5, y: 0.5, w: 9, h: 0.8, fontSize: 24 }); tableSlide.addTable([ [季度, 收入, 利润, 增长率], [一月, $125,000, $45,000, 12.5%], [二月, $138,000, $52,000, 15.8%], [三月, $152,000, $61,000, 18.2%] ], { x: 1, y: 1.5, w: 8, border: { type: solid, pt: 1, color: E2E8F0 }, fill: { color: F7FAFC }, fontSize: 14 }); // 保存文件 pptx.writeFile({ fileName: ${salesData.title}.pptx });企业级模板系统对于需要统一品牌形象的企业PptxGenJS支持创建和使用幻灯片母版// 创建企业品牌模板 function createCorporateTemplate(pptx) { // 定义主母版 pptx.defineSlideMaster({ title: CORPORATE_MASTER, background: { color: FFFFFF }, objects: [ // 公司Logo { type: image, path: logo.png, x: 0.5, y: 0.2, w: 1.5, h: 0.8 }, // 页脚 { type: text, text: © 2024 公司名称 - 机密信息, options: { x: 0.5, y: 6.8, w: 9, h: 0.3, fontSize: 10, color: 666666, align: center } } ], slideNumber: { x: 9.2, y: 6.8, color: 666666 } }); // 定义标题页布局 pptx.defineSlideMaster({ title: TITLE_LAYOUT, background: { fill: { color: 2C5282 } }, objects: [ { type: text, text: placeholder, options: { x: 0.5, y: 2, w: 9, h: 1.5, fontSize: 36, color: FFFFFF, bold: true, align: center, placeholder: true } } ] }); } // 使用模板创建演示文稿 const pptx new PptxGenJS(); createCorporateTemplate(pptx); // 使用标题布局 const titleSlide pptx.addSlide({ masterName: TITLE_LAYOUT }); titleSlide.addText(季度业务报告, { placeholder: placeholder }); // 使用企业母版 const contentSlide pptx.addSlide({ masterName: CORPORATE_MASTER }); contentSlide.addText(核心业务指标, { x: 0.5, y: 1, w: 9, h: 0.8, fontSize: 28, color: 2D3748 });PptxGenJS支持完整的幻灯片母版系统可以定义统一的品牌模板确保所有演示文稿都符合企业视觉规范 高级功能打造专业级演示文稿多媒体内容集成现代演示文稿需要丰富的多媒体元素PptxGenJS支持图片、视频、音频等多种媒体类型const pptx new PptxGenJS(); // 添加本地图片 const slide1 pptx.addSlide(); slide1.addImage({ path: company-logo.png, x: 0.5, y: 0.5, w: 2, h: 1, hyperlink: { url: https://company.com } }); // 添加网络图片 slide1.addImage({ path: https://example.com/chart.png, x: 3, y: 2, w: 5, h: 3, rounding: true, // 圆角效果 shadow: { type: outer, opacity: 0.5, blur: 10 } }); // 添加视频封面支持YouTube链接 const slide2 pptx.addSlide(); slide2.addText(产品演示视频, { x: 0.5, y: 0.5, w: 9, h: 0.8, fontSize: 24 }); slide2.addMedia({ type: video, path: https://www.youtube.com/watch?vdQw4w9WgXcQ, x: 1, y: 1.5, w: 8, h: 4.5, cover: video-thumbnail.jpg }); // 添加音频图标 slide2.addShape(pptx.ShapeType.SOUND, { x: 8.5, y: 0.2, w: 0.5, h: 0.5, fill: { color: 4299E1 } });动画与过渡效果为演示文稿添加动画效果可以提升观众的注意力const pptx new PptxGenJS(); const slide pptx.addSlide(); // 文本进入动画 slide.addText(主要观点, { x: 1, y: 1, w: 8, h: 1, fontSize: 32, bold: true, animation: { type: fly, // 飞入动画 direction: in, // 进入方向 speed: medium } }); // 形状动画 slide.addShape(pptx.ShapeType.ROUNDED_RECTANGLE, { x: 2, y: 2.5, w: 6, h: 3, fill: { color: E6FFFA }, line: { color: 38B2AC, pt: 2 }, animation: { type: zoom, // 缩放动画 speed: fast, start: withPrevious // 与上一个动画同时开始 } }); // 设置幻灯片过渡效果 slide.slideTransition { type: fade, // 淡入淡出 speed: 1000, // 1秒 direction: horizontal // 水平方向 };使用PptxGenJS可以创建具有专业品牌背景的演示文稿确保视觉一致性和专业性 跨平台应用场景浏览器端实时生成在Web应用中用户可以直接在浏览器中生成并下载演示文稿// 前端React组件示例 import React, { useState } from react; import pptxgen from pptxgenjs; function ReportGenerator() { const [loading, setLoading] useState(false); const generatePresentation async (reportData) { setLoading(true); try { const pptx new pptxgen(); // 根据用户数据动态生成内容 reportData.sections.forEach((section, index) { const slide pptx.addSlide(); slide.addText(section.title, { x: 0.5, y: 0.5, w: 9, h: 1, fontSize: 28, bold: true }); // 添加内容 section.content.forEach((item, itemIndex) { slide.addText(• ${item}, { x: 1, y: 1.8 (itemIndex * 0.5), w: 8, h: 0.4, fontSize: 16 }); }); }); // 在浏览器中下载 await pptx.writeFile({ fileName: report-${Date.now()}.pptx }); } catch (error) { console.error(生成失败:, error); } finally { setLoading(false); } }; return ( button onClick{() generatePresentation(userData)} disabled{loading} {loading ? 生成中... : 下载报告} /button ); }服务器端批量处理在Node.js环境中可以实现自动化批量生成const PptxGenJS require(pptxgenjs); const fs require(fs).promises; const path require(path); async function generateMonthlyReports(monthlyData) { const reports []; for (const monthData of monthlyData) { const pptx new PptxGenJS(); // 设置演示文稿属性 pptx.title ${monthData.month}月度报告; pptx.author 自动化报告系统; pptx.company 公司名称; // 生成内容 const slide pptx.addSlide(); slide.addText(${monthData.month}销售报告, { x: 0.5, y: 2, w: 9, h: 1.5, fontSize: 36, align: center }); // 生成图表 slide.addChart(pptx.ChartType.BAR, [{ name: 销售额, labels: monthData.products, values: monthData.sales }], { x: 1, y: 4, w: 8, h: 4 }); // 保存为Buffer const buffer await pptx.write({ outputType: nodebuffer }); reports.push({ month: monthData.month, buffer: buffer, filename: report-${monthData.month}.pptx }); } return reports; } // 批量保存到文件系统 async function saveReports(reports, outputDir) { await fs.mkdir(outputDir, { recursive: true }); for (const report of reports) { const filePath path.join(outputDir, report.filename); await fs.writeFile(filePath, report.buffer); console.log(已生成: ${filePath}); } } 常见问题与解决方案中文显示问题如果中文内容显示为方块或默认字体需要正确设置中文字体const pptx new PptxGenJS(); // 方法1设置全局字体 pptx.setFontFace(Microsoft YaHei); // Windows系统 // 或 pptx.setFontFace(PingFang SC); // macOS系统 // 方法2为特定文本设置字体 slide.addText(中文内容示例, { x: 1, y: 1, w: 8, h: 2, fontSize: 24, fontFace: SimHei, // 黑体 color: #333333 }); // 方法3嵌入自定义字体需要字体文件 pptx.embedFont({ filename: custom-chinese-font.ttf, family: CustomChineseFont });性能优化建议处理大型演示文稿时可以采用以下优化策略// 1. 分块处理大型数据集 async function generateLargePresentation(data, chunkSize 50) { const pptx new PptxGenJS(); for (let i 0; i data.length; i chunkSize) { const chunk data.slice(i, i chunkSize); // 为每个数据块创建幻灯片 chunk.forEach((item, index) { const slide pptx.addSlide(); // 添加内容... }); // 每处理50页保存一次中间结果 if (pptx.getSlides().length % 50 0) { console.log(已处理 ${pptx.getSlides().length} 页); } } return pptx.writeFile({ fileName: large-presentation.pptx }); } // 2. 图片压缩优化 slide.addImage({ path: large-image.jpg, x: 1, y: 1, w: 8, h: 5, compress: true, // 启用压缩 sizing: { type: cover }, // 智能裁剪 dpi: 96 // 降低分辨率 }); // 3. 使用异步处理 async function processBatch(items) { const promises items.map(async (item) { const pptx new PptxGenJS(); // 生成单个演示文稿 return pptx.write({ outputType: base64 }); }); return Promise.all(promises); }版本兼容性不同版本的PptxGenJS可能有API差异建议锁定版本在package.json中指定具体版本查看变更日志参考CHANGELOG.md了解版本变化使用TypeScript获得更好的类型提示和API文档{ dependencies: { pptxgenjs: 3.12.0 } } 学习资源与进阶指南官方示例代码项目提供了丰富的示例代码覆盖了所有主要功能基础示例demos/node/demo.js - Node.js环境的基础用法浏览器演示demos/browser/js/main.js - 浏览器环境的完整功能展示React集成demos/vite-demo/src/App.tsx - 现代前端框架集成示例API参考文档核心接口定义提供了完整的类型提示主要接口src/core-interfaces.ts - 所有API的类型定义枚举类型src/core-enums.ts - 常量定义图表生成src/gen-charts.ts - 图表相关功能最佳实践总结模板先行先设计好幻灯片母版再填充内容数据驱动将数据与展示逻辑分离便于维护错误处理添加适当的错误处理和用户反馈性能监控对于大型文档监控生成时间和内存使用测试覆盖确保在不同环境下的兼容性 总结为什么选择PptxGenJSPptxGenJS为JavaScript开发者提供了一个强大而灵活的解决方案用于自动化生成PowerPoint演示文稿。无论是构建报告系统、创建教育课件、还是开发数据分析工具它都能帮助你节省时间自动化重复的PPT制作工作保持一致性确保所有文档符合品牌规范处理动态数据实时生成基于最新数据的报告跨平台运行在浏览器、服务器、桌面应用中都可用完全免费开源MIT许可证无任何使用限制通过本文的指南和示例你已经掌握了使用PptxGenJS创建专业演示文稿的核心技能。现在就开始尝试将你的数据转换为令人印象深刻的演示文稿吧简洁现代的演示文稿设计展示PptxGenJS在视觉设计方面的强大能力适合各种专业场景【免费下载链接】PptxGenJSBuild PowerPoint presentations with JavaScript. Works with Node, React, web browsers, and more.项目地址: https://gitcode.com/gh_mirrors/pp/PptxGenJS创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

相关文章:

如何在JavaScript中快速生成专业的PowerPoint演示文稿

如何在JavaScript中快速生成专业的PowerPoint演示文稿 【免费下载链接】PptxGenJS Build PowerPoint presentations with JavaScript. Works with Node, React, web browsers, and more. 项目地址: https://gitcode.com/gh_mirrors/pp/PptxGenJS PptxGenJS是一个功能强大…...

深度实战:如何用League Akari将英雄联盟游戏效率提升300%的终极秘籍

深度实战:如何用League Akari将英雄联盟游戏效率提升300%的终极秘籍 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 你是否经历过在…...

别再轮询了!用STM32外部中断(EXTI)实现按键响应,效率提升不止一点点

STM32外部中断实战:从轮询到事件驱动的效率革命 刚接触STM32开发的工程师,往往会在按键检测这类基础功能上陷入"轮询陷阱"——用while循环不断检查GPIO状态,搭配delay_ms函数试图消除抖动。这种模式在51单片机时代或许可行&#x…...

SignalTap调试进阶:巧用约束与别名捕获FPGA优化后的关键信号

1. 为什么优化后的信号会"消失"? 很多FPGA工程师都遇到过这样的场景:明明在代码里明确定义了reg和wire信号,但在SignalTap里死活找不到它们的身影。这其实不是工具出了问题,而是Quartus的综合优化在"作怪"。…...

还在手动整理ai会议纪要浪费宝贵下班时间?2026年这4款真香AI工具3分钟搞定3小时会议

作为挖了快三年AI效率工具的爱好者,我上周刚被3小时项目复盘会的纪要搞到加班到九点,试了一圈新出的工具,直接给大家上结论:听脑AI是目前同类会议纪要工具里最值得用的,没有之一。 直达链接:https://iting…...

Python实战:三大曲线平滑技术对比与场景选型指南

1. 曲线平滑处理的必要性 当你处理传感器数据、金融时间序列或任何带有噪声的曲线时,原始数据往往像一条暴躁的蚯蚓——上下乱窜让人抓狂。我在处理工业传感器数据时就遇到过这种情况:一条本该平滑的温度曲线,因为电磁干扰变成了"心电图…...

告别手机外放‘破音’:深入拆解SmartPA技术如何拯救MTK平台的音频体验

告别手机外放‘破音’:深入拆解SmartPA技术如何拯救MTK平台的音频体验 你是否曾在用手机外放音乐时,遇到音量调大就出现刺耳破音的情况?或是发现低音部分总是软弱无力,完全没有沉浸感?这些问题在采用MTK平台的手机中尤…...

完整指南:3分钟解锁你的加密音乐文件

完整指南:3分钟解锁你的加密音乐文件 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经遇到过这样的情况:从音乐平台下载的歌曲只能在特定应…...

从编码器线数到电子齿轮比:一份给PLC编程员的伺服电机脉冲计算避坑指南

从编码器线数到电子齿轮比:PLC工程师的伺服电机脉冲计算实战手册 在工业自动化领域,伺服系统的精确定位控制一直是工程师面临的核心挑战。当机械臂需要以0.001mm的精度进行装配,或是数控机床要完成微米级的切削时,脉冲计算的准确…...

如何快速解锁中兴光猫:zteOnu工具的完整指南

如何快速解锁中兴光猫:zteOnu工具的完整指南 【免费下载链接】zteOnu A tool that can open ZTE onu device factory mode 项目地址: https://gitcode.com/gh_mirrors/zt/zteOnu 中兴光猫工厂模式解锁神器zteOnu是一款专为网络爱好者设计的开源工具&#xff…...

保姆级教程:在银河麒麟V10上为gcc编译的程序添加可执行权限(附kysec_set命令详解)

银河麒麟V10系统下gcc编译程序执行权限问题全解析 在银河麒麟V10操作系统中,许多开发者首次使用gcc编译程序后,会遇到一个看似简单却令人困惑的问题:明明已经为生成的可执行文件添加了传统Linux权限(如chmod x)&#…...

开源图表实时编辑器:从代码到可视化的无缝创作解决方案

开源图表实时编辑器:从代码到可视化的无缝创作解决方案 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/GitHub_Trending/me/mermaid-live-edito…...

如何用5分钟彻底解决Mac菜单栏混乱?Ice菜单栏管理工具终极指南

如何用5分钟彻底解决Mac菜单栏混乱?Ice菜单栏管理工具终极指南 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice 你是否曾盯着Mac屏幕顶部那密密麻麻的图标海洋感到无力?Wi-Fi图…...

保姆级教程:SAP S/4HANA数据迁移,用LTMC从零导入会计科目(附模板避坑指南)

SAP S/4HANA会计科目迁移实战:LTMC工具全流程详解与避坑手册 当企业首次部署SAP S/4HANA时,会计科目主数据的迁移往往是财务模块实施的关键第一步。不同于传统ECC系统,S/4HANA的简化数据模型对会计科目结构提出了新要求,而Migrati…...

从IEEE 1588到EtherCAT DC:深入对比两种工业网络时间同步协议的核心差异与应用选型

工业网络时间同步技术深度解析:EtherCAT DC与IEEE 1588的实战选型指南 在智能制造和自动化控制领域,毫秒级的响应时间早已成为过去式。现代工业网络对时间同步精度的要求已经进入纳秒时代——这相当于光在真空中仅能传播30厘米的时间跨度。当多个伺服电…...

从Arduino到STM32:GRBL固件选型、下载与刷写全攻略(2024版)

从Arduino到STM32:2024年GRBL固件选型与刷写实战指南 在DIY激光雕刻机和CNC设备的构建过程中,控制器的选择与GRBL固件的配置往往是决定项目成败的关键环节。面对市场上琳琅满目的硬件平台——从经典的Arduino Uno到性能更强的STM32系列开发板&#xff0…...

HS2-HF_Patch终极指南:一站式汉化与功能增强解决方案

HS2-HF_Patch终极指南:一站式汉化与功能增强解决方案 【免费下载链接】HS2-HF_Patch Automatically translate, uncensor and update HoneySelect2! 项目地址: https://gitcode.com/gh_mirrors/hs/HS2-HF_Patch HS2-HF_Patch是《Honey Select 2》玩家的终极解…...

3分钟掌握B站缓存转换:开源m4s-converter工具全攻略

3分钟掌握B站缓存转换:开源m4s-converter工具全攻略 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 还在为B站下架视频而烦恼吗&…...

Windows触控板手势定制终极指南:3个技巧实现高效三指拖拽优化

Windows触控板手势定制终极指南:3个技巧实现高效三指拖拽优化 【免费下载链接】ThreeFingersDragOnWindows Enables macOS-style three-finger dragging functionality on Windows Precision touchpads. 项目地址: https://gitcode.com/gh_mirrors/th/ThreeFinger…...

MLC LLM:大语言模型通用编译部署实战指南

1. 项目概述:当大语言模型遇见“通用编译” 最近几个月,我身边不少做AI应用和部署的朋友都在讨论一个词: MLC LLM 。这可不是一个新的大模型,而是一个旨在解决大语言模型(LLM)部署“最后一公里”问题的开…...

手把手教你用Matlab R2018a为TI C2000 DSP安装Embedded Coder支持包(含账户与版本避坑)

从零搭建Matlab与TI C2000 DSP的嵌入式开发环境:避坑指南与实战解析 当Matlab R2018a遇上TI C2000系列DSP处理器,工程师们便获得了一个从算法设计到硬件部署的完整解决方案。不同于传统的CCS开发模式,这种基于模型的设计(Model-Ba…...

Simulink代码生成实战指南:从模型配置到嵌入式部署

1. Simulink代码生成的核心价值 第一次接触Simulink代码生成功能时,我完全被它的自动化程度震惊了。想象一下,你花了几个月精心设计的控制算法模型,只需要点几下鼠标就能变成可以直接烧录到ECU的C代码,这简直就像魔术一样。不过在…...

归并排序:分治思想的经典应用

归并排序一、核心原理分治思想分:把数组不断从中间拆成左右两半,直到每个子数组只剩 1 个元素(天然有序);治:把两个有序子数组 合并 成一个大的有序数组;递归向上合并,最终整个数组有…...

HoRain云--PHP包含文件全解析

🎬 HoRain 云小助手:个人主页 ⛺️生活的理想,就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站,性价比超高,大内存超划算!忍不住分享一下给大家。点击跳转到网站。 目录 ⛳️ 推荐 …...

插入排序:原理与优化全解析

一、核心原理把数组分为 已排序区间 和 未排序区间从头开始,依次把未排序区间的第一个元素,向前插入到已排序区间的合适位置。类比:打牌摸牌,摸到一张往手里有序牌堆里插。二、算法流程默认第 0 个元素是已排序区间;从…...

别再用Excel手算了!用Python脚本快速搞定Zemax连续变焦镜头初始结构计算

别再用Excel手算了!用Python脚本快速搞定Zemax连续变焦镜头初始结构计算 光学设计工程师们,你们是否还在为连续变焦镜头的初始结构计算而头疼?每次手动调整变倍组和补偿组的位置,反复在Excel中敲打公式,结果却总是差强…...

别再傻傻分不清了!VB、VBS、VBA到底该学哪个?给新手的选型指南

VB、VBS与VBA终极选型指南:从零开始做出明智选择 每次打开Excel想要自动化处理数据时,是否对着宏录制按钮犹豫不决?当需要批量重命名几百个文件时,是否在批处理和VBS之间举棋不定?本文将带您深入理解这三种"VB系…...

ExplorerPatcher:三分钟打造你的专属Windows界面

ExplorerPatcher:三分钟打造你的专属Windows界面 【免费下载链接】ExplorerPatcher This project aims to enhance the working environment on Windows 项目地址: https://gitcode.com/GitHub_Trending/ex/ExplorerPatcher 还在为Windows 11的新界面感到困扰…...

基于Spring Boot的金融级钱包与支付系统设计与实现

1. 项目概述与核心价值 最近在折腾一个需要集成支付功能的项目,后台管理、用户体系都搭好了,就差一个稳定、灵活且能快速上线的钱包与支付模块。找了一圈开源方案,要么太重,耦合了太多业务逻辑;要么太轻,连…...

保姆级教程:用海思Hi3516EV200的himm命令手动切换IRCUT滤镜(附完整Shell脚本)

海思Hi3516EV200开发板实战:手把手教你用himm命令驱动IRCUT滤镜 在嵌入式视觉项目中,红外截止滤镜(IRCUT)的精准控制往往是决定夜间成像质量的关键。对于使用海思Hi3516EV200开发板的开发者来说,官方文档对GPIO底层操…...