按照文中配置编译好的ImageMagick c静态库下载地址:下载地址
项目中需要在linux下开发一个动态库,但是直接链接imagemagick动态库,会发现最后生成的动态库所依赖的库将近100来个。
如下图,依赖库太多,展示一部分:
基本都是imagemagick的依赖库,因此,编译ImageMagick静态库势在必行。
首先解压缩ImageMagick.tar.gz
tar xvzf ImageMagick.tar.gz
cd ImageMagick-7.0.5
然后,开始编译。既然要做一个便携版本,用不上的模块就先尽可能去掉。
CFLAGS="-fPIC" ./configure --prefix=/usr/local/ImageMagick --enable-shared=no --enable-static=yes --with-djvu=no --with-fontconfig=no --with-freetype=no --with-magick-plus-plus=no --with-openexr=no --with-pango=no --with-wmf=no --with-x=no
这几项的意思分别是:
DJVU 扫描格式,PDF的替代品
freetype 字体光栅化
magick-plus-plus mafick++
Pango 文字渲染
wmf windows 矢量图
OpenEXR exr格式
我项目中只是简单对图像的操作,不涉及文字绘制,用的是magick c库,因此将如上的全都去掉。
ImageMagick的默认选项就是同时生成静态库和动态库,为了生成便携的静态库版本,配置项中需声明--enable-shared=no --enable-static=yes。而开头的CFLAGS="-fPIC",是因为linux64 下,必须使用位置无关代码,否则使用生成的ImageMagick静态库编译连接自己动态库时,会连接失败,显示“
relocation R_X86_64_32 against `a local symbol' can not be used when making a shared object; recompile with -fPIC
... could not read symbols: Bad value”。
接下来,直接make就可以了。
make
make install
make完成,会在/usr/local下生成ImageMagick文件夹,所需要的静态库在lib目录下,头文件在include目录下,可直接使用。
makefile文件中连接ImageMagick目录和库方式如下:
INCLUDES=-I/usr/local/ImageMagick/include/ImageMagick-7
LIBS=-L/usr/local/ImageMagick/lib -Wl,-Bstatic -lMagickWand-7.Q16HDRI -lMagickCore-7.Q16HDRI -L/usr/local/lib -Wl,-Bdynamic -liconv
在应用程序需要连接外部库的情况下,linux默认对库的连接是使用动态库,在找不到动态库的情况下再选择静态库。
当对动态库与静态库混合连接的时候,需要作用-Wl的方式:
-Wl,-Bstatic -lMagickWand-7.Q16HDRI -lMagickCore-7.Q16HDRI -L/usr/local/lib -Wl,-Bdynamic -liconv
另外还要注意系统的运行库使用动态连接的方式,所以当动态库在静态库前面连接时,必须在命令行最后使用动态连接的命令才能正常连接
-Wl,-Bdynamic -liconv -Wl,-Bstatic -lMagickWand-7.Q16HDRI -lMagickCore-7.Q16HDRI -L/usr/local/lib -Wl,-Bdynamic
最后的-Wl,-Bdynamic表示将缺省库链接模式恢复成动态链接。
再来重新make自己的动态库,ldd看一下,如下图,为所有的依赖库,只剩下十几个系统库了,棒棒的。