- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我使用以下 lept4j
和 OpenCV
Maven 依赖项:
<!-- Leptonica -->
<dependency>
<groupId>net.sourceforge.lept4j</groupId>
<artifactId>lept4j</artifactId>
<version>1.9.0</version>
</dependency>
<!-- OpenCV -->
<dependency>
<groupId>org.openpnp</groupId>
<artifactId>opencv</artifactId>
<version>3.2.0-1</version>
</dependency>
我想同时使用 OpenCV 和 Leptonica 函数。为此,我需要能够将 Mat 转换为 Pix,并将 Pix 转换为 Mat。
这是我目前拥有的:
public static Pix matToGrayscalePix(Mat mat) {
if (mat == null) {
throw new IllegalArgumentException("Recycled matrix");
}
final byte[] bytes = new byte[(int) mat.total()];
mat.get(0, 0, bytes);
ByteBuffer buff = ByteBuffer.wrap(bytes);
return Leptonica1.pixReadMem(buff, new NativeSize(buff.capacity()));
}
public static Mat pixToGrayscaleMat(Pix pix) {
if (pix == null) {
throw new IllegalArgumentException("Recycled matrix");
}
PointerByReference pdata = new PointerByReference();
NativeSizeByReference psize = new NativeSizeByReference();
int format = net.sourceforge.lept4j.ILeptonica.IFF_TIFF;
Leptonica1.pixWriteMem(pdata, psize, pix, format);
byte[] b = pdata.getValue().getByteArray(0, psize.getValue().intValue());
return new MatOfByte(b).reshape(0, pix.h);
}
但这些功能目前无法使用。我做错了什么?
最佳答案
尝试以下操作:
public static Pix convertMatToPix(Mat mat) {
MatOfByte bytes = new MatOfByte();
Imgcodecs.imencode(".tif", mat, bytes);
ByteBuffer buff = ByteBuffer.wrap(bytes.toArray());
return Leptonica1.pixReadMem(buff, new NativeSize(buff.capacity()));
}
public static Mat convertPixToMat(Pix pix) {
PointerByReference pdata = new PointerByReference();
NativeSizeByReference psize = new NativeSizeByReference();
Leptonica1.pixWriteMem(pdata, psize, pix, ILeptonica.IFF_TIFF);
byte[] b = pdata.getValue().getByteArray(0, psize.getValue().intValue());
Leptonica1.lept_free(pdata.getValue());
return Imgcodecs.imdecode(new MatOfByte(b), Imgcodecs.CV_LOAD_IMAGE_UNCHANGED);
}
关于opencv - Leptonica OpenCV Java 将 Mat 转换为 Pix,反之亦然,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48868503/
当我尝试安装从他们的网站下载的构建 Leptonica 1.72 时:http://www.leptonica.com/download.html使用默认安装路径: ./configure make
我试图找到与蓝线和红线之间的区域相交的黑色像素连续区域的边界框(见下图)。 我已经使用 leptonica 库进行了非常简单的图像处理,并且我知道如何“手动”解决问题。但是,我认为 leptonica
我正在尝试编译然后执行 Leptonica 示例程序 colorquant_reg.c 事实: 操作系统:Ubuntu 位置: leptonlib-1.67/src/colorquant_reg.c
我正在尝试弄清楚如何使用 Leptonica 库提供的分段器进行文档分析。我一直在看 pageseg.c,但我不认为我完全理解它:(! 如果我拍摄图像并将其加载为 PIX 数据类型,我是否调用 pix
我试图在使用 leptonica 处理后将图像保存为 jpeg。我将 python 与 ctypes 一起使用,我的代码是: import ctypes leptlib = "liblept.so"
如何从像素中获取高度和宽度? Pix *image = pixRead((input).c_str()); 最佳答案 使用pixGetWidth和 pixGetHeight : Pix *image
我正在尝试使用 openFrameworks (0.9.0) 和 Xcode 7 构建一个 OSX OCR C++ 应用程序。 OCR 库是 Tesseract,它需要 Leptonica,我已经通过
我正在尝试做两件事 -> 首先,我需要读取图像并裁剪它(坐标/框架将由用户提供)。然后我想对其运行 OCR。 (实际上裁剪和OCR是要严格划分的)。现在我的问题是: 对于 OCR,我使用 Tesser
我在 Android 上面临与 Leptonica 库相同的问题 How to get skew angle from image我尝试了这两种方法 - 使用一个参数和六个参数,我尝试了多种组合。 F
我正在尝试将 Bitmap 转换为 Pix。然而,手动从 Bitmap 读取每个像素并在 Pix 中设置它太慢了。 Pix pix = new Pix(width, height, depth); f
我已经在 $HOME/local 中安装了 leptonica 和 tesseract,tesseract 工作正常,然后是 tesserocr python 包: CPPFLAGS="-I/home
我有一个关于 Leptonica 的有趣问题,我想知道其他 SO 成员是否已经看到了。 我正在进行去歪斜操作,并且存在严重的伪影问题,以至于没有人会正确地接受结果,这会降低图像质量而不是它们带来的好处
我有一个使用 leptonica 的小程序。但是我如何检查安装了哪个版本? #include 最佳答案 一切都在链接时完成。 如果您使用动态链接,您可以以依赖于编译器的方式指定要链接的库的版本。例如
我有一个 PIX 格式的图像,我也有一个 BOX[具有必要的坐标],我想在框中的内容周围画一个边框,例如 - 我查看了文档,但到目前为止我只发现了如何给整个图像加边框,而不仅仅是其中的一个矩形。 最佳
我正在尝试使用 tesseract OCR 扫描名片,我所做的只是在不进行预处理的情况下发送图像,这是我正在使用的代码。 Tesseract* tesseract = [[Tesseract all
我在 Android 上使用 Tesseract,我有以下代码来提取字符串和从图像中读取的框: TessBaseAPI baseApi = new TessBaseAPI(); baseApi.ini
我正在使用 Leptonica 库处理一些图片。之后我想在我的 QT GUI 中显示它们。 Leptonica 使用他们自己的图像格式 Pix,而 QT 使用他们自己的格式 QPixmap。目前对我来
我想知道应该使用什么函数来使用 Leptonica Image Processing 获取 Pix 类型图像的感兴趣区域图书馆。我已经在 OpenCV 中完成了这项工作,并且我想要它在 Leptoni
我有一个由 返回的 Leptonica Pix 对象 TessBaseApi.getThresholdedImage(); 现在,我如何将它转换为位图,以便我可以通过 ImageView 显示它。 l
我正在研究图像处理,并决定阅读颜色量化的工作原理,经过一番阅读后,我找到了 Modified Median Cut Quantization算法。 我一直在阅读 C implementation in
我是一名优秀的程序员,十分优秀!