MuPDF 开源PDF库编译过程记录

2024-02-26 11:08

本文主要是介绍MuPDF 开源PDF库编译过程记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近工作中需要开发一个PDF阅读的功能,开始选择了Android-pdfview开源组件,但是有些PDF文件打开会crash,这个开源组件没有提供jni代码,只能在java层进行捕获,还是无法解决打不开某些pdf文件的问题;只能另寻他家;在网上转了一圈,貌似可行的开源库有pdfbox,iText和MuPDF;最终选择MuPDF做尝试;从github找到了一个demo,运行了一下,前面打不开的pdf文件,使用该库可以代码,并且该库的加载速度和流畅性都由于前者;特意观察了一下内存,发现并没有耗内存的情况,可以放心尝试了;

抱着学习的态度,暂时不选择直接使用这个demo,尝试从MuPDF官网下载原代码自己编译(对NDK这块我还是比较生疏的,只写过一些简单的库);

下面主要记录一下MuPDF源代码编译过程以及遇到的问题和解决办法;

先贴出官网编译指导:

Set up an Android build environment

Download and install the Android SDK. Run the android tool to install the platform tools. Add the tools and platform-tools directories inside the SDK directory to your PATH.

Download and install the Android NDK (r6 or later). Use the 32-bit target NDK if targeting a 32-bit platform! Add the NDK directory to your PATH.

Make sure you have both JDK and ANT installed.

You will also need git and a regular development environment (gcc and gnu make).

Prepare the source

Check out a copy of the mupdf source from git:

~/src $ git clone git://git.ghostscript.com/mupdf.git

Check out the third party library submodules:

~/src/mupdf $ git submodule update --init

Populate the generated directory with the necessary files:

~/src/mupdf $ make generate

Build and debug

Change into the platform/android/viewer directory and edit the local properties configuration file.

~/src/mupdf $ cd platform/android/viewer
~/src/mupdf/platform/android/viewer $ cp local.properties.sample local.properties
~/src/mupdf/platform/android/viewer $ nano local.properties

Build the native code libraries:

~/src/mupdf/platform/android/viewer $ ndk-build

Build the java application:

~/src/mupdf/platform/android/viewer $ ant debug

Install the app on the device or emulator:

~/src/mupdf/platform/android/viewer $ ant debug install

Copy some files onto the device for the app to read:

~/src/mupdf/platform/android/viewer $ adb push .../file.pdf /mnt/sdcard/Download/file.pdf

To see debug messages from the emulator:

~/src/mupdf/platform/android/viewer $ adb logcat

Good luck!


基本的编译流程就是按官网指导来,但是也有一些需要特意说明的地方;

1、我是在windows上编译的,所以必须安装cygwin,选择“devel”和“shells”进行安装(gcc and gnu make);因为只有安装了cygwin,才能执行make命令;

2,在执行ndk-build时遇到了问题,报错了;参考http://www.gezila.com/tutorials/11080.html文章,但是还是报错;最终的解决办法:

首先,修改local.properties文件内容为

sdk.dir=C:\\Documents and Settings\\Administrator\\android-sdks\\platforms\\android-10

   ndk.dir=C:\\android-ndk-r8b

   分别是android sdk 路径和ndk 路径;

再就是看mupdf\platform\android\viewer\jni下的Application.mk文件最下面的内容:

# If the ndk is r8b then workaround bug by uncommenting the following line
#NDK_TOOLCHAIN_VERSION=4.4.3
# If the ndk is newer than r8c, try using clang.
#NDK_TOOLCHAIN_VERSION=clang3.1

对照自己的ndk版本,选择放开哪一行代码,但不是必须的;

我的ndk版本是r10e,所以一开始选择放开NDK_TOOLCHAIN_VERSION=clang3.1,但是不行报错了,如下:

$ ndk-build
Android NDK: WARNING:jni/Android.mk:mupdfcore: LOCAL_LDLIBS is always ignored fo         r static libraries
[armeabi-v7a] Cygwin         : Generating dependency file converter script
[armeabi-v7a] Compile        : mupdf_java <= mupdf.c
/bin/sh: /cygdrive/d/Android/android-ndk-r10e/toolchains/arm-linux-androideabi-c         lang3.1/prebuilt/windows/bin/arm-linux-androideabi-gcc: No such file or director         y
/cygdrive/d/Android/android-ndk-r10e/build/core/build-binary.mk:464: recipe for          target 'obj/local/armeabi-v7a/objs/mupdf_java/mupdf.o' failed
make: *** [obj/local/armeabi-v7a/objs/mupdf_java/mupdf.o] Error 127
对照报错日志看了下我的ndk目录,发现确实没有
android-ndk-r10e/toolchains/arm-linux-androideabi-c         lang3.1/
这个目录,然后就想到Application.mk中放开的那段代码了,就是这段代码指定的这个目录;所以我尝试又把这段代码注释掉,再编译竟然通过了;

如果你也遇到同样的问题,可以尝试我的方法,也可以看下自己toolchains目录下的目录,对照目录尝试修改Application.mk文件中NDK_TOOLCHAIN_VERSION=clang3.1这段代码中指定的clang版本号;


先到这里!

为android平台已编译好的1.8和1.9a版本源代码即demo下载地址:https://github.com/ZhangSir/mupdf-source

这篇关于MuPDF 开源PDF库编译过程记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/748652

相关文章

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

Java高效实现PowerPoint转PDF的示例详解

《Java高效实现PowerPoint转PDF的示例详解》在日常开发或办公场景中,经常需要将PowerPoint演示文稿(PPT/PPTX)转换为PDF,本文将介绍从基础转换到高级设置的多种用法,大家... 目录为什么要将 PowerPoint 转换为 PDF安装 Spire.Presentation fo

5 种使用Python自动化处理PDF的实用方法介绍

《5种使用Python自动化处理PDF的实用方法介绍》自动化处理PDF文件已成为减少重复工作、提升工作效率的重要手段,本文将介绍五种实用方法,从内置工具到专业库,帮助你在Python中实现PDF任务... 目录使用内置库(os、subprocess)调用外部工具使用 PyPDF2 进行基本 PDF 操作使用

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

Java实现为PDF设置背景色和背景图片

《Java实现为PDF设置背景色和背景图片》在日常的文档处理中,PDF格式因其稳定性和跨平台兼容性而广受欢迎,本文将深入探讨如何利用Spire.PDFforJava库,以简洁高效的方式为你的PDF文档... 目录库介绍与安装步骤Java 给 PDF 设置背景颜色Java 给 PDF 设置背景图片总结在日常的

Java轻松实现PDF转换为PDF/A的示例代码

《Java轻松实现PDF转换为PDF/A的示例代码》本文将深入探讨Java环境下,如何利用专业工具将PDF转换为PDF/A格式,为数字文档的永续保存提供可靠方案,文中的示例代码讲解详细,感兴趣的小伙伴... 目录为什么需要将PDF转换为PDF/A使用Spire.PDF for Java进行转换前的准备通过

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe