Linux 上的 FreeImage 返回 -1 格式

FreeImage on Linux returns -1 format

本文关键字:格式 返回 FreeImage 上的 Linux      更新时间:2023-10-16

我是Ubuntu 16.04 LTS的快乐用户。不久前,我尝试从FreeImage的sourceforge页面构建FreeImage。后来我完全卸载了它,并从apt-get安装了相同的版本

sudo apt-get install libfreeimage3

命令。 虽然,问题是一样的。我在Linux版本的Mono中使用FreeImage,尽管即使C++代码仍然存在问题。 假设我们有主.cpp文件,其中包含如下代码:

#include <FreeImage.h>
#include <iostream>
using namespace std;
int main()
{
FreeImage_Initialise();
FREE_IMAGE_FORMAT format = FreeImage_GetFIFFromFilenameU(L"/home/nikys/1.jpg");
cout << format << endl;
FreeImage_DeInitialise();
}

像这样编译后(在类似"apt-get"的安装之后,我将库的链接添加到/usr/lib,以便可以找到它):

g++ -I. -c main.cpp -o main.o -lc -lfreeimage
g++ main.o -o main -lc -lfreeimage

我收到 .exr 和 .jpg 文件的结果"-1"。

问题是,我在 Windows for .NET 上有 FreeImage 库,它为相同的对象返回正确的格式(Linux Mono 上的相同代码,与上述共享对象链接,也给了我"-1",没有任何 DllNotFoundException 或 EntryPointNotFound)。 可能出了什么问题?请求信息,因为我肯定忘记提及男人的重要信息。

UPD1:如果我使用

FREE_IMAGE_FORMAT format = FreeImage_GetFIFFromFilename("/home/nikys/1.jpg");

FREE_IMAGE_FORMAT format = FreeImage_GetFileType("/home/nikys/1.jpg");

我很高兴,像正常人一样拥有"2"。 虽然,对于宽字符串或FreeImage_GetFileTypeU,不是FreeImage_GetFIFFromFilenameU告诉我正确的结果。:(

Linux 用于文件和输入 UTF8 编码,而不是宽字符串。

为了使您的代码在不同的操作系统中工作,您需要用#if defined(OS1)...#else...将一些命令括起来,或者使用多操作系统API,如Qt或wxWidgets。