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

图片压缩工具 | 图片生成PDF文档

OPEN-IMAGE-TINY,一个基于 Electron + VUE3 的图片压缩工具,项目开源地址:https://github.com/0604hx/open-image-tiny

ℹ️ 需求描述

上一版本发布后,有用户提出想要将图片转换(或者说生成更为贴切)PDF文档,于是有了今天要分享的内容。
功能概述:将用户选择的文件,预处理(如裁剪、旋转)后,绘制到新的 PDF 文件内。

📄 关于PDF

PDF(Portable Document Format,便携式文档格式)是当今最广泛使用的电子文档格式之一,几乎成为数字文档交换的代名词。它的发展历程涉及技术创新、商业竞争和标准化演进。

📜发展简史

  • 1991年,Adobe 联合创始人 John Warnock 提出 “Camelot” 计划,目标是创建一种 跨平台、固定布局的电子文档格式,确保在任何设备上都能正确显示。
  • 1993年,Adobe 正式发布 PDF 1.0,配套推出 Acrobat 1.0(用于创建和阅读 PDF 的工具)。
  • 2008年,Adobe 将 PDF 提交给 ISO(国际标准化组织),使其成为开放标准(ISO 32000-1)。

🚀技术演进

版本发布时间重要改进
PDF 1.01993基础文本、图像支持
PDF 1.52003支持 JPEG2000、图层、增强压缩
PDF/A (2005)长期存档标准适合法律、档案存储
PDF/X (2001)印刷出版标准确保颜色、字体精确输出
PDF 2.0 (2017)最新 ISO 标准强化安全、标签化结构

🌍PDF 的现状(2020s+)

1. 无处不在的应用

  • Web 浏览器:Chrome、Firefox 内置 PDF 阅读器。
  • 移动端:iOS/Android 原生支持 PDF 预览。
  • 云服务:Google Drive、Dropbox 直接解析 PDF。
  • 开发者工具:如 pdf-libPDF.jsApache PDFBox

2. 现代 PDF 生态

  • 可编辑 PDF(Adobe Acrobat、Foxit)。
  • PDF 表单(交互式字段,支持电子签名)。
  • OCR 技术(将扫描件转为可搜索文本)。
  • 3D PDF(嵌入三维模型,用于工程图纸)。

3. 竞争对手

  • Office Open XML(DOCX, PPTX):微软的开放文档格式。
  • EPUB:更适合电子书。
  • Web 技术:HTML + CSS 逐渐替代简单 PDF(如在线报告)。

🧑‍💻 技术实现

pdf-lib 库

pdf-lib 是一个强大的 JavaScript/TypeScript 库,用于 创建、修改和操作 PDF 文档。它完全在 Node.js 和浏览器环境中运行,不依赖任何外部服务或原生依赖(如 PDFtk 或 Ghostscript)。

主要功能

  • ✅ 创建新的 PDF 文档
  • ✅ 修改现有的 PDF(如添加文本、图片、水印)
  • ✅ 合并多个 PDF 文件
  • ✅ 提取 PDF 页面
  • ✅ 添加表单字段(如文本框、复选框)
  • ✅ 支持嵌入字体(包括自定义字体)
  • ✅ 支持加密和权限控制

基本用法

创建一个简单的 PDF 文档

import { PDFDocument, rgb } from 'pdf-lib';async function createPdf() {// 创建一个新的 PDF 文档const pdfDoc = await PDFDocument.create();const page = pdfDoc.addPage([550, 750]); // [width, height]// 添加文本page.drawText('Hello, PDF-Lib!', {x: 50,y: 700,size: 30,color: rgb(0, 0, 0), // 黑色});// 保存 PDFconst pdfBytes = await pdfDoc.save();return pdfBytes; // 可写入文件或发送给客户端
}createPdf().then(pdfBytes => {// Node.js 写入文件const fs = require('fs');fs.writeFileSync('output.pdf', pdfBytes);
});

优缺点

✅ 优点

  • 纯 JavaScript,跨平台(Node.js 和浏览器均可运行)
  • API 直观,文档完善
  • 支持现代 PDF 功能(如嵌入字体、表单)
  • 不需要外部依赖(如 PDFtk、Ghostscript)

❌ 缺点

  • 处理超大 PDF 时可能较慢
  • 不支持 PDF 渲染(仅修改结构,不能像 PDF.js 那样显示 PDF)
  • 某些高级 PDF 功能(如 OCR)不支持

核心代码

安装依赖:

pnpm i pdf-lib
const sharp = require('sharp')
const { statSync, writeFileSync } = require('node:fs')
const { PDFDocument } = require('pdf-lib')/*** 图片转换为PDF* @param {sharp.Sharp} img* @param {String} target*/
const toPdf = async (img, target)=>{const pdf = await PDFDocument.create()const page = pdf.addPage()const pdfImg = await pdf.embedJpg(await img.toBuffer())const { width, height } = pdfImg.scale(1)page.setSize(width, height)page.drawImage(pdfImg, { x:0, y:0, width, height })const pdfBytes = await pdf.save()writeFileSync(target, pdfBytes)
}

效果预览

未来展望

能够合并所选图片到一个 PDF 文档。

相关文章:

图片压缩工具 | 图片生成PDF文档

OPEN-IMAGE-TINY,一个基于 Electron VUE3 的图片压缩工具,项目开源地址:https://github.com/0604hx/open-image-tiny ℹ️ 需求描述 上一版本发布后,有用户提出想要将图片转换(或者说生成更为贴切)PDF文档…...

Python的浅拷贝与深拷贝

一、浅拷贝 浅拷贝,指的是重新分配一块内存,创建一个新的对象,但里面的元素是原对象中各个子对象的引用。 浅拷贝有几种方法: 1、 使用数据类型本身的构造器 list1[1,2,3]list2 list(list1) # 使用了数据类型本身的构造器 list…...

VSCode - VSCode 放大与缩小代码

VSCode 放大与缩小代码 1、放大 点击顶部菜单栏【查看】 -> 点击外观 -> 点击【放大】 或者,使用快捷键:Ctrl # 操作方式先按住 Ctrl 键,再按 键2、缩小 点击顶部菜单栏【查看】 -> 点击外观 -> 点击【缩小】 或者&#x…...

消息队列处理模式:流式与批处理的艺术

🌊 消息队列处理模式:流式与批处理的艺术 📌 深入解析现代分布式系统中的数据处理范式 一、流式处理:实时数据的"活水" 在大数据时代,流式处理已成为实时分析的核心技术。它将数据视为无限的流,…...

11-Oracle 23ai Vector Embbeding和ONNX

Embedding (模型嵌入)是 AI 领域的一个核心概念 一、Embedding(嵌入)的含义 Embedding 是一种将 非结构化数据​(如文本、图像、音频、视频)转换为 数值向量的技术。 其核心是通过 嵌入模型​(…...

Build a Large Language Model (From Scratch) 序章

关于本书 《从零构建大型语言模型》旨在帮助读者全面理解并从头创建类似GPT的大型语言模型(LLMs)。 全书首先聚焦于文本数据处理的基础知识和注意力机制的编码,随后指导读者逐步实现一个完整的GPT模型。书中还涵盖了预训练机制以及针对文本…...

【HarmonyOS 5】教育开发实践详解以及详细代码案例

以下是基于 ‌HarmonyOS 5‌ 的教育应用开发实践详解及核心代码案例,结合分布式能力与教育场景需求设计: 一、教育应用核心开发技术 ‌ArkTS声明式UI‌ 使用 State 管理学习进度状态,LocalStorageProp 实现跨页面数据同步(如课程…...

NoSQL 之Redis哨兵

目录 一、Redis 哨兵模式概述 (一)背景与核心目标 (二)基本架构组成 (三)核心功能 二、哨兵模式实现原理 (一)配置关键参数 (二)哨兵节点的定时任务 …...

【nano与Vim】常用命令

使用nano编辑器 保存文件 : 按下CtrlO组合键,然后按Enter键确认文件名。 退出编辑器 : 按下CtrlX组合键。 使用vi或vim编辑器 保存文件 : 按Esc键退出插入模式,然后输入:w并按Enter键保存文件。 退出编辑器 &#xf…...

OpenCV 图像色彩空间转换与抠图

一、知识点: 1、色彩空间转换函数 (1)、void cvtColor( InputArray src, OutputArray dst, int code, int dstCn 0, AlgorithmHint hint cv::ALGO_HINT_DEFAULT ); (2)、将图像从一种颜色空间转换为另一种。 (3)、参数说明: src: 输入图像,即要进行颜…...

Amazing晶焱科技:电子系统产品在多次静电放电测试后的退化案例

在我们的电子设计世界里,ESD(静电放电)问题总是让人头疼。尤其是当客户面临系统失效的困境时,寻找一个能够彻底解决问题的方案就变得格外重要。这一次,我们要谈的是一个经典案例:电子系统产品在多次静电放电…...

Go 中的 Map 与字符处理指南

Go 中的 Map 与字符处理指南 在 Go 中,map 可以存储字符,但需要理解字符在 Go 中的表示方式。在 Go 语言中,"字符" 实际上有两种表示方法:byte(ASCII 字符)和 rune(Unicode 字符&…...

互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计

互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计 郑薪苦怀着忐忑的心情走进了会议室,对面坐着的是某大厂的技术总监张总,一位在云原生领域有着深厚积累的专家。 第一轮面试:微服务网关的设计挑战 张总&#xf…...

C++中const关键字详解:不同情况下的使用方式

在 C 中,const 关键字用于指定一个对象或变量是常量,意味着它的值在初始化之后不能被修改。下面详细介绍 const 修饰变量、指针、类对象和类中成员函数的区别以及注意事项。 修饰变量 详细介绍 当 const 修饰变量时,该变量成为常量&#x…...

Java 2D 图形类总结与分类

一、基本形状类 这些类用于绘制简单的标准几何形状。 1. 圆形 / 椭圆类 Ellipse2D:椭圆基类,支持浮点精度。 子类: Ellipse2D.Double:双精度浮点坐标。Ellipse2D.Float:单精度浮点坐标。 参数:x, y, wid…...

C# 快速检测 PDF 是否加密,并验证正确密码

引言:为什么需要检测PDF加密状态? 在批量文档处理系统(如 OCR 文字识别、内容提取、格式转换)中,加密 PDF 无法直接操作。检测加密状态可提前筛选文件,避免流程因密码验证失败而中断。 本文使用 Free Spire…...

服务器信任质询

NSURLSession 与 NSURLAuthenticationMethodServerTrust —— 从零开始的“服务器信任质询”全流程 目标读者:刚接触 iOS 网络开发、准备理解 HTTPS 与证书校验细节的同学 出发点:搞清楚为什么会有“质询”、质询的触发时机、以及在 delegate 里怎么正确…...

华为云Flexus+DeepSeek征文| 华为云Flexus X实例单机部署Dify-LLM应用开发平台全流程指南

华为云FlexusDeepSeek征文| 华为云Flexus X实例单机部署Dify-LLM应用开发平台全流程指南 前言一、相关名词介绍1.1 华为云Flexus X实例介绍1.2 Dify介绍1.3 DeepSeek介绍1.4 华为云ModelArts Studio介绍 二、部署方案介绍2.1 方案介绍2.2 方案架构2.3 需要资源2.4 本…...

Python: 操作 Excel折叠

💡Python 操作 Excel 折叠(分组)功能详解(openpyxl & xlsxwriter 双方案) 在处理 Excel 报表或数据分析时,我们常常希望通过 折叠(分组)功能 来提升表格的可读性和组织性。本文将详细介绍如何使用 Python 中的两个主流 Excel 操作库 —— openpyxl 和 xlsxwriter …...

IBM官网新闻爬虫代码示例

通常我们使用Python编写爬虫,常用的库有requests(发送HTTP请求)和BeautifulSoup(解析HTML)。但这里需要注意的是,在爬取任何网站之前,务必遵守该网站的robots.txt文件和相关法律法规&#xff0c…...

Java持久层技术对比:Hibernate、MyBatis与JPA的选择与应用

目录 简介持久层技术概述Hibernate详解MyBatis详解JPA详解技术选型对比最佳实践与应用场景性能优化策略未来发展趋势总结与建议 简介 在Java企业级应用开发中,持久层(Persistence Layer)作为连接业务逻辑与数据存储的桥梁,其技…...

Spring Boot实现接口时间戳鉴权

Spring Boot实现接口时间戳鉴权,签名(sign)和时间戳(ts)放入请求头(Header)。 一、请求头参数设计 参数名类型说明tsLong13位时间戳(Unix毫秒值),必填&…...

视觉SLAM基础补盲

3D Gaussian Splatting for Real-Time Radiance Field Rendering SOTA方法3DGS contribution传统重建基于点的渲染NeRF 基础知识补盲光栅化SFM三角化极线几何标准的双目立体视觉立体匹配理论与方法立体匹配的基本流程李群和李代数 李群和李代数的映射李代数的求导李代数解决求导…...

STM32外设问题总结

SPI: ①.软件SPI和硬件SPI有什么不一样? 答:软件SPI需要在代码中进行配置相关代码,如配置引脚等,而硬件SPI的话是它已经在硬件上已经配置好SPI了,已经可以直接实现,所以可以直接使…...

Vue-3-前端框架Vue基础入门之VSCode开发环境配置和Tomcat部署Vue项目

文章目录 1 安装配置VSCode1.1 安装中文语言插件1.2 主题颜色1.3 禁用自动更新1.4 开启代码提示设置1.5 安装open in browser插件2 安装配置nodejs2.1 配置环境变量2.2 npm与maven的区别2.3 使用npm避坑3 创建Vue项目3.1 两种创建方式3.2 package.json3.3 安装新的依赖3.4 运行…...

动态IP与静态IP:数字世界的“变脸术”与“身份证”

目录 动态IP:互联网的“游牧民族” 静态IP:数字世界的“常驻公民” 动态VS静态:场景驱动的选择逻辑 未来演进:IP地址的“液态化”趋势 选型指南:没有最好,只有最合适 在互联网的海洋里,每个…...

“一代更比一代强”:现代 RAG 架构的演进之路

编者按: 我们今天为大家带来的文章,作者的观点是:RAG 技术的演进是一个从简单到复杂、从 Naive 到 Agentic 的系统性优化过程,每一次优化都是在试图解决无数企业落地大语言模型应用时出现的痛点问题。 文章首先剖析 Naive RAG 的基…...

My图床项目

引言: 在海量文件存储中尤其是小文件我们通常会用上fastdfs对数据进行高效存储,在现实生产中fastdfs通常用于图片,文档,音频等中小文件。 一.项目中用到的基础组件(Base) 1.网络库(muduo) 我们就以muduo网络库为例子讲解IO多路复用和reactor网络模型 1.1 IO多路复用 我们可以…...

SpringBoot3项目架构设计与模块解析

一、项目概述 这是一个基于SpringBoot3构建的企业级后台管理系统,从项目结构来看,系统采用了经典的分层架构设计,包含完整的控制器层、服务层、数据访问层和实体层。项目整合了Web开发、数据库访问、权限控制等核心功能模块。 二、项目整体…...

C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作

C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作 在.NET 开发中,文件压缩与解压缩是常见的需求。无论是减少存储空间、加速网络传输,还是实现数据备份,System.IO.Compression命名空间都提供了强大的工具。本文将结…...