PDF文档中图片解析

我们在做PDF文档解析时有时需要解析PDF文档中的图片数据。跟解析文本类似的常见的解决方案也是两种。文档解析跟ocr技术处理。

下面我们来看看使用文档解析的方案来做PDF文档中的图片解析(使用pdfium库)。

以下为读取PDF中图片数据的相关代码:

cpp 复制代码
std::string strPdfPath = "pdf.pdf";
//初始化库
FPDF_InitLibrary();
//加载文档
FPDF_DOCUMENT document = FPDF_LoadDocument(strPdfPath.c_str(), nullptr);
if (!document)
{
    //load error
}
//获取页数
int page_count = FPDF_GetPageCount(document);
//此处我们只演示处理第一页
FPDF_PAGE page = FPDF_LoadPage(document, 0); // 加载第一页 (索引 0)
if (page)
{
    int objCount = FPDFPage_CountObjects(page); //获取当前页的对象数
    for (int i = 0; i < objCount; ++i)
    {
        FPDF_PAGEOBJECT obj = FPDFPage_GetObject(page, i);
        int nObjType = FPDFPageObj_GetType(obj);//对象类型
        switch (nObjType)
        {
            case FPDF_PAGEOBJ_UNKNOWN:
                break;
            case FPDF_PAGEOBJ_IMAGE:
            {
                // 获取图片对象
                FPDF_BITMAP bitmap = FPDFImageObj_GetBitmap(obj);
                //获取宽、高、stride数据
                int nWidth = FPDFBitmap_GetWidth(bitmap);
                int nHeight = FPDFBitmap_GetHeight(bitmap);
                int nStride = FPDFBitmap_GetStride(bitmap);
                //获取format
                /*
                * 0 FPDFBitmap_Unknown        Unknown or unsupported format.
                * 1 FPDFBitmap_Gray            Gray scale bitmap, one byte per pixel.
                * 2 FPDFBitmap_BGR            3 bytes per pixel, byte order: blue, green, red.
                * 3 FPDFBitmap_BGRx            4 bytes per pixel, byte order: blue, green, red, unused.
                * 4 FPDFBitmap_BGRA            4 bytes per pixel, byte order: blue, green, red, alpha.
                */
                //int nFormat = FPDFBitmap_GetFormat(bitmap); 
                //获取METADATA  这个结构中也包含图片大小、x/y-dpi、colorspace等数据
                FPDF_IMAGEOBJ_METADATA imgMetaData;     
                FPDFImageObj_GetImageMetadata(obj, page, &imgMetaData);
                
                //获取图片数据
                int nDataSize = nStride * nHeight;  
                std::vector<uint8_t> imageData(nDataSize);
                FPDFImageObj_GetImageDataRaw(obj, imageData.data(), nDataSize); 
                
                //保存图片
                //TODO:自行实现                                                                                                                                                                                                                                                                                                                                      
            }
            break;
            default:
                break;                               
        }    
    }
}
FPDF_ClosePage(page);

以上即为使用pdfium解析PDF文档中图片数据相关的代码。在实际测试中在word中插入的图片尺寸比转成PDF中的图片尺寸小。但是读到的图片尺寸跟PDF文档中是一致的。

相关推荐
guguhaohao1 小时前
map和set,咕咕咕!
数据结构·c++
喝凉白开都长肉的大胖子1 小时前
比较 main.tex 的两个不同版本(例如旧版和新版),并生成一个带有修改标记(如删除线、高亮、修订注释)的 PDF 或文本输出。
pdf·latex
Larry_Yanan1 小时前
QML学习笔记(五十二)QML与C++交互:数据转换——时间和日期
开发语言·c++·笔记·qt·学习·ui·交互
weixin_441003641 小时前
2025教资面试真题电子版|科目试讲+结构化真题解析|完整PDF
面试·职场和发展·pdf
小兜全糖(xdqt)1 小时前
python ppt转pdf以及图片提取
python·pdf·powerpoint
番石榴AI1 小时前
视频转ppt/pdf V2.0版(新增转为可编辑PPT功能)
人工智能·pdf·powerpoint
满天星83035772 小时前
【C++】智能指针
c语言·开发语言·c++·visual studio
m0_748248023 小时前
基于 C++ 的高性能批量媒体文件压缩程序
c++·人工智能·数据挖掘
Larry_Yanan3 小时前
QML学习笔记(五十三)QML与C++交互:数据转换——序列类型与 JavaScript 数组的转换
c++·笔记·学习
努力努力再努力wz3 小时前
【Linux进阶系列】:线程(上)
java·linux·运维·服务器·数据结构·c++·redis