.NET 以O2S方式 PDF 转图片

依赖下载

O2S.Components.PDFRender4NET.Win

System.Drawing.Common

目录结构

关键代码

PDFTranImgHelp

ini 复制代码
using O2S.Components.PDFRender4NET;
using System;
using System.Collections.Generic;
using System.Drawing;
using System.Drawing.Imaging;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace PDFTo
{
    public enum Definition
    {
        One = 1, Two = 2, Three = 3, Four = 4, Five = 5, Six = 6, Seven = 7, Eight = 8, Nine = 9, Ten = 10
    }
    public class PDFTranImgHelp
    {
        /// <summary>
        /// 将PDF文档转换为图片的方法
        /// </summary>
        /// <param name="pdfInputPath">PDF文件路径</param>
        /// <param name="imageOutputPath">图片输出路径</param>
        /// <param name="imageName">生成图片的名字</param>
        /// <param name="startPageNum">从PDF文档的第几页开始转换</param>
        /// <param name="endPageNum">从PDF文档的第几页开始停止转换</param>
        /// <param name="imageFormat">设置所需图片格式</param>
        /// <param name="definition">设置图片的清晰度,数字越大越清晰</param>
        public static void ConvertPDF2Image(
                string pdfInputPath,
                string imageOutputPath,
                string imageName,
                int startPageNum, 
                int endPageNum, 
                ImageFormat imageFormat, 
                Definition definition)
        {
            PDFFile pdfFile = PDFFile.Open(pdfInputPath);
            if (!Directory.Exists(imageOutputPath))
            {
                Directory.CreateDirectory(imageOutputPath);
            }
            // validate pageNum
            if (startPageNum <= 0)
            {
                startPageNum = 1;
            }
            if (endPageNum > pdfFile.PageCount)
            {
                endPageNum = pdfFile.PageCount;
            }
            if (startPageNum > endPageNum)
            {
                int tempPageNum = startPageNum;
                startPageNum = endPageNum;
                endPageNum = startPageNum;
            }
            // start to convert each page
            for (int i = startPageNum; i <= endPageNum; i++)
            {
                Bitmap pageImage = pdfFile.GetPageImage(i - 1, 56 * (int)definition);
                pageImage.Save(imageOutputPath + imageName +"_"+ i.ToString() + "." + imageFormat.ToString(), imageFormat);
                pageImage.Dispose();
            }
            pdfFile.Dispose();
        }
    }
}

测试

目标PDF

转化结果

调用代码

swift 复制代码
using System.Drawing.Imaging;
using PDFTo;

PDFTranImgHelp.ConvertPDF2Image(
    "Z:\\ocr\\tessdata\\01.pdf", 
    "Z:\\ocr\\tessdata\\", 
    "myPng",
    1,
    1,
    ImageFormat.Png,
    Definition.Ten);
相关推荐
Asthenia04121 小时前
RBAC模块分析:菜单-权限/角色-权限/用户-角色
后端
uhakadotcom1 小时前
MQTT入门:轻量级物联网通信协议
后端·面试·github
ONE_Gua2 小时前
chromium魔改——navigator.webdriver 检测
前端·后端·爬虫
可乐加.糖2 小时前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
Kagol2 小时前
macOS 和 Windows 操作系统下如何安装和启动 MySQL / Redis 数据库
redis·后端·mysql
无名之逆2 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
9号达人2 小时前
java9新特性详解与实践
java·后端·面试
Aurora_NeAr2 小时前
深入理解Java虚拟机-类加载机制
后端
用户98402276679182 小时前
基于 BFF + GRPC 实现数据聚合的功能
后端·grpc
lqstyle2 小时前
序列化界的"复仇者联盟":谁才是拯救你数据的超级英雄?
后端